Skip to main content

A django app plugin to add a new API to Open edX to export courses to S3 buckets

Project description

Course Export S3 Plugin

A django app plugin to add a new API to Open edX to export courses to S3 buckets.

Installation

You can install this plugin into any Open edX instance by using the following method:

Install from PyPI

pip install openedx-course-export

Configuration

1) edx-platform configuration

For testing, you might need to add the following configuration values to the config file in Open edX. For any release after Juniper, that config file is /edx/etc/studio.yml.

AWS_ACCESS_KEY_ID: <your aws access id>
AWS_SECRET_ACCESS_KEY: <your api access key>
COURSE_IMPORT_EXPORT_BUCKET: <bucket name to export the courses to>

How To Use

The API supports a POST API call that accepts the list of course Ids and returns the uploaded paths of the courses on S3

To call the API, Send a POST request to <STUDIO_BASE>/api/courses/v0/export/ with the a payload with a list of course IDs that might look like:

{
   "courses": ["course-v1:edX+DemoX+Demo_Course"]
}

The successful response would look like:

With 200

{
    "successful_uploads": {
        "course-v1:edX+DemoX+Demo_Course": "https://bucket_name.s3.amazonaws.com/course-v1:edX+DemoX+Demo_Course.tar.gz",
        "course-v1:edX+Test+Test_Course": "https://bucket_name.s3.amazonaws.com/course-v1:edX+Test+Test_Course.tar.gz"
    },
    "failed_uploads": {}
}

With 400

{
    "successful_uploads": {
        "course-v1:edX+DemoX+Demo_Course": "https://bucket_name.s3.amazonaws.com/course-v1:edX+DemoX+Demo_Course.tar.gz",
    },
    "failed_uploads": {
        "course-v1:edX+Test+Test_Course": "Error message"
    }
}

The response will contain either the s3 bucket url for successful uploads and/or an error message for failed uploads.

Change Log

Unreleased
[0.1.0] - 2023-02-24

Added

  • First release on PyPI.

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_course_export-0.1.4.tar.gz (21.9 kB view details)

Uploaded Source

Built Distribution

openedx_course_export-0.1.4-py2.py3-none-any.whl (21.6 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file openedx_course_export-0.1.4.tar.gz.

File metadata

  • Download URL: openedx_course_export-0.1.4.tar.gz
  • Upload date:
  • Size: 21.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.16

File hashes

Hashes for openedx_course_export-0.1.4.tar.gz
Algorithm Hash digest
SHA256 298ca54e5e8dfb5b20385045f5da121294974d0c805e1f770984bdcf4c2dec82
MD5 b6dcab6156a0d9955de64b7f6d104a76
BLAKE2b-256 56b2da0c15fbba603e6a99ad55e7ae39e43a1cfdfd9e17db0175176b0785a740

See more details on using hashes here.

File details

Details for the file openedx_course_export-0.1.4-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for openedx_course_export-0.1.4-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 face0ecb1b88ee4c2c2de19ffd7bb340277c4e04b96e205d714d755d985fc65b
MD5 a89a0086f5c78054f337d7649337dd9f
BLAKE2b-256 cebf6388209ac6940dbb61f244c3860bc2ff43fbfc2054c6b40fb08816159c6a

See more details on using hashes here.

Supported by

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