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.48 – 2026-03-05

  • fix: extract Percipio user UUID from SSO metadata instead of truncating username

  • fix: use course ID format (course:Org+Course) instead of course run for content_id

  • feat: add Percipio organization UUID to webhook payloads

  • refactor: consolidate webhook payload preparation logic to reduce code duplication

0.1.46 – 2026-02-26

  • fix: allowing django admin adding of WebhookTransmissionQueue

0.1.45 – 2026-02-26

  • chore: upgrade python requirements

0.1.44 – 2026-02-25

  • fix: renaming token field in EnterpriseWebhookConfiguration to be URL

0.1.43 – 2026-02-24

  • build: upgrade pip-tools to version 7.5.3

0.1.47 – 2026-03-04

  • fix: altering migration file to keep in sync

0.1.41 – 2026-02-24

  • fix: setup changes for region specific Percipio integration

0.1.40 – 2026-02-17

  • fix: alerting payload structure to match Skillsoft customer request

0.1.39 – 2026-02-11

  • fix: changing payload structure to match Percipio documentation

0.1.38 – 2026-02-03

  • chore: relax snowflake connector constraint

0.1.37 – 2026-02-03

Changed

  • Set course_completion=False and completed_timestamp=None for xAPI enrollment audit

0.1.36 – 2026-01-30

Changed

  • Optional features for webhook integration

0.1.35 – 2026-01-28

Changed

  • Add missing app_label to models

0.1.34 – 2026-01-27

Changed

  • Switched from consuming events via the event bus to listening to in process Django signals directly.

0.1.33 – 2026-01-20

Changed

  • chore: upgrade python requirements

0.1.32 – 2026-01-19

Changed

  • chore: Add Django>=4.2 constraint to support both Django 4.2 and 5.x

  • fix: Constrain social-auth-app-django<5.5 for Django 4.2 compatibility

0.1.31 – 2026-01-19

Changed

  • chore: Update snowflake-connector-python from 3.7.0 to >=3.18.0,<4.0.0 for compatibility with edx-platform

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.48.tar.gz (234.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.48-py2.py3-none-any.whl (319.3 kB view details)

Uploaded Python 2Python 3

File details

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

File metadata

File hashes

Hashes for enterprise_integrated_channels-0.1.48.tar.gz
Algorithm Hash digest
SHA256 b43cef16577b2547220237620ffd4b8f6aa061d60bf9bfaf9486b8f73dda41d3
MD5 2d8cdb1cf2a93165b35fb74680054f4d
BLAKE2b-256 45eeab4cae260d12bf0ba5b5c83b32f7caea8bb3b5488e549177916a75ae1f50

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for enterprise_integrated_channels-0.1.48-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 8cb3568c10e90d682899607fb881f4bd997f20ace6e394e53a2d23e8cd8420a6
MD5 f2f55454fba85a0a50b7d094374e248c
BLAKE2b-256 7386d534e46918edb9216411c706a048cbd294d4973bbd380924923392cd08a5

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