Skip to main content

CLI tools for setting up and retiring GitHub-backed course repositories

Project description

course-setup

CLI tools for setting up and retiring GitHub-backed course repositories.

Installation

Install as a uv tool (recommended):

uv tool install course-setup

This makes setup-course, retire-course, and setup-course-config available on your PATH. To upgrade:

uv tool upgrade course-setup

You can also install with pip (pip install course-setup).

Configuration

Generate a starter config file:

setup-course-config

This creates ~/.config/course-setup/config.toml. Open it and fill in your settings:

[github]
token = "ghp_YOUR_TOKEN_HERE"

[paths]
archive = "/path/to/your/archive"
# readme_source = "/path/to/custom/README.md"   # or a URL

[defaults]
notebook_type = "jupyter"   # or "marimo"
Setting Required Description
[github] token Yes GitHub personal access token. Alternatively, set the GITHUB_TOKEN environment variable.
[paths] archive Yes Directory where retired courses are archived.
[paths] readme_source No Local path or URL to a custom README for new courses. Omit to use the bundled default.
[defaults] notebook_type No "jupyter" (default) or "marimo".

To regenerate the config file, use setup-course-config --force.

Usage

setup-course — Create a new course repo

setup-course -c Acme -t python-intro
Flag Description
-c, --client Client name (required)
-t, --topic Course topic (required)
-d, --date YYYY-MM override (defaults to current month)
-n, --num-sessions Number of sessions (creates one notebook per session)
--freq Session frequency: daily or weekly (requires -n, defaults to daily)
--notebook-type jupyter or marimo (overrides config default)
--extras Dependency groups to add to the course pyproject.toml (see below)
--add-imports Pre-populate notebooks with import statements from --extras groups

Dependency groups

Group Packages
python ipython
data numpy, pandas, xlrd, openpyxl, plotly
viz matplotlib, seaborn
geo geopandas, folium, shapely
db duckdb, sqlalchemy
ml scikit-learn

You can also define custom groups in your config.toml under [extras]:

[extras]
finance = ["yfinance", "pandas-datareader"]

Example — a Pandas course with Python extras and data/viz packages:

setup-course -c Acme -t pandas --extras python data

This will:

  1. Create a directory and GitHub repo named {client}-{topic}-{YYYY-MM}
  2. Create a notebook per session, named {client}-{topic}-{YYYY-MM-DD} (.ipynb for Jupyter, .py for Marimo)
  3. Generate a pyproject.toml with the notebook dependency and gitautopush
  4. Configure the local .git/config with the GitHub SSH remote
  5. Make an initial commit and push to GitHub
  6. Run uv sync to install all dependencies

By default, a single notebook is created for today's date. Use -n to create multiple notebooks for multi-day or multi-week courses:

setup-course -c Acme -t python-intro -n 5              # 5 daily sessions
setup-course -c Acme -t python-intro -n 5 --freq weekly # 5 weekly sessions

retire-course — Archive a course repo

retire-course ./Acme-python-intro-2026-03
Argument Description
DIRNAME... One or more course directories to retire

This will (for each directory):

  1. Make the GitHub repo private
  2. Move the local directory to your configured archive path under the current year

You can retire multiple courses at once:

retire-course ./Acme-2026-03 ./Beta-2026-03 ./Gamma-2026-02

If any directory fails, the rest are still processed and errors are reported at the end.

Live teaching with gitautopush

In a separate terminal, run uv run gitautopush . from inside the course directory. This watches for notebook changes and automatically pushes them to GitHub, so students can follow along in real time by viewing the public repo.

Development

git clone https://github.com/reuven/course-setup.git
cd course-setup
uv sync --dev

Run tests, format, and lint:

uv run pytest
uv run black src/ tests/
uv run ruff check src/ tests/
uv run mypy --strict src/

License

MIT — see LICENSE for details.

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

course_setup-2.5.0.tar.gz (21.2 kB view details)

Uploaded Source

Built Distribution

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

course_setup-2.5.0-py3-none-any.whl (12.7 kB view details)

Uploaded Python 3

File details

Details for the file course_setup-2.5.0.tar.gz.

File metadata

  • Download URL: course_setup-2.5.0.tar.gz
  • Upload date:
  • Size: 21.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.11 {"installer":{"name":"uv","version":"0.10.11","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for course_setup-2.5.0.tar.gz
Algorithm Hash digest
SHA256 9a3b962c77942124a3803249c259d1624abe142ca046eb3e9b0ec5ad490fce79
MD5 58a1730087220b9cb81d624b230c1d36
BLAKE2b-256 3f92b276c6164245cf16d93a436b47e35765d7fba326d818dffcf3a877f35ef3

See more details on using hashes here.

File details

Details for the file course_setup-2.5.0-py3-none-any.whl.

File metadata

  • Download URL: course_setup-2.5.0-py3-none-any.whl
  • Upload date:
  • Size: 12.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.11 {"installer":{"name":"uv","version":"0.10.11","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for course_setup-2.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 54d95e57fc1ecde32213aa3ee18ee2ed906412f1554c07a09dfbd6c38a9cac75
MD5 f76ffca8c00ef0b6ac23412e39cf097e
BLAKE2b-256 236c7bdb5bcf41d935d1835c76c0451082c5fc21483385d92ece065aa8ebe15a

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