X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/3e080d01d6559a4caa4d7764d332a4009e28a2d0..c5a10dad40d295619065a8b24ed305eadcd1eac9:/docker/Makefile diff --git a/docker/Makefile b/docker/Makefile index 9cbaed0964..b365b70add 100644 --- a/docker/Makefile +++ b/docker/Makefile @@ -1,47 +1,17 @@ -all: api-image docserver-image workbench-image warehouse-image +all: api-image doc-image workbench-image warehouse-image sso-image -# ============================================================ -# The main Arvados servers: api, docserver, workbench, warehouse - -api-image: base-image $(API_DEPS) - tar -c -z -f api/generated/api.tar.gz -C ../services api - docker build -t arvados/api api - echo -n "Built at $(date)" > api-image - -docserver-image: base-image $(DOCSERVER_DEPS) - tar -c -z -f docserver/generated/doc.tar.gz -C .. doc - docker build -t arvados/docserver docserver - echo -n "Built at $(date)" > docserver-image - -workbench-image: base-image $(WORKBENCH_DEPS) - tar -c -z -f workbench/generated/workbench.tar.gz -C ../apps workbench - docker build -t arvados/workbench workbench - echo -n "Built at $(date)" > workbench-image - -warehouse-image: base-image $(WAREHOUSE_DEPS) - tar -c -z -f warehouse/generated/warehouse.tar.gz -C ../.. warehouse-apps - docker build -t arvados/warehouse warehouse - echo -n "Built at $(date)" > warehouse-image - -# ============================================================ -# The arvados/base image is the base Debian image plus packages -# that are dependencies for every Arvados service. - -base-image: debian-image - docker build -t arvados/base base - echo -n "Built at $(date)" > base-image - -debian-image: - ./mkimage-debootstrap.sh arvados/debian wheezy http://debian.lcs.mit.edu/debian/ - echo -n "Built at $(date)" > debian-image +clean: + -rm *-image */generated/* # ============================================================ # Dependencies for */generated files which are prerequisites # for building docker images. +BASE_DEPS = base/Dockerfile $(BASE_GENERATED) + API_DEPS = api/Dockerfile $(API_GENERATED) -DOCSERVER_DEPS = docserver/Dockerfile docserver/apache2_vhost +DOC_DEPS = doc/Dockerfile doc/apache2_vhost WORKBENCH_DEPS = workbench/Dockerfile \ workbench/passenger.conf \ @@ -51,13 +21,18 @@ WAREHOUSE_DEPS = warehouse/Dockerfile \ warehouse/supervisor.conf \ $(WAREHOUSE_GENERATED) +SSO_DEPS = sso/passenger.conf $(SSO_GENERATED) + +BASE_GENERATED = base/generated + API_GENERATED = \ api/generated/apache2_vhost \ api/generated/config_databases.sh \ api/generated/database.yml \ api/generated/omniauth.rb \ api/generated/production.rb \ - api/generated/secret_token.rb + api/generated/secret_token.rb \ + api/generated/superuser_token API_GENERATED_IN = \ api/apache2_vhost.in \ @@ -65,15 +40,16 @@ API_GENERATED_IN = \ api/database.yml.in \ api/omniauth.rb.in \ api/production.rb.in \ - api/secret_token.rb.in + api/secret_token.rb.in \ + api/superuser_token.in WORKBENCH_GENERATED = \ - workbench/generated/apache_vhost \ + workbench/generated/apache2_vhost \ workbench/generated/production.rb \ workbench/generated/secret_token.rb WORKBENCH_GENERATED_IN = \ - workbench/apache_vhost.in \ + workbench/apache2_vhost.in \ workbench/production.rb.in \ workbench/secret_token.rb.in @@ -81,11 +57,73 @@ WAREHOUSE_GENERATED = warehouse/generated/warehouse.conf WAREHOUSE_GENERATED_IN = warehouse/warehouse.conf.in -$(API_GENERATED): $(API_GENERATED_IN) +SSO_GENERATED = \ + sso/generated/apache2_vhost \ + sso/generated/seeds.rb \ + sso/generated/secret_token.rb + +SSO_GENERATED_IN = \ + sso/apache2_vhost.in \ + sso/seeds.rb.in \ + sso/secret_token.rb.in + +$(BASE_GENERATED): config.yml + ./config.rb + +$(API_GENERATED): config.yml $(API_GENERATED_IN) ./config.rb -$(WORKBENCH_GENERATED): $(WORKBENCH_GENERATED_IN) +$(WORKBENCH_GENERATED): config.yml $(WORKBENCH_GENERATED_IN) ./config.rb -$(WAREHOUSE_GENERATED): $(WAREHOUSE_GENERATED_IN) +$(WAREHOUSE_GENERATED): config.yml $(WAREHOUSE_GENERATED_IN) ./config.rb + +$(SSO_GENERATED): config.yml $(SSO_GENERATED_IN) + ./config.rb + +# ============================================================ +# The main Arvados servers: api, doc, workbench, warehouse + +api-image: passenger-image $(API_DEPS) + mkdir -p api/generated + tar -c -z -f api/generated/api.tar.gz -C ../services api + ./docker_build -t arvados/api api + echo -n "Built at $(date)" > api-image + +doc-image: base-image $(DOC_DEPS) + mkdir -p doc/generated + tar -c -z -f doc/generated/doc.tar.gz -C .. doc + ./docker_build -t arvados/doc doc + echo -n "Built at $(date)" > doc-image + +workbench-image: passenger-image $(WORKBENCH_DEPS) + mkdir -p workbench/generated + tar -c -z -f workbench/generated/workbench.tar.gz -C ../apps workbench + ./docker_build -t arvados/workbench workbench + echo -n "Built at $(date)" > workbench-image + +warehouse-image: base-image $(WAREHOUSE_DEPS) + ./docker_build -t arvados/warehouse warehouse + echo -n "Built at $(date)" > warehouse-image + +sso-image: passenger-image $(SSO_DEPS) + ./docker_build -t arvados/sso sso + echo -n "Built at $(date)" > sso-image + +# ============================================================ +# The arvados/base image is the base Debian image plus packages +# that are dependencies for every Arvados service. + +passenger-image: base-image + ./docker_build -t arvados/passenger passenger + echo -n "Built at $(date)" > passenger-image + +base-image: debian-image $(BASE_DEPS) + ./docker_build -t arvados/base base + echo -n "Built at $(date)" > base-image + +debian-image: + ./mkimage-debootstrap.sh arvados/debian wheezy http://debian.lcs.mit.edu/debian/ + echo -n "Built at $(date)" > debian-image +