Skip to main content

An app for storing LTI provider configurations centrally.

Project description

Openedx LTI Store

A plugin for openedx-platform to store LTI configurations centrally. This allows course creators to add LTI components without having to enter the details like secrets, keys and URLs everytime the component block is created.

Development

The development instructions are written with the Open edX Devstack as reference.

  1. Clone the repostiory to <devstack_root>/src/ directory
    cd <devstack_root>/src/
    git clone git@github.com:open-craft/openedx-ltistore.git
    
  2. Install the plugin inside the Studio container and run migrations
    cd <devstack_root>/devstack/
    make studio-shell
    pip install -e /edx/src/openedx-ltistore
    python manage.py cms migrate lti_store
    exit
    
  3. Install the plugin inside the LMS Container
    make lms-shell
    pip install -e /edx/src/openedx-ltistore
    exit
    
  4. The LTI Consumer XBlock can fetch configurations to LTI Tools using openedx-filters mechanism. It calls the filter org.openedx.xblock.lti_consumer.configuration.listed.v1 whenever it wants to fetch the configurations from external tools like plugins. In order for LTI Store to send available LTI Tools, add the following to any existing openedx-filters configurations for both LMS (edx-platform/lms/envs/devstack.py or private.py) and studio (edx-platform/cms/envs/devstack.py):
    OPEN_EDX_FILTERS_CONFIG = {
        "org.openedx.xblock.lti_consumer.configuration.listed.v1": {
            "fail_silently": False,
            "pipeline": [
                "lti_store.pipelines.GetLtiConfigurations"
            ]
        }
    }
    
  5. Restart the LMS & Studio for the latest config to take effect
    make lms-restart
    make studio-restart
    

Now any changes made to the source code should reflect in the application

Adding LTI Tools to the store

  1. Go to http://localhost:18000/admin
  2. Look for LTI_STORE and add External lti configurations by clicking + Add button

Use configuration on LTI consumer XBlock

  1. Go to http://localhost:18000/admin
  2. Look for LTI_STORE and go to External lti configurations
  3. On the list of external LTI configurations, note down the "Filter Key" value of the configuration to use (Example: lti_store:1).
  4. Copy "Filter Key" to the "External ID" field on the LTI consumer XBlock.

Linting

The project uses Black for linting. To lint the code

make lint

Testing

Unit tests can be run with

make test

Change Log

Unreleased

1.1.4 - 2025-11-18

Fixed

  • Fixes the migration conflict described in #37 where two migrations had the same number (0003).

1.1.3 - 2025-10-06

Fixed

  • Updated the readable name for LTI 1.1 fields. Making for a nicer admin experience.

1.1.2 - 2025-09-19

Fixed

  • Fixed issue with LTI 1.3 public JWK not being included in serialized config.

1.1.0 – 2025-05-21

Added

  • Initial release to PyPI.
  • CI pipelines.
  • Django 5.2 support.

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

openedx_ltistore-1.1.4.tar.gz (24.5 kB view details)

Uploaded Source

Built Distribution

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

openedx_ltistore-1.1.4-py2.py3-none-any.whl (23.3 kB view details)

Uploaded Python 2Python 3

File details

Details for the file openedx_ltistore-1.1.4.tar.gz.

File metadata

  • Download URL: openedx_ltistore-1.1.4.tar.gz
  • Upload date:
  • Size: 24.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for openedx_ltistore-1.1.4.tar.gz
Algorithm Hash digest
SHA256 d5791c1d43ad84c8e2e07e07193f2fe6f1185d3a080ef7e49605230b40f74f53
MD5 9d0518be41070bde9d413636a72d89b0
BLAKE2b-256 27719686b204ac3a69748c2ac73c3aa1cf1aea92dabda51ebe11ae3fea33a861

See more details on using hashes here.

File details

Details for the file openedx_ltistore-1.1.4-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for openedx_ltistore-1.1.4-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 905f1548d9f6fc741f201f091f971e6ae6eac713032c5771df72fbfff99261c0
MD5 16cab49d04330430617a5d1b1b8864ae
BLAKE2b-256 88b211168c0a5ecd2fdb9b6113e187dd060a32507383da25640a3fc0a804eb95

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