2018-11-20 11:24:34 +01:00
|
|
|
|
.PHONY: all android configure build update migrate run
|
2018-09-29 17:08:39 +02:00
|
|
|
|
.DEFAULT_GOAL := help
|
|
|
|
|
|
2017-12-26 01:16:35 +01:00
|
|
|
|
|
2018-09-04 12:13:18 +02:00
|
|
|
|
PWD ?= $$(pwd)
|
2018-04-30 09:01:40 +02:00
|
|
|
|
USERID ?= $$(id -u)
|
2018-05-16 19:02:44 +02:00
|
|
|
|
EDX_PLATFORM_SETTINGS ?= universal.production
|
2018-08-19 14:40:38 +02:00
|
|
|
|
DOCKER_COMPOSE = docker-compose -f docker-compose.yml
|
2018-09-29 15:51:48 +02:00
|
|
|
|
-include $(PWD)/config/Makefile.env
|
2018-08-19 14:40:38 +02:00
|
|
|
|
|
2018-09-18 20:17:42 +02:00
|
|
|
|
post_configure_targets =
|
|
|
|
|
ifneq ($(DISABLE_STATS), 1)
|
|
|
|
|
post_configure_targets += stats
|
|
|
|
|
endif
|
2018-08-19 14:40:38 +02:00
|
|
|
|
ifeq ($(ACTIVATE_HTTPS), 1)
|
|
|
|
|
post_configure_targets += https-certificate
|
|
|
|
|
endif
|
|
|
|
|
extra_migrate_targets =
|
|
|
|
|
ifeq ($(ACTIVATE_XQUEUE), 1)
|
|
|
|
|
extra_migrate_targets += migrate-xqueue
|
|
|
|
|
DOCKER_COMPOSE += -f docker-compose-xqueue.yml
|
|
|
|
|
endif
|
2018-09-15 15:19:57 +02:00
|
|
|
|
ifeq ($(ACTIVATE_NOTES), 1)
|
|
|
|
|
extra_migrate_targets += migrate-notes
|
|
|
|
|
DOCKER_COMPOSE += -f docker-compose-notes.yml
|
|
|
|
|
endif
|
2018-09-29 15:09:19 +02:00
|
|
|
|
ifeq ($(ACTIVATE_PORTAINER), 1)
|
|
|
|
|
DOCKER_COMPOSE += -f docker-compose-portainer.yml
|
|
|
|
|
endif
|
2018-08-19 14:40:38 +02:00
|
|
|
|
|
|
|
|
|
DOCKER_COMPOSE_RUN = $(DOCKER_COMPOSE) run --rm
|
2018-05-27 07:30:23 -04:00
|
|
|
|
DOCKER_COMPOSE_RUN_OPENEDX = $(DOCKER_COMPOSE_RUN) -e USERID=$(USERID) -e SETTINGS=$(EDX_PLATFORM_SETTINGS)
|
2018-04-09 19:16:58 +02:00
|
|
|
|
ifneq ($(EDX_PLATFORM_PATH),)
|
2018-05-27 07:30:23 -04:00
|
|
|
|
DOCKER_COMPOSE_RUN_OPENEDX += --volume="$(EDX_PLATFORM_PATH):/openedx/edx-platform"
|
2018-04-09 19:16:58 +02:00
|
|
|
|
endif
|
|
|
|
|
|
2018-05-27 07:30:23 -04:00
|
|
|
|
DOCKER_COMPOSE_RUN_LMS = $(DOCKER_COMPOSE_RUN_OPENEDX) -p 8000:8000 lms
|
|
|
|
|
DOCKER_COMPOSE_RUN_CMS = $(DOCKER_COMPOSE_RUN_OPENEDX) -p 8001:8001 cms
|
2018-04-09 19:16:58 +02:00
|
|
|
|
|
2018-09-29 17:22:55 +02:00
|
|
|
|
##################### Running Open edX
|
|
|
|
|
|
2018-09-29 17:08:39 +02:00
|
|
|
|
# other targets are not listed as requirements in order to reload the env file
|
|
|
|
|
all: configure ## Configure and run a full-featured platform
|
2018-09-29 15:51:48 +02:00
|
|
|
|
@$(MAKE) post_configure
|
|
|
|
|
@$(MAKE) update
|
2018-09-29 17:33:43 +02:00
|
|
|
|
@$(MAKE) databases
|
2018-09-29 15:51:48 +02:00
|
|
|
|
@$(MAKE) assets
|
|
|
|
|
@$(MAKE) daemonize
|
2018-07-16 19:42:39 +02:00
|
|
|
|
@echo "All set \o/ You can access the LMS at http://localhost and the CMS at http://studio.localhost"
|
2017-12-26 01:16:35 +01:00
|
|
|
|
|
2018-09-29 17:22:55 +02:00
|
|
|
|
run: ## Run the complete platform
|
|
|
|
|
$(DOCKER_COMPOSE) up
|
|
|
|
|
up: run
|
|
|
|
|
|
|
|
|
|
daemonize: ## Run the complete platform, with daemonization
|
|
|
|
|
$(DOCKER_COMPOSE) up -d
|
|
|
|
|
@echo "Daemon is up and running"
|
|
|
|
|
daemon: daemonize
|
|
|
|
|
|
|
|
|
|
stop: ## Stop all services
|
|
|
|
|
$(DOCKER_COMPOSE) rm --stop --force
|
|
|
|
|
|
|
|
|
|
##################### Configuration
|
2017-12-26 01:16:35 +01:00
|
|
|
|
|
2018-09-29 17:08:39 +02:00
|
|
|
|
configure: build-configurator ## Configure the environment prior to running the platform
|
2018-08-05 16:40:51 +02:00
|
|
|
|
docker run --rm -it --volume="$(PWD)/config:/openedx/config" \
|
2018-09-30 14:27:24 +02:00
|
|
|
|
-e USERID=$(USERID) -e SILENT=$(SILENT) $(CONFIGURE_OPTS) \
|
2018-09-15 16:19:35 +02:00
|
|
|
|
regis/openedx-configurator:hawthorn
|
2018-09-15 11:55:42 +02:00
|
|
|
|
|
2018-09-29 15:51:48 +02:00
|
|
|
|
post_configure: $(post_configure_targets)
|
|
|
|
|
|
2018-09-29 17:22:55 +02:00
|
|
|
|
##################### Database
|
2018-09-18 20:17:42 +02:00
|
|
|
|
|
2018-09-29 17:33:43 +02:00
|
|
|
|
databases: provision-databases migrate provision-oauth2 ## Bootstrap databases
|
|
|
|
|
|
|
|
|
|
provision-databases: ## Create necessary databases and users
|
2018-09-16 13:24:17 +02:00
|
|
|
|
$(DOCKER_COMPOSE_RUN) lms /openedx/config/provision.sh
|
2018-09-29 17:08:39 +02:00
|
|
|
|
provision-oauth2: ## Create users for SSO between services
|
2018-09-15 15:19:57 +02:00
|
|
|
|
$(DOCKER_COMPOSE_RUN) lms /openedx/config/oauth2.sh
|
2018-08-19 14:40:38 +02:00
|
|
|
|
|
2018-09-29 17:33:43 +02:00
|
|
|
|
migrate: migrate-openedx migrate-forum $(extra_migrate_targets) ## Perform all database migrations
|
2018-09-29 17:08:39 +02:00
|
|
|
|
migrate-openedx: ## Perform database migrations on LMS/CMS
|
2018-09-15 11:55:42 +02:00
|
|
|
|
$(DOCKER_COMPOSE_RUN) lms bash -c "dockerize -wait tcp://mysql:3306 -timeout 20s && ./manage.py lms migrate"
|
|
|
|
|
$(DOCKER_COMPOSE_RUN) cms bash -c "dockerize -wait tcp://mysql:3306 -timeout 20s && ./manage.py cms migrate"
|
|
|
|
|
$(MAKE) reindex-courses
|
2018-09-29 17:08:39 +02:00
|
|
|
|
migrate-forum: ## Perform database migrations on discussion forums
|
2018-05-27 07:30:23 -04:00
|
|
|
|
$(DOCKER_COMPOSE_RUN) forum bash -c "bundle exec rake search:initialize && \
|
|
|
|
|
bundle exec rake search:rebuild_index"
|
2018-09-29 17:08:39 +02:00
|
|
|
|
migrate-notes: ## Perform database migrations for the Notes service
|
2018-09-15 15:19:57 +02:00
|
|
|
|
$(DOCKER_COMPOSE_RUN) notes ./manage.py migrate
|
2018-09-29 17:08:39 +02:00
|
|
|
|
migrate-xqueue: ## Perform database migrations for the XQueue service
|
2018-09-15 11:55:42 +02:00
|
|
|
|
$(DOCKER_COMPOSE_RUN) xqueue ./manage.py migrate
|
2018-09-29 17:08:39 +02:00
|
|
|
|
reindex-courses: ## Refresh course index so they can be found in the LMS search engine
|
2018-09-15 11:55:42 +02:00
|
|
|
|
$(DOCKER_COMPOSE_RUN) cms ./manage.py cms reindex_course --all --setup
|
2018-06-01 21:29:53 -04:00
|
|
|
|
|
2018-09-29 17:22:55 +02:00
|
|
|
|
##################### Static assets
|
|
|
|
|
|
2018-11-20 11:24:34 +01:00
|
|
|
|
# To collect assets we don't rely on the "paver update_assets" command because
|
|
|
|
|
# webpack collection incorrectly sets the NODE_ENV variable when using custom
|
|
|
|
|
# settings. Thus, each step must be performed separately. This should be fixed
|
|
|
|
|
# in the next edx-platform release thanks to https://github.com/edx/edx-platform/pull/18430/
|
|
|
|
|
#assets-lms: ## Collect static assets for the LMS
|
|
|
|
|
#$(DOCKER_COMPOSE_RUN_OPENEDX) lms -e NO_PREREQ_INSTALL=True lms paver update_assets lms --settings=$(EDX_PLATFORM_SETTINGS)
|
|
|
|
|
#assets-cms: ## Collect static assets for the CMS
|
|
|
|
|
#$(DOCKER_COMPOSE_RUN_OPENEDX) cms -e NO_PREREQ_INSTALL=True cms paver update_assets cms --settings=$(EDX_PLATFORM_SETTINGS)
|
|
|
|
|
|
|
|
|
|
assets: assets-lms assets-cms ## Generate production-ready static assets
|
|
|
|
|
assets-development: assets-development-lms assets-development-cms ## Generate static assets for local development
|
|
|
|
|
|
|
|
|
|
assets-lms:
|
2018-11-20 19:06:43 +01:00
|
|
|
|
$(DOCKER_COMPOSE_RUN_OPENEDX) --no-deps lms bash -c \
|
2018-11-20 11:24:34 +01:00
|
|
|
|
"NODE_ENV=production ./node_modules/.bin/webpack --config=webpack.prod.config.js \
|
|
|
|
|
&& ./manage.py lms --settings=$(EDX_PLATFORM_SETTINGS) compile_sass lms \
|
|
|
|
|
&& python -c \"import pavelib.assets; pavelib.assets.collect_assets(['lms'], '$(EDX_PLATFORM_SETTINGS)')\""
|
|
|
|
|
assets-cms:
|
2018-11-20 19:06:43 +01:00
|
|
|
|
$(DOCKER_COMPOSE_RUN_OPENEDX) --no-deps cms bash -c \
|
2018-11-20 11:24:34 +01:00
|
|
|
|
"NODE_ENV=production ./node_modules/.bin/webpack --config=webpack.prod.config.js \
|
|
|
|
|
&& ./manage.py cms --settings=$(EDX_PLATFORM_SETTINGS) compile_sass studio \
|
|
|
|
|
&& python -c \"import pavelib.assets; pavelib.assets.collect_assets(['studio'], '$(EDX_PLATFORM_SETTINGS)')\""
|
|
|
|
|
assets-development-lms:
|
2018-11-20 19:06:43 +01:00
|
|
|
|
$(DOCKER_COMPOSE_RUN_OPENEDX) --no-deps lms bash -c \
|
2018-11-20 11:24:34 +01:00
|
|
|
|
"xmodule_assets common/static/xmodule \
|
|
|
|
|
&& python -c \"import pavelib.assets; pavelib.assets.process_npm_assets()\"
|
|
|
|
|
&& NODE_ENV=development ./node_modules/.bin/webpack --config=webpack.dev.config.js \
|
|
|
|
|
&& ./manage.py lms --settings=$(EDX_PLATFORM_SETTINGS) compile_sass lms \
|
|
|
|
|
&& python -c \"import pavelib.assets; pavelib.assets.collect_assets(['lms'], '$(EDX_PLATFORM_SETTINGS)')\""
|
|
|
|
|
assets-development-cms:
|
2018-11-20 19:06:43 +01:00
|
|
|
|
$(DOCKER_COMPOSE_RUN_OPENEDX) --no-deps cms bash -c \
|
2018-11-20 11:24:34 +01:00
|
|
|
|
"xmodule_assets common/static/xmodule \
|
|
|
|
|
&& python -c \"import pavelib.assets; pavelib.assets.process_npm_assets()\"
|
|
|
|
|
&& NODE_ENV=development ./node_modules/.bin/webpack --config=webpack.dev.config.js \
|
|
|
|
|
&& ./manage.py cms --settings=$(EDX_PLATFORM_SETTINGS) compile_sass studio \
|
|
|
|
|
&& python -c \"import pavelib.assets; pavelib.assets.collect_assets(['studio'], '$(EDX_PLATFORM_SETTINGS)')\""
|
|
|
|
|
|
2017-12-26 01:16:35 +01:00
|
|
|
|
|
2018-09-29 17:22:55 +02:00
|
|
|
|
##################### Information
|
2017-12-26 01:16:35 +01:00
|
|
|
|
|
2018-09-29 17:22:55 +02:00
|
|
|
|
# Obtained by running "echo '\033' in a shell
|
|
|
|
|
ESCAPE =
|
|
|
|
|
help: ## Print this help
|
|
|
|
|
@grep -E '^([a-zA-Z_-]+:.*?## .*|######* .+)$$' Makefile \
|
|
|
|
|
| sed 's/######* \(.*\)/\n $(ESCAPE)[1;31m\1$(ESCAPE)[0m/g' \
|
|
|
|
|
| awk 'BEGIN {FS = ":.*?## "}; {printf "\033[33m%-30s\033[0m %s\n", $$1, $$2}'
|
2017-12-26 01:16:35 +01:00
|
|
|
|
|
2018-09-29 17:08:39 +02:00
|
|
|
|
info: ## Print some information about the current install, for debugging
|
2018-06-18 14:20:08 +02:00
|
|
|
|
uname -a
|
|
|
|
|
@echo "-------------------------"
|
2018-09-03 07:53:34 +02:00
|
|
|
|
git rev-parse HEAD
|
|
|
|
|
@echo "-------------------------"
|
2018-06-18 14:20:08 +02:00
|
|
|
|
docker version
|
|
|
|
|
@echo "-------------------------"
|
|
|
|
|
docker-compose --version
|
|
|
|
|
@echo "-------------------------"
|
|
|
|
|
echo $$EDX_PLATFORM_PATH
|
|
|
|
|
echo $$EDX_PLATFORM_SETTINGS
|
|
|
|
|
|
2018-09-29 18:01:08 +02:00
|
|
|
|
|
|
|
|
|
#################### Logging
|
|
|
|
|
|
|
|
|
|
logs: ## Print all logs from a service since it started. E.g: "make logs service=lms", "make logs service=nginx"
|
|
|
|
|
$(DOCKER_COMPOSE) logs $(service)
|
|
|
|
|
tail: ## Similar to "tail" on the logs of a service. E.g: "make tail service=lms", "make tail service=nginx"
|
|
|
|
|
$(DOCKER_COMPOSE) logs --tail=10 $(service)
|
|
|
|
|
tail-follow: ## Similar to "tail -f" on the logs of a service. E.g: "make tail-follow service=lms", "make tail-follow service=nginx"
|
|
|
|
|
$(DOCKER_COMPOSE) logs --tail=10 -f $(service)
|
|
|
|
|
|
2018-09-29 17:22:55 +02:00
|
|
|
|
#################### Docker image building & updating
|
2018-04-09 19:16:58 +02:00
|
|
|
|
|
2018-09-29 17:22:55 +02:00
|
|
|
|
update: ## Download most recent images
|
|
|
|
|
$(DOCKER_COMPOSE) pull
|
2018-04-09 19:16:58 +02:00
|
|
|
|
|
2018-09-29 17:27:38 +02:00
|
|
|
|
build: build-openedx build-configurator build-forum build-notes build-xqueue build-android ## Build all docker images
|
2018-09-29 17:22:55 +02:00
|
|
|
|
build-openedx: ## Build the Open edX docker image
|
|
|
|
|
docker build -t regis/openedx:latest -t regis/openedx:hawthorn openedx/
|
|
|
|
|
build-configurator: ## Build the configurator docker image
|
|
|
|
|
docker build -t regis/openedx-configurator:latest -t regis/openedx-configurator:hawthorn configurator/
|
|
|
|
|
build-forum: ## Build the forum docker image
|
|
|
|
|
docker build -t regis/openedx-forum:latest -t regis/openedx-forum:hawthorn forum/
|
|
|
|
|
build-notes: ## Build the Notes docker image
|
|
|
|
|
docker build -t regis/openedx-notes:latest -t regis/openedx-notes:hawthorn notes/
|
|
|
|
|
build-xqueue: ## Build the Xqueue docker image
|
|
|
|
|
docker build -t regis/openedx-xqueue:latest -t regis/openedx-xqueue:hawthorn xqueue/
|
2018-09-29 17:27:38 +02:00
|
|
|
|
build-android: ## Build the docker image for Android
|
|
|
|
|
docker build -t regis/openedx-android:latest android/
|
|
|
|
|
|
|
|
|
|
################### Pushing images to docker hub
|
|
|
|
|
|
2018-09-30 13:49:07 +02:00
|
|
|
|
push: push-openedx push-configurator push-forum push-notes push-xqueue push-android ## Push all images to dockerhub
|
2018-09-29 17:27:38 +02:00
|
|
|
|
push-openedx: ## Push Open edX images to dockerhub
|
|
|
|
|
docker push regis/openedx:hawthorn
|
|
|
|
|
docker push regis/openedx:latest
|
|
|
|
|
push-configurator: ## Push configurator image to dockerhub
|
|
|
|
|
docker push regis/openedx-configurator:hawthorn
|
|
|
|
|
docker push regis/openedx-configurator:latest
|
2018-10-02 18:14:39 +02:00
|
|
|
|
push-forum: ## Push forum image to dockerhub
|
2018-09-29 17:27:38 +02:00
|
|
|
|
docker push regis/openedx-forum:hawthorn
|
|
|
|
|
docker push regis/openedx-forum:latest
|
|
|
|
|
push-notes: ## Push notes image to dockerhub
|
|
|
|
|
docker push regis/openedx-notes:hawthorn
|
|
|
|
|
docker push regis/openedx-notes:latest
|
|
|
|
|
push-xqueue: ## Push Xqueue image to dockerhub
|
|
|
|
|
docker push regis/openedx-xqueue:hawthorn
|
|
|
|
|
docker push regis/openedx-xqueue:latest
|
2018-09-30 13:49:07 +02:00
|
|
|
|
push-android: ## Push the Android image to dockerhub
|
2018-09-29 17:27:38 +02:00
|
|
|
|
docker push regis/openedx-android:latest
|
|
|
|
|
|
|
|
|
|
dockerhub: build push ## Build and push all images to dockerhub
|
2018-08-16 15:59:31 +02:00
|
|
|
|
|
2018-04-09 19:16:58 +02:00
|
|
|
|
##################### Development
|
|
|
|
|
|
2018-09-29 17:08:39 +02:00
|
|
|
|
lms: ## Open a bash shell in the LMS
|
2018-04-09 19:16:58 +02:00
|
|
|
|
$(DOCKER_COMPOSE_RUN_LMS) bash
|
2018-09-29 17:08:39 +02:00
|
|
|
|
cms: ## Open a bash shell in the CMS
|
2018-04-09 19:16:58 +02:00
|
|
|
|
$(DOCKER_COMPOSE_RUN_CMS) bash
|
|
|
|
|
|
2018-09-29 17:40:58 +02:00
|
|
|
|
lms-python: ## Open a python shell in the LMS
|
2018-05-27 07:30:23 -04:00
|
|
|
|
$(DOCKER_COMPOSE_RUN_OPENEDX) lms ./manage.py lms shell
|
2018-09-29 17:40:58 +02:00
|
|
|
|
lms-shell: lms-python
|
|
|
|
|
cms-python: ## Open a python shell in the CMS
|
2018-05-27 07:30:23 -04:00
|
|
|
|
$(DOCKER_COMPOSE_RUN_OPENEDX) cms ./manage.py cms shell
|
2018-09-29 17:40:58 +02:00
|
|
|
|
cms-shell: cms-python
|
2018-05-16 19:02:44 +02:00
|
|
|
|
|
2018-11-13 11:27:00 -08:00
|
|
|
|
restart-openedx: ## Restart lms, cms, and workers
|
|
|
|
|
docker-compose restart lms lms_worker cms cms_worker
|
|
|
|
|
|
2018-09-29 17:22:55 +02:00
|
|
|
|
##################### SSL/TLS (HTTPS certificates)
|
|
|
|
|
|
|
|
|
|
https_command = docker run --rm -it \
|
|
|
|
|
--volume="$(PWD)/config/letsencrypt/:/openedx/letsencrypt/config/" \
|
|
|
|
|
--volume="$(PWD)/data/letsencrypt/:/etc/letsencrypt/" \
|
|
|
|
|
-p "80:80"
|
|
|
|
|
certbot_image = certbot/certbot:latest
|
2018-05-16 19:02:44 +02:00
|
|
|
|
|
2018-09-29 17:22:55 +02:00
|
|
|
|
https-certificate: ## Generate https certificates
|
|
|
|
|
$(https_command) --entrypoint "/openedx/letsencrypt/config/certonly.sh" $(certbot_image)
|
|
|
|
|
|
|
|
|
|
https-certificate-renew: ## Renew https certificates
|
|
|
|
|
$(https_command) $(certbot_image) renew
|
|
|
|
|
|
|
|
|
|
#################### Android application
|
2018-05-27 15:29:14 -04:00
|
|
|
|
|
2018-09-29 17:08:39 +02:00
|
|
|
|
android: ## Build the Android app, for development
|
2018-10-03 15:43:21 +02:00
|
|
|
|
@docker-compose -f docker-compose-android.yml run --rm android
|
|
|
|
|
@echo "Your APK file is ready: ./data/android/$(shell ls data/android/*.apk)"
|
2018-05-27 15:29:14 -04:00
|
|
|
|
|
2018-09-29 17:27:38 +02:00
|
|
|
|
android-release: ## Build the final Android app (beta)
|
2018-05-27 15:29:14 -04:00
|
|
|
|
# Note that this requires that you edit ./config/android/gradle.properties
|
|
|
|
|
docker-compose -f docker-compose-android.yml run --rm android ./gradlew assembleProdRelease
|
|
|
|
|
|
2018-09-29 17:22:55 +02:00
|
|
|
|
##################### Additional commands
|
|
|
|
|
|
|
|
|
|
stats: ## Collect anonymous information about the platform
|
|
|
|
|
@docker run --rm -it --volume="$(PWD)/config:/openedx/config" \
|
|
|
|
|
regis/openedx-configurator:hawthorn /openedx/config/openedx/stats 2> /dev/null|| true
|
|
|
|
|
|
|
|
|
|
import-demo-course: ## Import the demo course from edX
|
|
|
|
|
$(DOCKER_COMPOSE_RUN_OPENEDX) cms /bin/bash -c "git clone https://github.com/edx/edx-demo-course ../edx-demo-course && git -C ../edx-demo-course checkout open-release/hawthorn.beta1 && python ./manage.py cms import ../data ../edx-demo-course"
|
|
|
|
|
|
|
|
|
|
create-staff-user: ## Create a user with admin rights
|
|
|
|
|
$(DOCKER_COMPOSE_RUN_OPENEDX) lms /bin/bash -c "./manage.py lms manage_user --superuser --staff ${USERNAME} ${EMAIL} && ./manage.py lms changepassword ${USERNAME}"
|