Browse the Open Source Society University Computer Science curriculum from the command line.
ossucs is a single pure-Go binary. It reads the OSSU CS curriculum from GitHub
over plain HTTPS, shapes it into clean records, and prints output that pipes into
the rest of your tools. No API key, nothing to run alongside it.
The same package is also a resource-URI driver,
so a host program like ant can address
ossucs as ossucs:// URIs.
go install github.com/tamnd/ossucs-cli/cmd/ossucs@latestOr grab a prebuilt binary from the releases, or run the container image:
docker run --rm ghcr.io/tamnd/ossucs:latest --helpossucs courses # list all ~54 courses in the OSSU CS curriculum
ossucs courses -o json # as JSON, ready for jq
ossucs courses -o csv # as CSV for spreadsheets
ossucs courses --fields section,title # pick columns
ossucs courses -n 10 # first 10 courses
ossucs --help # the whole command treeEvery command shares one output contract: -o table|json|jsonl|csv|tsv|url|raw,
--fields to pick columns, --template for a custom line, and -n to limit.
The default adapts to where output goes (a table on a terminal, JSONL in a
pipe), so the same command reads well by hand and parses cleanly downstream.
The same operations are available over HTTP and as an MCP tool set for agents, with no extra code:
ossucs serve --addr :7777 # GET /v1/courses returns NDJSON
ossucs mcp # speak MCP over stdioossucs registers an ossucs domain the way a program registers a
database driver with database/sql. A host enables it with one blank import:
import _ "github.com/tamnd/ossucs-cli/ossucs"Then ant (or any program that links the package)
dereferences ossucs:// URIs without knowing anything about ossucs:
ant ls ossucs://course # list all coursescmd/ossucs/ thin main: hands cli.NewApp to kit.Run
cli/ assembles the kit App from the ossucs domain
ossucs/ the library: HTTP client, data models, and domain.go (the driver)
docs/ documentation site
make build # ./bin/ossucs
make test # go test ./...
make vet # go vet ./...Push a version tag and GitHub Actions runs GoReleaser, which builds the archives, Linux packages, the multi-arch GHCR image, checksums, SBOMs, and a cosign signature:
git tag v0.1.0
git push --tagsThe Homebrew and Scoop steps self-disable until their tokens exist, so the first release works with no extra secrets.
Apache-2.0. See LICENSE.