REST API Client for Open edX |CI|_ |Codecov|_
=============================================
.. |CI| image:: https://github.com/aulasneo/openedx-api-client/workflows/Python%20CI/badge.svg?branch=master
.. _CI: https://github.com/aulasneo/openedx-rest-api-client/actions?query=workflow%3A%22Python+CI%22
.. |Codecov| image:: https://codecov.io/github/aulasneo/openedx-api-client/coverage.svg?branch=master
.. _Codecov: https://codecov.io/github/aulasneo/openedx-rest-api-client?branch=master
The REST API client for Open edX REST API allows users to communicate with various edX REST APIs.
It is based on https://github.com/edx/edx-rest-api-client, whith a few differences:
- It does not depend on Django
- What is called 'the client' in edX's version is now called 'session'.
- As the edX's version relies on Django's cache, now the token is stored in memory under the scope of the session object
- The client here encompasses the session, and one function per REST API entry point
Part of the code is also taken from Opencraft's `implementation of the openedx client`_.
.. _implementation of the openedx client: https://gist.github.com/bradenmacdonald/930c7655dca32dc648af9cb0aed4a7c5
Testing
-------
$ make validate
Usage
~~~~~
The ``OpenedxRESTAPIClient`` object starts a session with the LMS and provides methods to access the Open edX endpoints.
.. code-block:: python
# create client
client = OpenedxRESTAPIClient('https://lms.example.com', 'client_id', 'client_secret')
# get a list of all courses
courses = client.list_all_courses()
Function Reference
------------------
list_all_courses
~~~~~~~~~~~~~~~~
Get the full list of courses visible to the requesting user.
Calls the /api/courses/v1/courses LMS endpoint
Args:
- org: filter by organization
Returns:
- List of dict in the form:
.. code-block::
[
{
"blocks_url": "https://lms.example.com/api/courses/v1/blocks/?course_id=course-v1%3A<org>%2B<code>%2B<edition>",
"effort":"01:00",
"end":"None",
"enrollment_start":"None",
"enrollment_end":"None",
"id":"course-v1:<org>+<code>+<run>",
"media":{
"course_image":{
"uri":"<img path>"
},
"course_video":{
"uri":"None"
},
"image":{
"raw":"<img url>",
"small":"<img url>",
"large":"<img url>"
}
},
"name":"Course name",
"number":"<edition>",
"org":"<org>",
"short_description":"",
"start":"2018-01-11T00:00:00Z",
"start_display":"11 de Enero de 2018",
"start_type":"timestamp",
"pacing":"instructor",
"mobile_available":true,
"hidden":false,
"invitation_only":false,
"course_id":"course-v1:<org>+<code>+<edition>"
},
...
]
change_enrollment
~~~~~~~~~~~~~~~~~
Enroll or unenroll (depending on the value of action) the list of emails in the list of courses.
Calls the /api/bulk_enroll/v1/bulk_enroll/ LMS endpoint
Args:
- emails: list of emails to enroll
- courses: list of course ids to enroll
- action: can be 'enroll' or 'unenroll'
- url: url of the LMS (base or site). If not specified, uses the base url of the session. Defaults to the LMS base.
- auto_enroll: if true, the users will be automatically enrolled as soon as they register. Defaults to true.
- email_students: if true, an email will be sent with the update. Defaults to true.
- cohorts: List of cohort names to add the students to.
Returns:
dict in the form:
.. code-block::
{
"action":"enroll",
"courses":{
"course-v1:ORG+CODE+EDITION":{
"action":"enroll",
"results":[
{
"identifier":"mail@example.com",
"after":{
"enrollment":true,
"allowed":false,
"user":true,
"auto_enroll":false
},
"before":{
"enrollment":false,
"allowed":false,
"user":true,
"auto_enroll":false
}
},
...
],
"auto_enroll":true
},
...
},
"email_students":true,
"auto_enroll":true
}
Account validation
~~~~~~~~~~~~~~~~~~
Validates the account registration form. Calls the `/api/user/v1/validation/registration` API endpoint.
Args:
* url: url of the LMS (base or site). If not specified, uses the base url of the session. Defaults to the LMS base.
* \*\*kwargs: dict with form parameters to validate. E.g.:
.. code-block::
{
email=<email>,
username=<username>,
name=<name>,
password=<password>,
honor_code=<honor_code>,
terms_of_service=<terms_of_service>,
}
Returns:
dict in the form:
.. code-block::
{
'validation_decisions': {
<field name>: <validation result, or empty if success>,
...
},
'username_suggestions': [<username suggestions * 3>]
}
Account registration
~~~~~~~~~~~~~~~~~~~~
Registers a new user account. Calls the `/api/user/v1/account/registration/` API endpoint.
Args:
* email: email to register
* username: username to register
* name: full name of the user
* password: password
* url: url of the LMS (base or site). If not specified, uses the base url of the session.
Defaults to the LMS base.
Additional default fields accepted:
* name: full name of the user
* level_of_education \*: one of:
* 'p': 'Doctorate'
* 'm': "Master's or professional degree"
* 'b': "Bachelor's degree"
* 'a': "Associate degree"
* 'hs': "Secondary/high school"
* 'jhs': "Junior secondary/junior high/middle school"
* 'el': "Elementary/primary school"
* 'none': "No formal education"
* 'other': "Other education"
* gender \*: can be 'm', 'f', or 'o'
* mailing_address *
* city *
* country: ISO3166-1 two letters country codes as used in django_countries.countries *
* goals *
* year_of_birth \*: numeric 4-digit year of birth
* honor_code \*: Bool. If mandatory and not set will not create the account.
* terms_of_service \*: Bool. If unset, will be set equally to honor_code
* marketing_emails_opt_in \*: Bool. If set, will add a is_marketable user attribute (see Student > User Attributes in Django admin)
* provider: Oauth2 provider information
* social_auth_provider: Oauth2 provider information
\* Can be set as hidden, optional or mandatory in REGISTRATION_EXTRA_FIELDS setting.
Returns:
Dict with the form:
- If successful:
.. code-block::
{
'success': True,
'redirect_url': <redirection url to finish the authorization and go to the dashboard>
}
- If error:
.. code-block::
{
<field name>: [
{'user_message': <error message>}
]
'error_code': <error code>,
'username_suggestions': [<username suggestions> * 3]
}
How to Contribute
-----------------
To contribute, please send a message to `andres@aulasneo.com`_
.. _andres@aulasneo.com: mailto:andres@aulasneo.com
Raw data
{
"_id": null,
"home_page": "https://github.com/aulasneo/openedx-rest-api-client",
"name": "openedx-rest-api-client",
"maintainer": "",
"docs_url": null,
"requires_python": "",
"maintainer_email": "",
"keywords": "openedx rest api client",
"author": "Aulasneo",
"author_email": "andres@aulasneo.com",
"download_url": "https://files.pythonhosted.org/packages/e6/e8/b3da5bcc0049f47bc6b1d8c03ed33cf222f66ad518c3f5d0717c80907629/openedx-rest-api-client-0.3.1.tar.gz",
"platform": null,
"description": "REST API Client for Open edX |CI|_ |Codecov|_\n=============================================\n.. |CI| image:: https://github.com/aulasneo/openedx-api-client/workflows/Python%20CI/badge.svg?branch=master\n.. _CI: https://github.com/aulasneo/openedx-rest-api-client/actions?query=workflow%3A%22Python+CI%22\n\n.. |Codecov| image:: https://codecov.io/github/aulasneo/openedx-api-client/coverage.svg?branch=master\n.. _Codecov: https://codecov.io/github/aulasneo/openedx-rest-api-client?branch=master\n\nThe REST API client for Open edX REST API allows users to communicate with various edX REST APIs.\nIt is based on https://github.com/edx/edx-rest-api-client, whith a few differences:\n\n- It does not depend on Django\n- What is called 'the client' in edX's version is now called 'session'.\n- As the edX's version relies on Django's cache, now the token is stored in memory under the scope of the session object\n- The client here encompasses the session, and one function per REST API entry point\n\nPart of the code is also taken from Opencraft's `implementation of the openedx client`_.\n\n.. _implementation of the openedx client: https://gist.github.com/bradenmacdonald/930c7655dca32dc648af9cb0aed4a7c5\n\n\nTesting\n-------\n $ make validate\n\n\nUsage\n~~~~~\n\nThe ``OpenedxRESTAPIClient`` object starts a session with the LMS and provides methods to access the Open edX endpoints.\n\n.. code-block:: python\n\n # create client\n client = OpenedxRESTAPIClient('https://lms.example.com', 'client_id', 'client_secret')\n\n # get a list of all courses\n courses = client.list_all_courses()\n\nFunction Reference\n------------------\n\nlist_all_courses\n~~~~~~~~~~~~~~~~\nGet the full list of courses visible to the requesting user.\nCalls the /api/courses/v1/courses LMS endpoint\n\nArgs:\n\n- org: filter by organization\n\nReturns:\n\n- List of dict in the form:\n\n.. code-block::\n\n [\n {\n \"blocks_url\": \"https://lms.example.com/api/courses/v1/blocks/?course_id=course-v1%3A<org>%2B<code>%2B<edition>\",\n \"effort\":\"01:00\",\n \"end\":\"None\",\n \"enrollment_start\":\"None\",\n \"enrollment_end\":\"None\",\n \"id\":\"course-v1:<org>+<code>+<run>\",\n \"media\":{\n \"course_image\":{\n \"uri\":\"<img path>\"\n },\n \"course_video\":{\n \"uri\":\"None\"\n },\n \"image\":{\n \"raw\":\"<img url>\",\n \"small\":\"<img url>\",\n \"large\":\"<img url>\"\n }\n },\n \"name\":\"Course name\",\n \"number\":\"<edition>\",\n \"org\":\"<org>\",\n \"short_description\":\"\",\n \"start\":\"2018-01-11T00:00:00Z\",\n \"start_display\":\"11 de Enero de 2018\",\n \"start_type\":\"timestamp\",\n \"pacing\":\"instructor\",\n \"mobile_available\":true,\n \"hidden\":false,\n \"invitation_only\":false,\n \"course_id\":\"course-v1:<org>+<code>+<edition>\"\n },\n ...\n ]\n\nchange_enrollment\n~~~~~~~~~~~~~~~~~\n\nEnroll or unenroll (depending on the value of action) the list of emails in the list of courses.\nCalls the /api/bulk_enroll/v1/bulk_enroll/ LMS endpoint\n\nArgs:\n\n- emails: list of emails to enroll\n- courses: list of course ids to enroll\n- action: can be 'enroll' or 'unenroll'\n- url: url of the LMS (base or site). If not specified, uses the base url of the session. Defaults to the LMS base.\n- auto_enroll: if true, the users will be automatically enrolled as soon as they register. Defaults to true.\n- email_students: if true, an email will be sent with the update. Defaults to true.\n- cohorts: List of cohort names to add the students to.\n\nReturns:\n\ndict in the form:\n\n.. code-block::\n\n {\n \"action\":\"enroll\",\n \"courses\":{\n \"course-v1:ORG+CODE+EDITION\":{\n \"action\":\"enroll\",\n \"results\":[\n {\n \"identifier\":\"mail@example.com\",\n \"after\":{\n \"enrollment\":true,\n \"allowed\":false,\n \"user\":true,\n \"auto_enroll\":false\n },\n \"before\":{\n \"enrollment\":false,\n \"allowed\":false,\n \"user\":true,\n \"auto_enroll\":false\n }\n },\n ...\n ],\n \"auto_enroll\":true\n },\n ...\n },\n \"email_students\":true,\n \"auto_enroll\":true\n }\n\nAccount validation\n~~~~~~~~~~~~~~~~~~\n\nValidates the account registration form. Calls the `/api/user/v1/validation/registration` API endpoint.\n\nArgs:\n\n* url: url of the LMS (base or site). If not specified, uses the base url of the session. Defaults to the LMS base.\n* \\*\\*kwargs: dict with form parameters to validate. E.g.:\n\n.. code-block::\n\n {\n email=<email>,\n username=<username>,\n name=<name>,\n password=<password>,\n honor_code=<honor_code>,\n terms_of_service=<terms_of_service>,\n }\n\nReturns:\ndict in the form:\n\n.. code-block::\n\n {\n 'validation_decisions': {\n <field name>: <validation result, or empty if success>,\n ...\n },\n 'username_suggestions': [<username suggestions * 3>]\n }\n\n\nAccount registration\n~~~~~~~~~~~~~~~~~~~~\n\nRegisters a new user account. Calls the `/api/user/v1/account/registration/` API endpoint.\n\nArgs:\n\n* email: email to register\n* username: username to register\n* name: full name of the user\n* password: password\n* url: url of the LMS (base or site). If not specified, uses the base url of the session.\n Defaults to the LMS base.\n\nAdditional default fields accepted:\n\n* name: full name of the user\n* level_of_education \\*: one of:\n * 'p': 'Doctorate'\n * 'm': \"Master's or professional degree\"\n * 'b': \"Bachelor's degree\"\n * 'a': \"Associate degree\"\n * 'hs': \"Secondary/high school\"\n * 'jhs': \"Junior secondary/junior high/middle school\"\n * 'el': \"Elementary/primary school\"\n * 'none': \"No formal education\"\n * 'other': \"Other education\"\n* gender \\*: can be 'm', 'f', or 'o'\n* mailing_address *\n* city *\n* country: ISO3166-1 two letters country codes as used in django_countries.countries *\n* goals *\n* year_of_birth \\*: numeric 4-digit year of birth\n* honor_code \\*: Bool. If mandatory and not set will not create the account.\n* terms_of_service \\*: Bool. If unset, will be set equally to honor_code\n* marketing_emails_opt_in \\*: Bool. If set, will add a is_marketable user attribute (see Student > User Attributes in Django admin)\n* provider: Oauth2 provider information\n* social_auth_provider: Oauth2 provider information\n\n\\* Can be set as hidden, optional or mandatory in REGISTRATION_EXTRA_FIELDS setting.\n\n\nReturns:\nDict with the form:\n\n- If successful:\n\n.. code-block::\n\n {\n 'success': True,\n 'redirect_url': <redirection url to finish the authorization and go to the dashboard>\n }\n\n- If error:\n\n.. code-block::\n\n {\n <field name>: [\n {'user_message': <error message>}\n ]\n 'error_code': <error code>,\n 'username_suggestions': [<username suggestions> * 3]\n }\n\nHow to Contribute\n-----------------\n\nTo contribute, please send a message to `andres@aulasneo.com`_\n\n.. _andres@aulasneo.com: mailto:andres@aulasneo.com\n",
"bugtrack_url": null,
"license": "Apache",
"summary": "Standalone client used to access Open edX REST APIs.",
"version": "0.3.1",
"project_urls": {
"Homepage": "https://github.com/aulasneo/openedx-rest-api-client"
},
"split_keywords": [
"openedx",
"rest",
"api",
"client"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "dc383c0b9cfbbf21b099557b118620eb55a6c84aeccde0e18d8fa3457e1fd0b5",
"md5": "8fb2b340319e820aa6ee4556dc91bfa5",
"sha256": "0e17822423ccd61c2a67e8379e8a185ba6420b4af5d39f77d17bb53857d8fae1"
},
"downloads": -1,
"filename": "openedx_rest_api_client-0.3.1-py3-none-any.whl",
"has_sig": false,
"md5_digest": "8fb2b340319e820aa6ee4556dc91bfa5",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": null,
"size": 19037,
"upload_time": "2024-02-15T20:08:49",
"upload_time_iso_8601": "2024-02-15T20:08:49.639543Z",
"url": "https://files.pythonhosted.org/packages/dc/38/3c0b9cfbbf21b099557b118620eb55a6c84aeccde0e18d8fa3457e1fd0b5/openedx_rest_api_client-0.3.1-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "e6e8b3da5bcc0049f47bc6b1d8c03ed33cf222f66ad518c3f5d0717c80907629",
"md5": "2655719da7817c639c0c46a3ac44c0e4",
"sha256": "37158d76d1d7eba21193f52731bfb9567ef460d7c00bbbb8eb2f62db35580a90"
},
"downloads": -1,
"filename": "openedx-rest-api-client-0.3.1.tar.gz",
"has_sig": false,
"md5_digest": "2655719da7817c639c0c46a3ac44c0e4",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 17838,
"upload_time": "2024-02-15T20:09:18",
"upload_time_iso_8601": "2024-02-15T20:09:18.944888Z",
"url": "https://files.pythonhosted.org/packages/e6/e8/b3da5bcc0049f47bc6b1d8c03ed33cf222f66ad518c3f5d0717c80907629/openedx-rest-api-client-0.3.1.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-02-15 20:09:18",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "aulasneo",
"github_project": "openedx-rest-api-client",
"travis_ci": false,
"coveralls": false,
"github_actions": false,
"requirements": [],
"lcname": "openedx-rest-api-client"
}