-
Roles: common_vars
- Added COMMON_RG_SENTRY_DSN for sentry.io integration for all services
-
Roles: edxapp
- Added EDXAPP_RG_SENTRY_DSN, RG_SENTRY_DSN for LMS and CMS sentry.io integration
-
Roles: nginx
- Added RG_NGINX_LMS_CLIENT_MAX_BODY_SIZE, RG_NGINX_CMS_CLIENT_MAX_BODY_SIZE to override
client_max_body_size
in lms and cms nginx configuration.
- Added RG_NGINX_LMS_CLIENT_MAX_BODY_SIZE, RG_NGINX_CMS_CLIENT_MAX_BODY_SIZE to override
-
Role: edxapp
- Added creation of enterprise_worker user to provisioning. This user is used by the edx-enterprise package when making API requests to Open edX IDAs.
-
Role: forum
- Added
FORUM_REBUILD_INDEX
to rebuild the ElasticSearch index from the database, when enabled. Default:False
.
- Added
-
Role: edxapp
- Let
confirm_email
inEDXAPP_REGISTRATION_EXTRA_FIELDS
default to"hidden"
. - Let
terms_of_service
inEDXAPP_REGISTRATION_EXTRA_FIELDS
default to"hidden"
.
- Let
-
Role: ecommerce
- Added ECOMMERCE_LANGUAGE_COOKIE_NAME which is the name of the cookie the ecommerce django app looks at for determining the language preference.
-
Role: neo4j
- Enabled splunk forwarding for neo4j logs.
- Increased maximum amount of open files to 40000, as suggested by neo4j.
- Updated the java build that neo4j uses to run.
-
Role: edxapp
- Set the default value for EDXAPP_BULK_EMAIL_ROUTING_KEY_SMALL_JOBS to 'edx.lms.core.low'.
-
Role: jenkins_master
- Update pinned use of JDK7 in Jenkins installs to default JDK version from role
oraclejdk
.
- Update pinned use of JDK7 in Jenkins installs to default JDK version from role
-
Role: notifier
- Added
NOTIFIER_DATABASE_ENGINE
,NOTIFIER_DATABASE_NAME
,NOTIFIER_DATABASE_USER
,NOTIFIER_DATABASE_PASSWORD
,NOTIFIER_DATABASE_HOST
, andNOTIFIER_DATABASE_PORT
to be able to configure thenotifier
service to use a database engine other than sqlite. Defaults to local sqlite. - Deprecated:
NOTIFIER_DB_DIR
: Please useNOTIFIER_DATABASE_NAME
instead.
- Added
-
Role: elasticsearch
- Replaced
elasticsearch_apt_key
andelastic_search_apt_keyserver
withelasticsearch_apt_key_url
- Updated elasticsearch version to 1.5.0
- Replaced
-
Role: edxapp
- Install development.txt in Vagrant and Docker devstacks
-
Role: edxapp
- Set the EDXAPP_IMPORT_EXPORT_BUCKET setting to an empty string
-
Role: edxapp
- Updated default value of the EDXAPP_ENTERPRISE_COURSE_ENROLLMENT_AUDIT_MODES setting to ["audit", "honor"]
-
Role: edx_notes_api
- Removed EDX_NOTES_API_ELASTICSEARCH_HOST.
- Removed EDX_NOTES_API_ELASTICSEARCH_PORT.
- EDX_NOTES_API_ELASTICSEARCH_URL.
-
Role: edxapp
- Added the EDXAPP_ACTIVATION_EMAIL_SUPPORT_LINK URL with default value
''
. - Added the EDXAPP_PASSWORD_RESET_SUPPORT_LINK URL with default value
''
.
- Added the EDXAPP_ACTIVATION_EMAIL_SUPPORT_LINK URL with default value
-
Role: edxapp
- Added the EDXAPP_SHOW_HEADER_LANGUAGE_SELECTOR feature flag with default value [false]
- Added the EDXAPP_SHOW_FOOTER_LANGUAGE_SELECTOR feature flag with default value [false]
-
Role: edxapp
- Added the EDXAPP_ENTERPRISE_COURSE_ENROLLMENT_AUDIT_MODES setting with default value ["audit"]
-
Role: edxapp
- DOC_LINK_BASE settings have been removed, replaced by HELP_TOKENS_BOOKS
-
Role: edxapp
- Add the EDXAPP_LANGUAGE_COOKIE setting
-
Role: rabbitmq
- Upgraded to 3.6.9
- Switched to a PPA rather than a .deb hosted in S3
- Note that you generally cannot upgrade RabbitMQ live in place https://www.rabbitmq.com/clustering.html this is particularly true coming from 3.2 to 3.6. We are using the shovel plugin to move tasks across clusters but their documentation covers different scenarios.
-
Role: edxapp
- Added a new EDXAPP_MYSQL_CONN_MAX_AGE, default to 0. Adjust it to change how long a connection is kept open for reuse before it is closed.
- Set preload_app to False in gunicorn config for LMS and Studio.
-
Role: analytics_api
- Added
ANALYTICS_API_AGGREGATE_PAGE_SIZE
, default value 10. Adjust this parameter to increase the number of aggregate search results returned by the Analytics API, i.e. in course_metadata: enrollment_modes, cohorts, and segments.
- Added
-
Role: programs
- This role has been removed as this service is no longer supported. The role is still available on the Ficus branch.
-
Role: xqueue
- Changed
XQUEUE_RABBITMQ_TLS
default fromtrue
tofalse
.
- Changed
-
Role: credentials
- Added
CREDENTIALS_EXTRA_APPS
to enable the inclusion of additional Django apps in the Credentials Service.
- Added
-
Role: common
- Renamed
COMMON_AWS_SYNC
toCOMMON_OBJECT_STORE_LOG_SYNC
- Renamed
COMMON_AWS_SYNC_BUCKET
toCOMMON_OBJECT_STORE_LOG_SYNC_BUCKET
- Renamed
COMMON_AWS_S3_SYNC_SCRIPT
toCOMMON_OBJECT_STORE_LOG_SYNC_SCRIPT
- Added
COMMON_OBJECT_STORE_LOG_SYNC_PREFIX
. Default:logs/tracking/
- Added
COMMON_EDXAPP_SETTINGS
. Default:aws
- Renamed
-
Role: aws
- Removed
AWS_S3_LOGS
- Added
vhost
role as dependency
- Removed
-
Role: edxapp
- Added
EDXAPP_SWIFT_USERNAME
- Added
EDXAPP_SWIFT_KEY
- Added
EDXAPP_SWIFT_TENANT_ID
- Added
EDXAPP_SWIFT_TENANT_NAME
- Added
EDXAPP_SWIFT_AUTH_URL
- Added
EDXAPP_SWIFT_AUTH_VERSION
- Added
EDXAPP_SWIFT_REGION_NAME
- Added
EDXAPP_SWIFT_USE_TEMP_URLS
- Added
EDXAPP_SWIFT_TEMP_URL_KEY
- Added
EDXAPP_SWIFT_TEMP_URL_DURATION
- Added
EDXAPP_SETTINGS
to allow using a settings file other thanaws.py
. Default:aws
- Renamed
ENABLE_S3_GRADE_DOWNLOADS
toENABLE_GRADE_DOWNLOADS
- Replaced
EDXAPP_GRADE_STORAGE_TYPE
,EDXAPP_GRADE_BUCKET
andEDXAPP_GRADE_ROOT_PATH
withEDXAPP_GRADE_STORAGE_CLASS
andEDXAPP_GRADE_STORAGE_KWARGS
- Added
-
Role: openstack
- Added role
-
Role: vhost
- Added as dependency for aws and openstack roles. Handles common functionality for setting up VM hosts
-
Role: xqueue
- Added
XQUEUE_SETTINGS
to specify which settings file to use. Default:aws_settings
- Renamed
XQUEUE_S3_BUCKET
toXQUEUE_UPLOAD_BUCKET
- Renamed
XQUEUE_S3_PATH_PREFIX
toXQUEUE_UPLOAD_PATH_PREFIX
- Added
-
Role: discovery
- Course Discovery JWT configuration now takes a list of issuers instead of a single issuer. This change is not backward compatible with older versions of course discovery.
-
Role: hadoop_common
- Enable log retention by default to assist with debugging. Now YARN will retain stdout and stderr logs produced by map reduce tasks for 24 hours. They can be retrieved by running "yarn logs -applicationId YOUR_APPLICATION_ID".
-
Role: rabbitmq
- Removed the RABBITMQ_CLUSTERED var and related tooling. The goal of the var was to be able to setup a cluster in the aws environment without having to know all the IPs of the cluster before hand. It relied on the
hostvars
ansible varible to work correctly which it no longer does in 1.9. This may get fixed in the future but for now, the "magic" setup doesn't work. - Changed
rabbitmq_clustered_hosts
to RABBITMQ_CLUSTERED_HOSTS.
- Removed the RABBITMQ_CLUSTERED var and related tooling. The goal of the var was to be able to setup a cluster in the aws environment without having to know all the IPs of the cluster before hand. It relied on the
-
Role: edxapp
- Removed SUBDOMAIN_BRANDING and SUBDOMAIN_COURSE_LISTINGS variables
-
Role: ora
- Remove the ora1 role as support for it was deprecated in Cypress.
- Removed dependencies on ora throughout the playbooks / vagrantfiles.
-
Role: edxapp
- Removed XmlModuleStore from the default list of modulestores for the LMS.
- EDXAPP_XML_MAPPINGS variable no longer exists by default and is not used by the edxapp role.
-
Role: ecommerce
- Removed ECOMMERCE_ORDER_NUMBER_PREFIX variable
-
Role: edxapp
- All of the following changes are BACKWARDS-INCOMPATABLE:
- Renamed two top level variables SEGMENT_IO_LMS_KEY and SEGMENT_IO_KEY to SEGMENT_KEY in {lms|cms].auth.json.
- Renamed two top level variables in roles/edxapp/defaults/main.yml. EDXAPP_SEGMENT_IO_LMS_KEY and EDXAPP_SEGMENT_IO_KEY are now EDXAPP_LMS_SEGMENT_KEY and EDXAPP_CMS_SEGMENT_KEY respectively
- REMOVED two top level variables SEGMENT_IO_LMS and SEGMENT_IO from {lms|cms].auth.json. We will use the existence of the SEGMENT_KEY to to serve the same function that these boolean variables served.
- REMOVED two top level variables EDXAPP_SEGMENT_IO_LMS and EDXAPP_SEGMENT_IO from roles/edxapp/defaults/main.yml.
- All of the following changes are BACKWARDS-INCOMPATABLE:
-
Updated ansible fork to be based on ansible 1.9.3rc1 instead of 1.9.1
- Ansible Changelog: https://github.com/ansible/ansible/blob/stable-1.9/CHANGELOG.md
-
Role: edxapp
- Removed deprecated variables EDXAPP_PLATFORM_TWITTER_URL, EDXAPP_PLATFORM_MEETUP_URL, EDXAPP_PLATFORM_LINKEDIN_URL, and EDXAPP_PLATFORM_GOOGLE_PLUS_URL in favor of EDXAPP_SOCIAL_MEDIA_FOOTER_URLS. These variables haven't been used in edx-platform since March 17, 2015 (when https://github.com/edx/edx-platform/pull/7383 was merged). This change is backwards incompatible with versions of edx-platform from before March 17, 2015.
- Added EDXAPP_MOBILE_STORE_URLS and EDXAPP_FOOTER_ORGANIZATION_IMAGE variables, used in https://github.com/edx/edx-platform/pull/8175 (v3 version of the edx.org footer).
-
Updated ansible fork with small bug fix.
-
Role: edxapp
- Removed post.txt from the list of files that will have its github urls replaced with git mirror urls.
-
Role: edxapp
- The edxapp role no longer uses checksums to bypass pip installs.
- pip install will always run for all known requirements files.
- The edxapp role no longer uses checksums to bypass pip installs.
-
Role: edx-ansible
/edx/bin/update
no longer runs the ansible command with--tags deploy
-
Role: edxapp
- Added newrelic monitoring capabilities to edxapp workers. Note that this is a BACKWARDS-INCOMPATABLE CHANGE, as it introduces a new key,
monitor
, to each item inEDXAPP_CELERY_WORKERS
indefaults/main.yml
, and plays including this role will fail if that key is not set.
- Added newrelic monitoring capabilities to edxapp workers. Note that this is a BACKWARDS-INCOMPATABLE CHANGE, as it introduces a new key,
-
Role: edxapp
- Enabled combined login registration feature by default
-
Role: analytics_api, xqwatcher, insights, minos, edx_notes_api
-
Expanded
edx_service
role to do git checkout and ec2 tagging -
Refactored roles that depend on
edx_service
to use the new interface:minos
,analytics_api
,insights
, andxqwatcher
-
Refactored name from
analytics-api
toanalytics_api
-
Changed location of minos' config file from
/edx/etc/minos/minos.yml
to/edx/etc/minos.yml
-
Added new
edx_notes_api
role for forthcoming notes api -
This is a BACKWARDS INCOMPATABLE change and will require additional migrations when upgrading an existing server. While we recommend building from scratch, running the following command might work:
rm -rf /edx/app/analytics-api /edx/app/ /edx/app/nginx/sites-available/analytics-api.j2 /edx/app/supervisor/conf.d.available/analytics_api.conf rm -rf /edx/etc/minos
-
-
Role: notifier
- Refactored
NOTIFIER_HOME
andNOTIFIER_USER
tonotifier_app_dir
andnotifier_user
to match other roles. This shouldn't change anything since users should've only been overriding COMMON_HOME.
- Refactored
-
Role: gitreload
- New role added for running gitreload that can be used for importing courses via github/gitlab Web hooks, or more generally updating any git repository that is already checked out on disk via a hook.
-
Role: analytics-api, edxapp, ora, xqueue, xserver
- Switched gunicorn from using an entirely command argument based configuration to usign python configuration files. Variables for extra configuration in the configuration file template, and command line argument overrides are available.
-
Role: analytics-api, insights
- Using Django 1.7 migrate command.
-
Role: edxapp
- A new var was added to make it easy ot invalidate the default
memcache store to make it easier to invalidate sessions. Updating
the edxapp env.json files will result in all users getting logged
out. This is a one time penalty as long as the value of
EDXAPP_DEFAULT_CACHE_VERSION
is not explicitly changed.
- A new var was added to make it easy ot invalidate the default
memcache store to make it easier to invalidate sessions. Updating
the edxapp env.json files will result in all users getting logged
out. This is a one time penalty as long as the value of
-
Role: nginx
- New html templates for server errors added. Defaults for a ratelimiting static page and server error static page. CMS/LMS are set to use them by default, wording can be changed in the Nginx default vars.
-
Role: edxapp
- We now have an all caps variable override for celery workers
-
Role: common
- We now remove the default syslog.d conf file (50-default.conf) this will break people who have hand edited that file.
-
Role: edxapp
- Updated the module store settings to match the new settings format.
-
Update, possible breaking change: the edxapp role vars edxapp_lms_env and edxapp_cms_env have been changed to EDXAPP_LMS_ENV and EDXAPP_CMS_ENV to indicate, via our convention, that overridding them is expected. The default values remain the same.
-
Role: analytics-api
- Added a new role for the analytics-api Django app. Currently a private repo
-
Logrotation now happens hourly by default for all logs.
-
Role: xqwatcher, xqueue, nginx, edxapp, common
- Moving nginx basic authorization flag and credentials to the common role
- Basic auth will be turned on by default
-
Role: Edxapp
- Turn on code sandboxing by default and allow the jailed code to be able to write files to the tmp directory created for it by codejail.
-
Role: Edxapp
- The repo.txt requirements file is no longer being processed in anyway. This file was removed from edxplatform via pull #3487(https://github.com/edx/edx-platform/pull/3487)
-
Update
CMS_HOSTNAME
default to allow any hostname that starts withstudio
along withprod-studio
orstage-studio
. -
Start a change log to keep track of backwards incompatible changes and deprecations.
-
Role: Mongo
- Fixed case of variable used in if block that breaks cluster configuration by changing mongo_clustered to MONGO_CLUSTERED.
-
Role: Edxapp
- Added EDXAPP_LMS_AUTH_EXTRA and EDXAPP_CMS_AUTH_EXTRA for passing unique AUTH_EXTRA configurations to the LMS and CMS. Both variables default to EDXAPP_AUTH_EXTRA for backward compatibility
-
Role: ecommerce
- Renamed
ECOMMERCE_COMPREHENSIVE_THEME_DIR
toECOMMERCE_COMPREHENSIVE_THEME_DIRS
,ECOMMERCE_COMPREHENSIVE_THEME_DIRS
is now a list of directories. Change is backward incompatible. - Renamed
COMPREHENSIVE_THEME_DIR
toCOMPREHENSIVE_THEME_DIRS
,COMPREHENSIVE_THEME_DIRS
is now a list of directories. Change is backward incompatible.
- Renamed
-
Role: Edxapp
EDXAPP_COMPREHENSIVE_THEME_DIR
is deprecated and is maintained for backward compatibility,EDXAPP_COMPREHENSIVE_THEME_DIRS
should be used instead which is a list of directories.EDXAPP_COMPREHENSIVE_THEME_DIR
if present will have priority overEDXAPP_COMPREHENSIVE_THEME_DIRS
COMPREHENSIVE_THEME_DIR
is deprecated and is maintained for backward compatibility,COMPREHENSIVE_THEME_DIRS
should be used instead which is a list of directories.COMPREHENSIVE_THEME_DIR
if present will have priority overCOMPREHENSIVE_THEME_DIRS
-
Role: edxapp
- Added COMPREHENSIVE_THEME_LOCALE_PATHS to support internationalization of strings originating from custom themes.
-
Role: edxapp
- Added
EXPIRING_SOON_WINDOW
to show message to learners if their verification is expiring soon.
- Added
-
Role: discovery
- Added
PUBLISHER_FROM_EMAIL
for sending emails to publisher app users.
- Added
-
Role: security
- Changed SECURITY_UPGRADE_ON_ANSIBLE to only apply security updates. If you want to retain the behavior of running safe-upgrade, you should switch to using SAFE_UPGRADE_ON_ANSIBLE.
-
Role: mongo_2_6
- Added
MONGO_AUTH
to turn authentication on/off. Auth is now enabled by default, and was previously disabled by default.
- Added
-
Role: mongo_3_0
- Changed MONGO_STORAGE_ENGINE to default to wiredTiger which is the default in 3.2 and 3.4 and what edX suggests be used even on 3.0. If you have a mmapv1 3.0 install, override MONGO_STORAGE_ENGINE to be mmapv1 which was the old default.
- Support parsing the replset JSON in 3.2 and 3.0
- Added
MONGO_AUTH
to turn authentication on/off. Auth is now enabled by default, and was previously disabled by default.
-
Role: xqueue
- Added
XQUEUE_RABBITMQ_TLS
to allow configuring xqueue to use TLS when connecting to the AMQP broker. - Added
XQUEUE_RABBITMQ_VHOST
to allow configuring the xqueue RabbitMQ host. - Added
XQUEUE_RABBITMQ_PORT
to allow configuring the RabbitMQ port.
- Added
-
Role: edxapp
- Added
EDXAPP_CELERY_BROKER_USE_SSL
to allow configuring celery to use TLS.
- Added
-
Role: ecommerce
- Added
ECOMMERCE_ENTERPRISE_URL
for theenterprise
API endpoint exposed by a new serviceedx-enterprise
(currently hosted byLMS
), which defaults to the existing settingECOMMERCE_LMS_URL_ROOT
.
- Added
-
Role: ecommerce
- Removed
SEGMENT_KEY
which is no longer used. Segment key is now defined in DB configuration. (https://github.com/edx/ecommerce/pull/1121)
- Removed
-
Role: edxapp
- Added
EDXAPP_BLOCK_STRUCTURES_SETTINGS
to configure S3-backed Course Block Structures.
- Added
-
Role: insights
- Removed
INSIGHTS_FEEDBACK_EMAIL
which is no longer used, as it was deemed redundant withINSIGHTS_SUPPORT_EMAIL
.
- Removed
-
Role: insights
- Removed
SUPPORT_EMAIL
setting fromINSIGHTS_CONFIG
, as it is was replaced bySUPPORT_URL
.
- Removed
-
Role: insights
- Added
INSIGHTS_DOMAIN
to configure the domain Insights is deployed on - Added
INSIGHTS_CLOUDFRONT_DOMAIN
to configure the domain static files can be served from - Added
INSIGHTS_CORS_ORIGIN_WHITELIST_EXTRA
to configure allowing CORS on domains other than theINSIGHTS_DOMAIN
- Added
-
Role: edxapp
- Added
EDXAPP_VIDEO_IMAGE_SETTINGS
to configure S3-backed video images.
- Added