Skip to main content

Learning Paths plugin

Project description

learning-paths-plugin

Purpose

A Learning Path consists of a selection of courses bundled together for learners to progress through. This plugin enables the creation and management of Learning Paths.

License

The code in this repository is licensed under the Not open source unless otherwise noted.

Please see LICENSE.txt for details.

Installation and Configuration

  1. Clone the Repository

    Clone the repository containing the plugin to the src directory under your devstack root:

    git clone <repository_url> <devstack_root>/src/learning-paths-plugin
  2. Install the Plugin

    Inside the LMS shell, install the plugin by running:

    pip install -e /edx/src/learning-paths-plugin/
  3. Run Migrations for the Plugin

    After installing the plugin, run the database migrations for learning_paths:

    ./manage.py lms migrate learning_paths
  4. Run Completion Aggregator Migrations

    Ensure that the completion aggregator service is also up to date by running its migrations:

    ./manage.py lms migrate completion_aggregator

Once these steps are complete, the Learning Paths plugin should be successfully installed and ready to use.

Usage

After installing the plugin, a learning path can be created in the django admin panel {LMS_URL}/admin/learning_paths/learningpath/.

Change Log

Unreleased

0.3.5 - 2025-09-01

Changed

  • Allow changing the Learning Path key in the Django admin interface.

Removed

  • Grading criteria from the Django admin interface.

  • Step weight and order from the Django admin interface.

0.3.4 - 2025-08-02

Added

  • Bulk unenrollment API.

  • Enrollment audit model that tracks the enrollment state transitions.

  • Allow specifying time commitment.

  • Allow duplicating Learning Paths in the Django admin interface.

Changed

  • The Learning Paths API includes start and end dates for its steps.

  • Return enrollment date in the API instead of a boolean.

  • Allow specifying any text for the duration.

  • Make the skill level optional.

0.3.3 - 2025-05-23

Changed

  • Changed line length from 80 to 120 characters.

0.3.2 - 2025-05-02

Added

  • Course key selection in admin forms.

  • Learning Path selection field in admin forms.

  • Enrollment status to the Learning Path list and retrieve APIs.

  • Invite-only functionality for Learning Paths.

  • Course enrollment API.

Changed

  • The Learning Path subtitle to TextField and made it optional.

  • The image URL field to ImageField.

  • The user field on the admin enrollments page to raw ID, to prevent the page from retrieving all users in the system.

Removed

  • The slug field from the Learning Path model.

  • The UUID compatibility layer from Learning Path keys.

0.3.1 - 2025-04-14

Added

  • API for listing and retrieving Learning Paths.

Fixed

  • Automatically create grading criteria for Learning Paths.

Changed

  • Replaced relative due dates with actual due dates from course runs.

0.3.0 - 2025-04-03

Changed

  • Replaced Learning Path UUID with LearningPathKey.

0.2.3 - 2025-03-31

Added

  • Enrollment API.

0.2.2 - 2024-12-05

Added

  • User grade API

0.2.1 - 2024-10-28

Added

  • Progress API

0.2.0 - 2024-01-23

Added

  • Database models

  • Django Admin interface

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

learning_paths_plugin-0.3.5.tar.gz (31.4 kB view details)

Uploaded Source

Built Distribution

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

learning_paths_plugin-0.3.5-py2.py3-none-any.whl (39.4 kB view details)

Uploaded Python 2Python 3

File details

Details for the file learning_paths_plugin-0.3.5.tar.gz.

File metadata

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

File hashes

Hashes for learning_paths_plugin-0.3.5.tar.gz
Algorithm Hash digest
SHA256 5941e2ef7d46e97ce8e21048b8ef040d49cf1ffc38504fbf54b924503a3677a8
MD5 d8dbf6c5568b79939ee2d267e0474cd2
BLAKE2b-256 06dc2516d32c77b093466eae400c240019c4e7f8382fbff738df93b96eb85b3b

See more details on using hashes here.

File details

Details for the file learning_paths_plugin-0.3.5-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for learning_paths_plugin-0.3.5-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 333665f6bdf9104f60acfeca6d89ab85437394fa330a67ed4868de0a5f84246e
MD5 1d3915f30eba4608b9e7671ea6d91714
BLAKE2b-256 b649b642f85e3adeb53bd8c8c7c42c24f66f96f0e51887d01a5fa0c3dd397136

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