Install
openclaw skills install @yujun-bo2/tronclass-cliInteract with the TronClass learning management system (currently optimized for FJU) via the `tronclass` CLI — check courses, assignments, deadlines, grades, announcements, and course materials; download lecture slides or PDFs; submit homework. Use whenever the user asks anything about TronClass, even if they don't say "TronClass" explicitly. Triggers include checking what homework is due, downloading lecture slides or PDFs, submitting assignments, listing enrolled courses, reading school or course announcements, or viewing activity details. If the user mentions school, assignments, due dates, course files, or anything that sounds like an LMS task, lean toward using this skill.
openclaw skills install @yujun-bo2/tronclass-cliYou have access to tronclass-cli, a command-line tool for managing the user's TronClass account.
Install globally (once):
npm install -g tronclass-cli
tronclass auth login <username>. The session is reused automatically; tronclass auth check probes a live TronClass endpoint to confirm whether it's still valid.tronclass auth login --fju <student_id> for the CAS flow with CAPTCHA support.--password <p> (and --base-url <u> for generic deployments) to skip prompts. For FJU, where a human must solve the CAPTCHA, use the two-step deferred flow: tronclass auth login --fju --non-interactive <user> prints a captcha ID and opens the captcha image; then tronclass auth captcha --password <p> <captcha_id> <code> completes the login. The password is never written to disk — it is supplied only at resume time.courses list → activities list <course_id> → activities view <activity_id>. The todo command shows activity IDs directly in the first column.activities → a, courses → c, homework → hw/h, todo → td/t, announcements → ann. Subcommands also have short aliases (list→l/ls, view→v, download→d/dl, submit→s).| Command | What it does |
|---|---|
tronclass auth login [--fju] [--password <p>] [--base-url <u>] <user> | Log in (interactive by default; --password / --base-url make it non-interactive) |
tronclass auth login --fju --non-interactive <user> | Start a deferred-CAPTCHA FJU login; prints a captcha ID, no password on disk |
tronclass auth captcha --password <p> <id> <code> | Complete a deferred FJU login with the solved CAPTCHA |
tronclass auth check | Probe a live endpoint to report session validity (Valid / Expired / Unknown) |
tronclass auth logout | Clear saved session |
tronclass todo | Pending tasks — first column is the activity ID |
tronclass courses list [--all] [--raw] | List courses |
tronclass activities list <course_id> | List activities in a course |
tronclass activities view <activity_id> | Rich view: metadata + description + attachments |
tronclass activities download <ref_id> [output] | Download file (defaults to ~/Downloads/) |
tronclass homework list <course_id> | List homework for a course |
tronclass homework view <activity_id> | Rich view: metadata + prompt + teacher attachments + your own submission/draft |
tronclass homework submit <activity_id> <files...> | Submit homework files |
tronclass ann list [course_id] | List announcements (school-wide if no course_id) |
tronclass ann view <ann_id> [course_id] | Rich view: metadata + HTML-rendered body + attachments |
tronclass ann download <ref_id> [output] | Download an announcement attachment |
Most list/view commands support --fields f1,f2,... to customize displayed columns.
tronclass todo — shows id, course_name, title, end_time by default. The id column is the activity ID you can pass directly to activities view.
tronclass activities view <id> — displays a formatted table (not raw JSON). The Attachments section lists each file with its ref_id and a ready-to-run download command. No need to manually dig through JSON.
tronclass activities download <ref_id> — output_file is optional. If omitted, the file is saved to ~/Downloads/<filename> using the server-provided filename.
tronclass homework view <activity_id> — rich layout: metadata (status / deadline color-coded), HTML-rendered prompt, teacher attachments (each with ref_id for activities download), and a "My Submission" section showing whether you've submitted, saved a draft, or done nothing — plus the files you uploaded. Use this before submitting to read the prompt and confirm a draft.
tronclass ann list — with no argument, lists the school-wide announcement feed (first page, ~30 items). Pass a course_id to list announcements for a specific course.
tronclass ann view <ann_id> — renders the announcement's HTML body in the terminal (bold, links, lists, images). If you know which course the announcement belongs to, pass course_id as the second argument to skip a multi-page search of the global feed.
Check what's due:
tronclass todo
Download a course file:
tronclass courses list # get course_id
tronclass activities list <course_id> # get activity_id
tronclass activities view <activity_id> # see Attachments table → note ref_id
tronclass activities download <ref_id> # saves to ~/Downloads/ automatically
Submit homework:
tronclass homework list <course_id> # find activity_id
tronclass homework view <activity_id> # read the prompt + grab teacher attachments
tronclass homework submit <activity_id> ./my_essay.pdf --draft # save a draft first
tronclass homework view <activity_id> # verify the draft
tronclass homework submit <activity_id> ./my_essay.pdf # final submit
Read announcements:
tronclass ann list # school-wide feed
tronclass ann list <course_id> # course-specific feed
tronclass ann view <ann_id> [course_id] # full content, HTML rendered
For detailed option lists, field names, and edge cases, load the relevant reference:
references/auth.md — login flows, session managementreferences/todo.md — todo fields, filteringreferences/courses.md — course fields, --raw flagreferences/activities.md — activities list/view/download in depthreferences/homework.md — homework list, view, submit options, draft modereferences/announcements.md — announcements list, view (HTML rendering), download