Skip to main content

Terminal-first CLI for Moodle LMS

Project description

moodle-cli

Terminal-first CLI for Moodle LMS that reuses an authenticated browser session.

Features

  • No API token setup required
  • Reuses MoodleSession from okta-auth, your browser, or MOODLE_SESSION
  • Works with Moodle AJAX APIs and falls back to authenticated page scraping when needed
  • Upcoming timeline items for student-facing deadlines and actions
  • Terminal output plus --json and --yaml

Requirements

  • Python 3.10+
  • uv
  • One of:
    • okta-auth-cli configured for your Moodle site
    • An active Moodle browser session
    • A MOODLE_SESSION environment variable

Install

# Recommended: uv tool
uv tool install moodle-cli

# Optional: automatic Okta login and session reuse
uv tool install okta-auth-cli
okta config

# Alternative: pipx
pipx install moodle-cli

Agent Skill

Install the agent skill with the shared skills CLI spec:

npx skills add https://github.com/bunizao/moodle-cli

If you already installed moodle, the CLI exposes the same thing as a thin alias:

moodle skills add

If npx is not available, the alias falls back to npm exec.

Install from source:

git clone https://github.com/bunizao/moodle-cli.git
cd moodle-cli
uv sync

Usage

moodle --help
moodle user
moodle alerts
moodle todo
moodle overview
moodle courses
moodle grades 34637
moodle activities 34637
moodle https://school.example.edu/course/view.php?id=34637
moodle https://school.example.edu/mod/forum/discuss.php?d=9001#p9101 --json
moodle skills
moodle skills add
moodle update
moodle update --check-only

You can also paste supported Moodle page URLs directly as the first argument. The CLI routes forum discussion, forum view, assignment, quiz, resource, link, page, folder, course, and grade report URLs to the shortest matching command.

To check without applying an upgrade:

moodle update --check-only

moodle update now tries to upgrade directly with uv tool upgrade moodle-cli and falls back to pipx upgrade moodle-cli when needed.

To upgrade manually after an update is available:

uv tool upgrade moodle-cli
# or
pipx upgrade moodle-cli

Configuration

On first run, if no base_url is configured, the CLI will prompt you and write it to config.yaml in the project directory or in ~/.config/moodle-cli/:

base_url: https://school.example.edu

Required format:

  • Use a full root URL such as https://school.example.edu
  • Do not include paths, query strings, or fragments
  • Do not use URLs like /login/index.php or /my/
  • The CLI validates the URL against Moodle's token endpoint and asks again if it does not look valid

You can also set MOODLE_BASE_URL instead of using the interactive prompt. You can copy from config.example.yaml.

Environment overrides:

  • MOODLE_BASE_URL
  • MOODLE_SESSION

Development

uv run python -m compileall moodle_cli
uv build

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

moodle_cli-0.4.2.tar.gz (104.5 kB view details)

Uploaded Source

Built Distribution

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

moodle_cli-0.4.2-py3-none-any.whl (47.3 kB view details)

Uploaded Python 3

File details

Details for the file moodle_cli-0.4.2.tar.gz.

File metadata

  • Download URL: moodle_cli-0.4.2.tar.gz
  • Upload date:
  • Size: 104.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for moodle_cli-0.4.2.tar.gz
Algorithm Hash digest
SHA256 0a7efc23c1d13e01f22f841106399c4e97bd7cdd1b2122bbe1025b422a7020c3
MD5 550aa6cdac24756af197ff7057f4de5b
BLAKE2b-256 416dc2a632042a1e4b9877c1f736893ab4a4328d922a7fff42a0af806a7af5be

See more details on using hashes here.

Provenance

The following attestation bundles were made for moodle_cli-0.4.2.tar.gz:

Publisher: publish.yml on bunizao/moodle-cli

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file moodle_cli-0.4.2-py3-none-any.whl.

File metadata

  • Download URL: moodle_cli-0.4.2-py3-none-any.whl
  • Upload date:
  • Size: 47.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for moodle_cli-0.4.2-py3-none-any.whl
Algorithm Hash digest
SHA256 dc4165e91480fb6b726b51d395865573934fb2f6a7a1e2f7018a7a2fbbb5ff62
MD5 4f606a8fd4c799c998723b3c7e20f198
BLAKE2b-256 c55b4999cc3d217e3a79048517db761281406501f4084f338b1de8581ce5c2cb

See more details on using hashes here.

Provenance

The following attestation bundles were made for moodle_cli-0.4.2-py3-none-any.whl:

Publisher: publish.yml on bunizao/moodle-cli

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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