Skip to main content

eduNEXT Openedx extensions

Project description

Maintainance Status GitHub Actions Workflow Test Status PyPI - Version

Eox-core is an openedx plugin for the edx-platform, and part of the Edunext Open edX Extensions (aka EOX), that adds multiple API endpoints to extend its functionality and avoid changing the base code directly. These API endpoints include bulk creation of pre-activated users (for example, skip sending an activation email), enrollments, and pre-enrollment operations.

Installation

  1. Add this plugin in your Tutor config.yml with the OPENEDX_EXTRA_PIP_REQUIREMENTS setting.

    OPENEDX_EXTRA_PIP_REQUIREMENTS:
       - eox-core=={{version}} # basic installation
       - eox-core{{requirements}}=={{version}} # requeriments e.g. [sentry,tpa]. Useful for integration with third-party applications.
  2. Save the configuration with tutor config save.

  3. Build an open edx image with tutor images build openedx.

  4. Launch your platform with tutor local launch.

Note: To use all the features, you need to have the tutor-forum plugin and the eox-tenant plugin.

Features

  • Support redirections with middleware.

  • Add pipelines for authentication.

  • Add a group of APIs.

    Eox-core APIs

Usage

See the How to section for guidance on middleware, pipeline and API usage.

Compatibility Notes

Open edX Release

Version

Ironwood

< 4.0

Juniper

>= 3.0 < 5.0

Koa

>= 4.9 < 6.0

Lilac

>= 4.9 < 6.0

Maple

>= 6.0 < 11.0

Nutmeg

>= 7.0 < 11.0

Olive

>= 8.0 < 11.0

Palm

>= 9.0 < 11.0

Quince

>= 10.0 < 12.0

Redwood

>= 10.5.1

Sumac

>= 11.1.0

Teak

>= 12.0.0

The plugin is configured for the latest release (Teak). The following changes in the plugin settings should be applied in order to be used for previous releases.

Maple

EOX_CORE_PRE_ENROLLMENT_BACKEND: "eox_core.edxapp_wrapper.backends.pre_enrollment_l_v1"
EOX_CORE_ENROLLMENT_BACKEND: "eox_core.edxapp_wrapper.backends.enrollment_l_v1"

Nutmeg

EOX_CORE_PRE_ENROLLMENT_BACKEND: "eox_core.edxapp_wrapper.backends.pre_enrollment_l_v1"
EOX_CORE_ENROLLMENT_BACKEND: "eox_core.edxapp_wrapper.backends.enrollment_l_v1"

These settings can be changed in eox_core/settings/common.py or, in the instance settings.

🚨 If the release you are looking for is not listed, please note:

  • If the Open edX release is compatible with the current eox-core version (see Compatibility Notes), the default configuration is sufficient.

  • If incompatible, you can refer to the README from the relevant version tag for configuration details (e.g., v6.2.1 README).

Integrations with third-party services

The plugin offers some integrations listed below:

  1. Sentry: This service allows tracking the errors generated on edx-platform. Check more details at https://sentry.io/welcome/.

    To enable the integration, follow the steps below:

    • Install the plugin with Sentry support (extras_require [sentry]).

    • Sign up/in your sentry account and create a new Django application integration.

    • Get the DSN for your integration. This is a unique identifier for your application.

    • Setup the following configuration values for edx-platform:

      EOX_CORE_SENTRY_INTEGRATION_DSN: <your DSN value>
      EOX_CORE_SENTRY_IGNORED_ERRORS: [] # optional
      EOX_CORE_SENTRY_EXTRA_OPTIONS: {} # optional
      • EOX_CORE_SENTRY_INTEGRATION_DSN: By default the setting is None, which disables the sentry integration.

      • EOX_CORE_SENTRY_IGNORED_ERRORS: List of the exceptions you want to ignore (see below for a reference).

      • EOX_CORE_SENTRY_EXTRA_OPTIONS Dictionary with extra options to be passed to the sentry client. For instance, it can be defined as:

      EOX_CORE_SENTRY_IGNORED_ERRORS: [
        'xmodule.exceptions.NotFoundError',
        'openedx.core.djangoapps.user_authn.exceptions.AuthFailedError',
      ]
      EOX_CORE_SENTRY_EXTRA_OPTIONS:
          experiments:
             profiles_sample_rate: 0.5
          another_client_parameter: 'value'

Auditing Django views

Most views in eox-core use an auditing decorator, defined in our custom library, eox-audit-model, that helps save relevant information about non-idempotent operations. By default, this functionality is turned on. To check your auditing records go to Django sysadmin and find DJANGO EDUNEXT AUDIT MODEL.

You can check the eox-audit-model documentation for more information.

Development

You can find more information about testing in the Help for devs doc.

How to Contribute

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.

License

This software is licensed under the terms of the AGPLv3. See the LICENSE file for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

eox_core-12.1.0.tar.gz (117.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

eox_core-12.1.0-py3-none-any.whl (166.7 kB view details)

Uploaded Python 3

File details

Details for the file eox_core-12.1.0.tar.gz.

File metadata

  • Download URL: eox_core-12.1.0.tar.gz
  • Upload date:
  • Size: 117.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for eox_core-12.1.0.tar.gz
Algorithm Hash digest
SHA256 07d809ac28f17594698aa79e6e193283c0974e1ce0e4f83dbaa81f8023604d96
MD5 27f9afc81468d3db8c19cb3490381ee8
BLAKE2b-256 aff1fa282b79908c2d244e7a2d7cc17180af9977a055ba9b781ac0a6a3d063b2

See more details on using hashes here.

File details

Details for the file eox_core-12.1.0-py3-none-any.whl.

File metadata

  • Download URL: eox_core-12.1.0-py3-none-any.whl
  • Upload date:
  • Size: 166.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for eox_core-12.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 bd2102065a0d8e66ca77437e7ca51d5bd663d5f34429713f35de519b90502bcc
MD5 4bca57e646aa2a266470a50d6782982c
BLAKE2b-256 6af6d1652048afaf8012dd367c8501ffe9a27eac4385056b0470e2fac48f85db

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page