Skip to content

Latest commit

 

History

History
25 lines (13 loc) · 1.93 KB

readme.md

File metadata and controls

25 lines (13 loc) · 1.93 KB

Moodle API Tools

Example scripts for accessing different portions of the Moodle REST APIs. The Moodle APIs are comprehensive but tricky to use. These scripts are illustrative and not intended for production use, though similar code is running in other CCA apps.

Setup

Obtain a Web Services token for a Service with the appropriate API permissions, then save that token in a config.py file (see example.config.py for details) in the root of this project.

This project uses uv. Run uv sync to install its dependencies.

course_get_categories

This script was an example provided to the Integration Engineer so that a Moodle course database could be built which includes structured enrollment data with knowledge of Moodle course category IDs. This makes it so courses are added under the appropriate categories when they appear in the database. It takes a "filter" dict of category properties (e.g. {"name": "2021SU"}) and returns an array of all categories that match the filter and their children.

course_get_courses_by_field

This script was an example provided to the Portal team during Learning Hub development so that links to Moodle course sites could be established. The Portal has moved away from having direct access to the Moodle database but Moodle course links require knowledge of Moodle's internal IDs; this script returns course information, including ID, when given a "shortname" of form ANIMA-1000-1-2021FA.

course_get_courses

Returns all the Moodle courses using the core_course_get_courses wsfunction. This is currently (as of August 2020) the method that the Portal uses to pull Moodle data, which it matches to its course data. So we need to ensure this function works with whatever web services user/token Portal uses.

enrol_get_enrolled_users

Given a course ID, returns a list of users enrolled in that course using the core_enrol_get_enrolled_users function.