Eox-tenant is a multi-tenancy django app for edx-platform. It is build as an openedx plugin so even as a django app it will auto install in the larger edx-platform core code once installed in the same python environment.
The code is written and maintained by eduNEXT and it is what we use to support our own multi-tenant services. It was initially created as an extension of the microsites and site_configurations features of the Open edX platform, but it has grown to completely replace them in order to support more robust multi tenancy model.
If you are looking for professional development or support with multi tenancy or multi sites in the Open edX platform, you can reach out at sales@edunext.co
Open edX Release | Version |
---|---|
Ironwood | < 3.0 |
Juniper | >= 3.0 < 4.0 |
Koa | >= 4.0 <= 5.1.3 |
Lilac | >= 4.0 |
Maple | >= 6.0 |
Nutmeg | >= 6.0 |
The following changes to the plugin settings are necessary. If the release you are looking for is not listed, then the accumulation of changes from previous releases is enough.
Ironwood
GET_BRANDING_API: 'eox_tenant.edxapp_wrapper.backends.branding_api_h_v1'
GET_CERTIFICATES_MODULE: 'eox_tenant.edxapp_wrapper.backends.certificates_module_i_v1'
GET_SITE_CONFIGURATION_MODULE: 'eox_tenant.edxapp_wrapper.backends.site_configuration_module_i_v1'
GET_THEMING_HELPERS: 'eox_tenant.edxapp_wrapper.backends.theming_helpers_h_v1'
EOX_TENANT_EDX_AUTH_BACKEND: "eox_tenant.edxapp_wrapper.backends.edx_auth_i_v1"
EOX_TENANT_USERS_BACKEND: 'eox_tenant.edxapp_wrapper.backends.users_i_v1'
EDXMAKO_MODULE_BACKEND: 'eox_tenant.edxapp_wrapper.backends.edxmako_h_v1'
UTILS_MODULE_BACKEND: 'eox_tenant.edxapp_wrapper.backends.util_h_v1'
Juniper
For version >= 3.4
GET_OAUTH_DISPATCH_BACKEND: 'eox_tenant.edxapp_wrapper.backends.oauth_dispatch_j_v1'
Koa (optional)
GET_BRANDING_API: 'eox_tenant.edxapp_wrapper.backends.branding_api_l_v1'
EOX_TENANT_USERS_BACKEND: 'eox_tenant.edxapp_wrapper.backends.users_l_v1'
EDXMAKO_MODULE_BACKEND: eox_tenant.edxapp_wrapper.backends.edxmako_l_v1
Lilac
GET_BRANDING_API: 'eox_tenant.edxapp_wrapper.backends.branding_api_l_v1'
EOX_TENANT_USERS_BACKEND: 'eox_tenant.edxapp_wrapper.backends.users_l_v1'
EDXMAKO_MODULE_BACKEND: eox_tenant.edxapp_wrapper.backends.edxmako_l_v1
Maple
GET_BRANDING_API: 'eox_tenant.edxapp_wrapper.backends.branding_api_l_v1'
EOX_TENANT_USERS_BACKEND: 'eox_tenant.edxapp_wrapper.backends.users_l_v1'
EDXMAKO_MODULE_BACKEND: eox_tenant.edxapp_wrapper.backends.edxmako_l_v1
Those settings can be changed in eox_tenant/settings/common.py
or, for example, in ansible configurations.
NOTE: the current common.py
works with Open edX juniper version.
Migrating from 0.* version to 1.0.0
From version 1.0.0, middlewares RedirectionsMiddleware and PathRedirectionMiddleware are not longer supported in this plugin.These middlewares were moved to the eox-core plugin here. From this, you can have three cases:
You have already installed eox-core alongside eox-tenant. In this case you need to:
- Upgrade eox-core to version 2.0.0 (previous releases are not compatible with eox-tenant 1.0.0)
- Run the plugin migrations as indicated below:
./manage.py lms migrate eox_tenant --settings=<your app settings> ./manage.py lms migrate eox_core --fake-initial --settings=<your app settings>
You only have installed eox-tenant and you want to keep the functionality that middlewares offer. You need to:
- Install eox-core version 2.0.0 as edx-platform requirement. You can use Ansible to add this plugin as an extra requirement.
- Run the plugin migrations as indicated below:
./manage.py lms migrate eox_tenant --settings=<your app settings> ./manage.py manage.py lms migrate eox_core --fake-initial --settings=<your app settings>
In the case your are not using the redirection middlewares, and only have eox-tenant installed, you can simply apply the database migrations for the eox-tenant plugin:
./manage.py manage.py lms migrate eox_tenant --settings=<your app settings>
The table corresponding to the Redirection model will not be deleted but it will be discarded from the Django state
This comand will synchronize the course_org_filter values in lms_configs(TenantConfig model) or values(Microsite model) with the TenantOrganization registers, if the organization does not existe, it will be create, otherwise it will be add to the organizations model field.
./manage.py lms synchronize_organizations # only for TenantConfig and Microsite
./manage.py lms synchronize_organizations --model TenantConfig # only for TenantConfig
./manage.py lms synchronize_organizations --model Microsite # only for Microsite
Contributions are welcome! See our CONTRIBUTING file for more information – it also contains guidelines for how to maintain high code quality, which will make your contribution more likely to be accepted.