Metadata-Version: 2.4
Name: cheesegrader
Version: 1.1.4
Summary: A collection of grading/quercus tools for University of Toronto instructors.
Author: Jesse Ward-Bond
Author-email: Jesse Ward-Bond <jesse.wardbond@mail.utoronto.ca>
License-Expression: GPL-3.0-or-later
License-File: LICENSE
Requires-Dist: requests>=2.32.5
Requires-Dist: tqdm>=4.67.1
Requires-Dist: typer>=0.20.0
Requires-Python: >=3.13
Project-URL: Homepage, https://github.com/jwardbond/cheesegrader
Project-URL: Issues, https://github.com/jwardbond/cheesegrader/issues
Description-Content-Type: text/markdown

Cheesegrader 🧀
============

Cheesegrader is a CLI tool to streamline grading workflows for Quercus (Canvas). Its main features are


Interacting with quercus programmatically: 
- `downloading` from quercus: student lists and assignment submissions.
- `uploading` to quercus: grades, files (e.g., named rubrics for every student), or both!

Convenient file utils:
- `sorting` named files: Sort files into folders based on who is assigned to grade them, etc.
- `copying`: Copy and rename a file for every student in your course (e.g., a rubric)
- `renaming`: Bulk replace part of a named file with another name. This is useful when you download things manually off quercus and then realize they are name using some internal ID rather than utorid... easy to change!

Following the prompts should be pretty straightforward, but you can press `h` at any time for help, and `q` or `ctrl+c` to quit.


## Table of contents<!-- omit from toc -->
- [Getting Started](#getting-started)
- [Authentication and tokens](#authentication-and-tokens)
- [Course and assignment IDs](#course-and-assignment-ids)
- [Contact](#contact)


## Getting Started
1. `pip install cheesegrader`
2. run `cheesegrader` from the command line
3. Follow the prompts
   

## Authentication and tokens
To use the uploading and downloading scripts, you will need to generate and input an API access token. You can get this:
- By following the instructions [here](https://developerdocs.instructure.com/services/canvas/oauth2/file.oauth#manual-token-generation)... but they were out of date last time I checked.
- Logging in to canvas/quercus and then `account > settings > + New Access Token`
- Navigating to [https://q.utoronto.ca/profile/settings](https://q.utoronto.ca/profile/settings) and clicking `+ New Access Token`


## Course and assignment IDs
- Course and assignment IDs are visible in Quercus URLs:
  - https://q.utoronto.ca/courses/[COURSE_ID]/assignments/[ASSIGNMENT_ID]
- CSVs should have clean headers (no duplicates, no blanks) and UTF-8 encoding.


## Contact
- Submit issues/bugs [here](https://github.com/jwardbond/cheesegrader/issues)
- I'm also happy to answer any questions if you send them to jesse.wardbond at mail.utoronto.ca