Skip to main content

An integrated channel is an abstraction meant to represent a third-party system which provides an API that can be used to transmit EdX data to the third-party system.

Project description

enterprise-integrated-channels

PyPI CI Codecov Documentation Supported Python versions License status-badge

Purpose

An integrated channel is an abstraction meant to represent a third-party system which provides an API that can be used to transmit EdX data to the third-party system. The most common example of such a third-party system is an enterprise-level learning management system (LMS). LMS users are able to discover content made available by many different content providers and manage the learning outcomes that are produced by interaction with the content providers. In such a scenario, EdX would be the content provider while a system like SAP SuccessFactors would be the integrated channel.

Getting Started with Development

Please see the Open edX documentation for guidance on Python development in this repo.

Running tests locally

Once inside an LMS Devstack container, you’ll want to run unit tests via tox:

tox

tox will run tests via the pytest inside a virtual environment. If you want to pass arguments to pytest, you can pass them after a -- in the command:

tox -- tests/test_channel_integrations/test_api/test_base_views.py -v

It’s necessary to use tox both because of its use of a python virtual environment (which helps stay isolated from the edxapp python virtual environment), and because it adds the mock_apps/ directory to the PYTHONPATH.

Getting Help

Documentation

Start by going through the documentation. If you need more help see below.

More Help

If you’re having trouble, we have discussion forums at https://discuss.openedx.org where you can connect with others in the community.

Our real-time conversations are on Slack. You can request a Slack invitation, then join our community Slack workspace.

For anything non-trivial, the best path is to open an issue in this repository with as many details about the issue you are facing as you can provide.

https://github.com/openedx/enterprise-integrated-channels/issues

For more information about these options, see the Getting Help page.

License

The code in this repository is licensed under the AGPL 3.0 unless otherwise noted.

Please see LICENSE.txt for details.

Contributing

Contributions are very welcome. Please read How To Contribute for details.

This project is currently accepting all types of contributions, bug fixes, security fixes, maintenance work, or new features. However, please make sure to discuss your new feature idea with the maintainers before beginning development to maximize the chances of your change being accepted. You can start a conversation by creating a new issue on this repo summarizing your idea.

The Open edX Code of Conduct

All community members are expected to follow the Open edX Code of Conduct.

People

The assigned maintainers for this component and other project details may be found in Backstage. Backstage pulls this data from the catalog-info.yaml file in this repo.

Reporting Security Issues

Please do not report security issues in public. Please email security@openedx.org.

Change Log

Unreleased

0.1.30 – 2026-01-19

Added

  • feat: Add webhook learning time enrichment from Snowflake with dedicated Celery queue

  • test: Add comprehensive test coverage for webhook task routing and branch conditions

0.1.29 – 2026-01-17

Added

  • chore: add logging to track sending course completion xAPI statements

0.1.28 – 2026-01-13

Fixed

  • fix: change webhook model id fields to AutoField for edx-platform compatibility

0.1.27 – 2026-01-12

Added

  • feat: Region-aware webhook system for enterprise course completion

  • chore: add logging for track sending course completion xAPI statements

Fixed

[0.1.26] - 2026-01-08

Added

0.1.25 – 2025-11-28

Added

  • feat: fetch SAP userid by remote_id_field_name

0.1.24 – 2025-11-24

Added

  • Feat: Update Moodle serialiser to accomodates changes made in edx-enterprise

0.1.23 – 2025-10-30

Added

  • Upgrade Python Requirements

0.1.22 – 2025-10-23

Added

  • feat: Optimize data migration command by implementing bulk inserts for improved performance.

  • feat: Add management command to truncate non-empty destination tables before data migration.

0.1.21 – 2025-10-22

Added

  • Upgrade Python Requirements

  • fix: Convert UUIDField columns to uuid type for MariaDB

0.1.20 – 2025-10-19

Added

  • Upgrade Python Requirements

0.1.19 – 2025-10-09

Added

  • Upgrade Python Requirements

0.1.18 – 2025-10-03

Added

  • Upgrade Python Requirements

0.1.17 – 2025-09-26

Added

  • Upgrade Python Requirements

0.1.16 – 2025-09-15

Added

  • Enhances the migration command with customer-specific functionality to support targeted data migration during the integrated channels transition.

0.1.15 – 2025-09-01

Added

  • Add explicit index naming for SAP SuccessFactors audit table and corresponding database migration.

0.1.14 – 2025-08-13

Added

  • Upgrade Python Requirements

0.1.13 – 2025-07-23

Added

  • Add __init__.py to api/v1/ directory to ensure it is recognized as a package.

0.1.12 – 2025-07-22

Added

  • Upgrade Python Requirements

0.1.11 – 2025-07-15

Added

  • Update CHANGELOG and README

0.1.10 – 2025-07-15

Added

  • Fix admin redirects for various channel integrations to use the correct app namespace.

  • Upgrade Python Requirements

0.1.9 – 2025-07-04

Added

  • Upgrade Python Requirements

0.1.8 – 2025-06-26

Added

  • fix test_migrations_are_in_sync test on edx-platform

0.1.7 – 2025-06-25

Added

  • add migrations for various channel integrations

0.1.6 – 2025-06-25

Added

  • Upgrade Python Requirements

0.1.5 – 2025-06-16

Added

  • Rename xAPI management commands to avoid conflicts with existing commands in edx-enterprise.

0.1.4 – 2025-06-11

Added

  • Added django52 support.

0.1.3 – 2025-06-10

Added

  • Add DB migrations against index_together changes.

0.1.2 – 2025-05-30

Added

  • Added management command to copy data from legacy tables to new tables.

  • Added (Experimental) tag to app name in the admin interface.

0.1.1 – 2025-05-20

Added

  • Renamed jobs to avoid conflicts with existing jobs in edx-enterprise.

0.1.0 – 2025-01-16

Added

  • First release on PyPI.

  • Created mock_apps for testing purposes.

  • Updated requirements in base.in and run make requirements.

  • Migrated integrated_channel app from edx-enterprise.

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

enterprise_integrated_channels-0.1.30.tar.gz (227.6 kB view details)

Uploaded Source

Built Distribution

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

enterprise_integrated_channels-0.1.30-py2.py3-none-any.whl (309.6 kB view details)

Uploaded Python 2Python 3

File details

Details for the file enterprise_integrated_channels-0.1.30.tar.gz.

File metadata

File hashes

Hashes for enterprise_integrated_channels-0.1.30.tar.gz
Algorithm Hash digest
SHA256 fa7909eb06d169e691e883b7e5e21f00820643831337966df0978cd8297a8d03
MD5 3e20ef94ef37374b3222b836648d0db9
BLAKE2b-256 8fb9acd80095731cddd771e85ce50be8f4ae61f7c8ad2ac4e5efea97a5c1be5d

See more details on using hashes here.

File details

Details for the file enterprise_integrated_channels-0.1.30-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for enterprise_integrated_channels-0.1.30-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 5917fb2557442845b39360de9edd535a16405beb72167b4cecae593c946cd0e6
MD5 ea727a518160748b8fb85dda3b784010
BLAKE2b-256 005e9aff5211eaae46783f2bfcd6b1caa1e119328705b28bf0e98b98babcdc73

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