Name | edq-canvas JSON |
Version |
0.0.8
JSON |
| download |
home_page | None |
Summary | A suite of tools and Python interface for Instructure's Canvas LMS. |
upload_time | 2024-12-19 00:49:10 |
maintainer | None |
docs_url | None |
author | None |
requires_python | >=3.8 |
license | MIT License Copyright (c) 2023 Eriq Augustine Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
keywords |
education
lms
canvas
api
|
VCS |
|
bugtrack_url |
|
requirements |
json5
platformdirs
requests
|
Travis-CI |
No Travis.
|
coveralls test coverage |
No coveralls.
|
# Canvas Tools
A suite of tools and Python interface for Instructure's Canvas LMS.
This project is not affiliated with Instructure.
Documentation Table of Contents:
- [Installation](#installation)
- [CLI Configuration](#cli-configuration)
- [Usage Notes](#usage-notes)
- [Users](#users)
- [Assignments](#assignments)
- [Groupings and Groups](#groupings-and-groups)
- [Tables](#tables)
- [CLI Tools](#cli-tools)
- [List Course Users](#list-course-users)
- [Fetch a Single User](#fetch-a-single-user)
- [List Assignments](#list-assignments)
- [Fetch a Single Assignment](#fetch-a-single-assignment)
- [Fetch Assignment Scores](#fetch-assignment-scores)
- [Fetch Assignment Submission Files](#fetch-assignment-submission-files)
- [Upload Assignment Scores](#upload-assignment-scores)
- [Upload Single Assignment Score](#upload-single-assignment-score)
- [Fetch Gradebook](#fetch-gradebook)
- [Upload Gradebook](#upload-gradebook)
- [List Groupings](#list-groupings)
- [List Groups](#list-groups)
- [List Membership in a Grouping](#list-membership-in-a-grouping)
- [List Members in a Group](#list-members-in-a-group)
## Installation
The project (tools and API) can be installed from PyPi with:
```
pip install edq-canvas
```
Standard Python requirements are listed in `pyproject.toml`.
The project and Python dependencies can be installed from source with:
```
pip3 install .
```
### CLI Configuration
Before discussing specific tools, you should know some general information about
configuring and sending options to each CLI tool.
To know who you are and what you are working on the package needs a few configuration options:
- `server` -- The Canvas server to connect to.
- `course` -- The Canvas ID for the course you are working with.
- `token` -- Your Canvas API token (see the [Canvas documentation](https://community.canvaslms.com/t5/Admin-Guide/How-do-I-manage-API-access-tokens-as-an-admin/ta-p/89).
- `assignment` -- A query for the current assignment you are working on (does not always apply).
All these options can be set on the command line when invoking on of these tools, e.g.,:
```sh
python3 -m canvas.cli.user.list --server canvas.test.com --course 12345 --token abc123
```
However, it will generally be more convenient to hold these common options in a more reusable location.
There are several other places that config options can be specified,
with each later location overriding any earlier options.
Here are the places options can be specified in the order that they are checked:
1. `./edq-canvas.json` -- If a `edq-canvas.json` exists in the current directory, it is loaded.
2. `<platform-specific user config location>/edq-canvas.json` -- A directory which is considered the "proper" place to store user-related config for the platform you are using (according to [platformdirs](https://github.com/platformdirs/platformdirs)). Use `--help` to see the exact place in your specific case. This is a great place to store login credentials.
3. Files specified by `--config` -- These files are loaded in the order they appear on the command-line.
4. Bare Options -- Options specified directly like `--course` or `--token`. These will override all previous options.
Using the default config file (`edq-canvas.json`):
```sh
# `./edq-canvas.json` will be looked for and loaded if it exists.
python3 -m canvas.cli.user.list
```
Using a custom config file (`my_config.json`):
```sh
# `./my_config.json` will be used.
python3 -m canvas.cli.user.list --config my_config.json
```
A sample config file is provided in this repo at [sample-edq-canvas.json](./sample-edq-canvas.json).
For brevity, all future commands in this document will assume that all standard config options are in the default
config files (and thus will not need to be specified).
## Usage Notes
### Users
When a user is required, tools and API functions accept a "user query" (unless specified).
A user query is any object that can be used to uniquely identify a user.
Valid user queries are:
- Canvas User ID (as an integer or string of digits)
- Email
- Full Name
- "email (id)" where "email" is an email and "id" is a Canvas ID
User queries must be unambiguous within the pool of possible users (e.g., students in a course).
It is recommended to use an email or Canvas ID as a user query.
Resolving a user query that is not a Canvas ID will take longer,
because a list of users must be fetched from Canvas.
### Assignments
When an assignment is required, tools and API functions accept an "assignment query" (unless specified).
An assignment query is any object that can be used to uniquely identify an assignment.
Valid assignment queries are:
- Canvas Assignment ID (as an integer or string of digits)
- Full Name
- "name (id)" where "name" is a full assignment name and "id" is a Canvas ID
Assignment queries must be unambiguous within the pool of possible assignments (e.g., assignments in a course).
Resolving an assignment query that is not a Canvas ID will take longer,
because a list of assignments must be fetched from Canvas.
### Groupings and Groups
A "grouping", also called a "group set" or "group category" in Canvas,
is a set of groups created for a specific purpose (like for a specific assignment).
A grouping has a name and contains groups.
A "group" is a collection of users (usually students).
The hierarchy goes "grouping" -> "group" -> "user".
When a group is required, tools and API functions accept a "group query" (unless specified).
(All information about group queries also applies to grouping queries.)
A group query is any object that can be used to uniquely identify a group.
Valid group queries are:
- Canvas Group ID (as an integer or string of digits)
- Full Name
- "name (id)" where "name" is a full group name and "id" is a Canvas ID
Group queries must be unambiguous within the pool of possible groups (e.g., groups in a course).
### Tables
Most commands that list results can also output results into a tab-separated table (on stdout)
using the `-t` / `--table` option.
To skip the header row, you can use the `--skip-headers` option.
## CLI Tools
All CLI tools can be invoked with `-h` / `--help` to see the full usage and all options.
### List Course Users
Course users can be listed using the `canvas.cli.user.list` tool.
For example:
```
python3 -m canvas.cli.user.list
```
### Fetch a Single User
To fetch information about a single course user, use the `canvas.cli.user.fetch` tool.
For example:
```
python3 -m canvas.cli.user.fetch 12345
# Or
python3 -m canvas.cli.user.fetch alice@uni.edu
```
### List Assignments
Course assignments can be listed using the `canvas.cli.assignment.list` tool.
For example:
```
python3 -m canvas.cli.assignment.list
```
### Fetch a Single Assignment
Fetch information about a single assignment using the `canvas.cli.assignment.fetch` tool.
For example:
```
python3 -m canvas.cli.assignment.fetch 123456
# Or
python3 -m canvas.cli.assignment.fetch 'My Assignment'
```
### Fetch Assignment Scores
To fetch the scores for a specific assignment, use the `canvas.cli.assignment.fetch-scores` tool.
For example:
```
python3 -m canvas.cli.assignment.fetch-scores 123456
# Or
python3 -m canvas.cli.assignment.fetch-scores 'My Assignment'
```
The student's email and score will be written to stdout as a tab-separated row.
### Fetch Assignment Submission Files
To fetch the files students have submitted for an assignment, use the `canvas.cli.assignment.fetch-submission-files` tool.
For example:
```
python3 -m canvas.cli.assignment.fetch-submission-files 123456
# Or
python3 -m canvas.cli.assignment.fetch-submission-files 'My Assignment'
```
Only assignment with a submission type of "Online - Text Entry" or "Online - File Uploads" will be downloaded.
By default, files will be written to the `out` directory.
This can be controlled with the `--out-dir` argument.
### Upload Assignment Scores
Uploading scores for an assignment can be done with the `canvas.cli.assignment.upload-scores` tool:
```
python3 -m canvas.cli.assignment.upload-scores <assignment query> <path>
```
Where `<path>` points to a tab-separated file where each row has 2-3 columns: email, score, and comment (optional).
Each row does not need to have the same length (i.e., some rows can have comments where others do not).
Empty comments are ignored.
The `--skip-rows` argument can be used to skip a specified number of header rows.
For example:
```
python3 -m canvas.cli.assignment.upload-scores 'My Assignment' grades.txt --skip-rows 1
```
Where `grades.txt` looks like:
```
user score comment?
1001 75
alice@uni.edu 100 Great Job!
```
### Upload Single Assignment Score
To upload just one assignment score without a file, you can use the `canvas.cli.assignment.upload-score` tool:
```
python3 -m canvas.cli.assignment.upload-score <assignment query> <user query> <score> [comment]
```
Note that the comment is optional.
For example:
```
python3 -m canvas.cli.assignment.upload-score 'My Assignment' alice@uni.edu 100 'Great Job!'
```
### Fetch Gradebook
To fetch the full gradebook for a course, use the `canvas.cli.gradebook.fetch` tool.
For example:
```
python3 -m canvas.cli.gradebook.fetch
```
A gradebook will be written to stdout as a tab-separated file.
To output the gradebook to a file, you can redirect stdout to a file.
Expect this command to take a few minutes for larger classes.
You can limit to gradebook to only specific students by specifying their IDs on the command line.
Any number of students can be specified.
```
python3 -m canvas.cli.gradebook.fetch 12345 67890
```
By default, assignments and users without submissions will be pruned.
They can be included by using the respective `--include-empty-assignments` and `--include-empty-users` flags.
For example, you can write a gradebook with all assignments and users to `grades.txt` using the following command:
```
python3 -m canvas.cli.gradebook.fetch --include-empty-assignments --include-empty-users > grades.txt
```
To include scores that are computed by Canvas (such as the final score), use the `--include-computed-scores` flag:
```
python3 -m canvas.cli.gradebook.fetch --include-computed-scores
```
### Upload Gradebook
To upload a gradebook, use the `canvas.cli.gradebook.upload` tool:
```
python3 -m canvas.cli.gradebook.upload <path>
```
Where `<path>` points to a gradebook file that has the same format as the output from `canvas.cli.gradebook.fetch`:
a tab-separated file with users down the rows and assignments along the columns.
The first column is user queries where the first cell is ignored,
the first row is assignment queries where the first cell is ignored,
and the remaining cells are the associated scores.
Any number of users and assignments can be specified as long as they exist in the course.
Empty cells will not be uploaded.
A gradebook file can look like:
```
user 98765 Assignment 2
1001 1 2
alice@uni.edu 3
```
### List Groupings
Groups in a course can be listed using the `canvas.cli.group.list-groupings` tool.
For example:
```
python3 -m canvas.cli.group.list-groupings
```
Note that this lists the groupings themselves,
not groups in the groupings or the users in those groups.
### List Groups
To list the groups (not groupings) in a course, use the `canvas.cli.group.list-groups` tool.
For example:
```
python3 -m canvas.cli.group.list-groups
```
To limit the results based on grouping, provide a query for that grouping.
For example:
```
python3 -m canvas.cli.group.list-groups 12345
# Or
python3 -m canvas.cli.group.list-groups 'My Grouping'
```
### List Membership in a Grouping
To list the users inside each group within a grouping, use the `canvas.cli.group.list-grouping-membership` tool.
For example:
```
python3 -m canvas.cli.group.list-grouping-membership 12345
# Or
python3 -m canvas.cli.group.list-grouping-membership 'My Grouping'
```
### List Members in a Group
To list the users inside a specific group (not a grouping), use the `canvas.cli.group.list-group-members` tool.
For example:
```
python3 -m canvas.cli.group.list-group-members 12345
# Or
python3 -m canvas.cli.group.list-group-members 'My Group'
```
Raw data
{
"_id": null,
"home_page": null,
"name": "edq-canvas",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.8",
"maintainer_email": null,
"keywords": "education, lms, canvas, api",
"author": null,
"author_email": "Eriq Augustine <eriq@edulinq.org>",
"download_url": "https://files.pythonhosted.org/packages/cb/4e/03461917d7725419669843f01043aef2b399b2766c3e675fae0a4cd83bbd/edq_canvas-0.0.8.tar.gz",
"platform": null,
"description": "# Canvas Tools\n\nA suite of tools and Python interface for Instructure's Canvas LMS.\n\nThis project is not affiliated with Instructure.\n\nDocumentation Table of Contents:\n - [Installation](#installation)\n - [CLI Configuration](#cli-configuration)\n - [Usage Notes](#usage-notes)\n - [Users](#users)\n - [Assignments](#assignments)\n - [Groupings and Groups](#groupings-and-groups)\n - [Tables](#tables)\n - [CLI Tools](#cli-tools)\n - [List Course Users](#list-course-users)\n - [Fetch a Single User](#fetch-a-single-user)\n - [List Assignments](#list-assignments)\n - [Fetch a Single Assignment](#fetch-a-single-assignment)\n - [Fetch Assignment Scores](#fetch-assignment-scores)\n - [Fetch Assignment Submission Files](#fetch-assignment-submission-files)\n - [Upload Assignment Scores](#upload-assignment-scores)\n - [Upload Single Assignment Score](#upload-single-assignment-score)\n - [Fetch Gradebook](#fetch-gradebook)\n - [Upload Gradebook](#upload-gradebook)\n - [List Groupings](#list-groupings)\n - [List Groups](#list-groups)\n - [List Membership in a Grouping](#list-membership-in-a-grouping)\n - [List Members in a Group](#list-members-in-a-group)\n\n## Installation\n\nThe project (tools and API) can be installed from PyPi with:\n```\npip install edq-canvas\n```\n\nStandard Python requirements are listed in `pyproject.toml`.\nThe project and Python dependencies can be installed from source with:\n```\npip3 install .\n```\n\n### CLI Configuration\n\nBefore discussing specific tools, you should know some general information about\nconfiguring and sending options to each CLI tool.\n\nTo know who you are and what you are working on the package needs a few configuration options:\n - `server` -- The Canvas server to connect to.\n - `course` -- The Canvas ID for the course you are working with.\n - `token` -- Your Canvas API token (see the [Canvas documentation](https://community.canvaslms.com/t5/Admin-Guide/How-do-I-manage-API-access-tokens-as-an-admin/ta-p/89).\n - `assignment` -- A query for the current assignment you are working on (does not always apply).\n\nAll these options can be set on the command line when invoking on of these tools, e.g.,:\n```sh\npython3 -m canvas.cli.user.list --server canvas.test.com --course 12345 --token abc123\n```\nHowever, it will generally be more convenient to hold these common options in a more reusable location.\n\nThere are several other places that config options can be specified,\nwith each later location overriding any earlier options.\nHere are the places options can be specified in the order that they are checked:\n 1. `./edq-canvas.json` -- If a `edq-canvas.json` exists in the current directory, it is loaded.\n 2. `<platform-specific user config location>/edq-canvas.json` -- A directory which is considered the \"proper\" place to store user-related config for the platform you are using (according to [platformdirs](https://github.com/platformdirs/platformdirs)). Use `--help` to see the exact place in your specific case. This is a great place to store login credentials.\n 3. Files specified by `--config` -- These files are loaded in the order they appear on the command-line.\n 4. Bare Options -- Options specified directly like `--course` or `--token`. These will override all previous options.\n\nUsing the default config file (`edq-canvas.json`):\n```sh\n# `./edq-canvas.json` will be looked for and loaded if it exists.\npython3 -m canvas.cli.user.list\n```\n\nUsing a custom config file (`my_config.json`):\n```sh\n# `./my_config.json` will be used.\npython3 -m canvas.cli.user.list --config my_config.json\n```\n\nA sample config file is provided in this repo at [sample-edq-canvas.json](./sample-edq-canvas.json).\n\nFor brevity, all future commands in this document will assume that all standard config options are in the default\nconfig files (and thus will not need to be specified).\n\n## Usage Notes\n\n### Users\n\nWhen a user is required, tools and API functions accept a \"user query\" (unless specified).\nA user query is any object that can be used to uniquely identify a user.\nValid user queries are:\n - Canvas User ID (as an integer or string of digits)\n - Email\n - Full Name\n - \"email (id)\" where \"email\" is an email and \"id\" is a Canvas ID\n\nUser queries must be unambiguous within the pool of possible users (e.g., students in a course).\nIt is recommended to use an email or Canvas ID as a user query.\nResolving a user query that is not a Canvas ID will take longer,\nbecause a list of users must be fetched from Canvas.\n\n### Assignments\n\nWhen an assignment is required, tools and API functions accept an \"assignment query\" (unless specified).\nAn assignment query is any object that can be used to uniquely identify an assignment.\nValid assignment queries are:\n - Canvas Assignment ID (as an integer or string of digits)\n - Full Name\n - \"name (id)\" where \"name\" is a full assignment name and \"id\" is a Canvas ID\n\nAssignment queries must be unambiguous within the pool of possible assignments (e.g., assignments in a course).\nResolving an assignment query that is not a Canvas ID will take longer,\nbecause a list of assignments must be fetched from Canvas.\n\n### Groupings and Groups\n\nA \"grouping\", also called a \"group set\" or \"group category\" in Canvas,\nis a set of groups created for a specific purpose (like for a specific assignment).\nA grouping has a name and contains groups.\nA \"group\" is a collection of users (usually students).\nThe hierarchy goes \"grouping\" -> \"group\" -> \"user\".\n\nWhen a group is required, tools and API functions accept a \"group query\" (unless specified).\n(All information about group queries also applies to grouping queries.)\nA group query is any object that can be used to uniquely identify a group.\nValid group queries are:\n - Canvas Group ID (as an integer or string of digits)\n - Full Name\n - \"name (id)\" where \"name\" is a full group name and \"id\" is a Canvas ID\n\nGroup queries must be unambiguous within the pool of possible groups (e.g., groups in a course).\n\n### Tables\n\nMost commands that list results can also output results into a tab-separated table (on stdout)\nusing the `-t` / `--table` option.\nTo skip the header row, you can use the `--skip-headers` option.\n\n## CLI Tools\n\nAll CLI tools can be invoked with `-h` / `--help` to see the full usage and all options.\n\n### List Course Users\n\nCourse users can be listed using the `canvas.cli.user.list` tool.\nFor example:\n```\npython3 -m canvas.cli.user.list\n```\n\n### Fetch a Single User\n\nTo fetch information about a single course user, use the `canvas.cli.user.fetch` tool.\nFor example:\n```\npython3 -m canvas.cli.user.fetch 12345\n\n# Or\npython3 -m canvas.cli.user.fetch alice@uni.edu\n```\n\n### List Assignments\n\nCourse assignments can be listed using the `canvas.cli.assignment.list` tool.\nFor example:\n```\npython3 -m canvas.cli.assignment.list\n```\n\n### Fetch a Single Assignment\n\nFetch information about a single assignment using the `canvas.cli.assignment.fetch` tool.\nFor example:\n```\npython3 -m canvas.cli.assignment.fetch 123456\n\n# Or\npython3 -m canvas.cli.assignment.fetch 'My Assignment'\n```\n\n### Fetch Assignment Scores\n\nTo fetch the scores for a specific assignment, use the `canvas.cli.assignment.fetch-scores` tool.\nFor example:\n```\npython3 -m canvas.cli.assignment.fetch-scores 123456\n\n# Or\npython3 -m canvas.cli.assignment.fetch-scores 'My Assignment'\n```\n\nThe student's email and score will be written to stdout as a tab-separated row.\n\n### Fetch Assignment Submission Files\n\nTo fetch the files students have submitted for an assignment, use the `canvas.cli.assignment.fetch-submission-files` tool.\nFor example:\n```\npython3 -m canvas.cli.assignment.fetch-submission-files 123456\n\n# Or\npython3 -m canvas.cli.assignment.fetch-submission-files 'My Assignment'\n```\n\nOnly assignment with a submission type of \"Online - Text Entry\" or \"Online - File Uploads\" will be downloaded.\n\nBy default, files will be written to the `out` directory.\nThis can be controlled with the `--out-dir` argument.\n\n### Upload Assignment Scores\n\nUploading scores for an assignment can be done with the `canvas.cli.assignment.upload-scores` tool:\n```\npython3 -m canvas.cli.assignment.upload-scores <assignment query> <path>\n```\n\nWhere `<path>` points to a tab-separated file where each row has 2-3 columns: email, score, and comment (optional).\nEach row does not need to have the same length (i.e., some rows can have comments where others do not).\nEmpty comments are ignored.\n\nThe `--skip-rows` argument can be used to skip a specified number of header rows.\nFor example:\n```\npython3 -m canvas.cli.assignment.upload-scores 'My Assignment' grades.txt --skip-rows 1\n```\n\nWhere `grades.txt` looks like:\n```\nuser\tscore\tcomment?\n1001\t75\nalice@uni.edu\t100\tGreat Job!\n```\n\n### Upload Single Assignment Score\n\nTo upload just one assignment score without a file, you can use the `canvas.cli.assignment.upload-score` tool:\n```\npython3 -m canvas.cli.assignment.upload-score <assignment query> <user query> <score> [comment]\n```\n\nNote that the comment is optional.\n\nFor example:\n```\npython3 -m canvas.cli.assignment.upload-score 'My Assignment' alice@uni.edu 100 'Great Job!'\n```\n\n### Fetch Gradebook\n\nTo fetch the full gradebook for a course, use the `canvas.cli.gradebook.fetch` tool.\nFor example:\n```\npython3 -m canvas.cli.gradebook.fetch\n```\n\nA gradebook will be written to stdout as a tab-separated file.\nTo output the gradebook to a file, you can redirect stdout to a file.\nExpect this command to take a few minutes for larger classes.\n\nYou can limit to gradebook to only specific students by specifying their IDs on the command line.\nAny number of students can be specified.\n```\npython3 -m canvas.cli.gradebook.fetch 12345 67890\n```\n\nBy default, assignments and users without submissions will be pruned.\nThey can be included by using the respective `--include-empty-assignments` and `--include-empty-users` flags.\n\nFor example, you can write a gradebook with all assignments and users to `grades.txt` using the following command:\n```\npython3 -m canvas.cli.gradebook.fetch --include-empty-assignments --include-empty-users > grades.txt\n```\n\nTo include scores that are computed by Canvas (such as the final score), use the `--include-computed-scores` flag:\n```\npython3 -m canvas.cli.gradebook.fetch --include-computed-scores\n```\n\n### Upload Gradebook\n\nTo upload a gradebook, use the `canvas.cli.gradebook.upload` tool:\n```\npython3 -m canvas.cli.gradebook.upload <path>\n```\n\nWhere `<path>` points to a gradebook file that has the same format as the output from `canvas.cli.gradebook.fetch`:\na tab-separated file with users down the rows and assignments along the columns.\nThe first column is user queries where the first cell is ignored,\nthe first row is assignment queries where the first cell is ignored,\nand the remaining cells are the associated scores.\nAny number of users and assignments can be specified as long as they exist in the course.\nEmpty cells will not be uploaded.\n\nA gradebook file can look like:\n```\nuser\t98765\tAssignment 2\n1001\t1\t2\nalice@uni.edu\t3\t\n```\n\n### List Groupings\n\nGroups in a course can be listed using the `canvas.cli.group.list-groupings` tool.\nFor example:\n```\npython3 -m canvas.cli.group.list-groupings\n```\n\nNote that this lists the groupings themselves,\nnot groups in the groupings or the users in those groups.\n\n### List Groups\n\nTo list the groups (not groupings) in a course, use the `canvas.cli.group.list-groups` tool.\nFor example:\n```\npython3 -m canvas.cli.group.list-groups\n```\n\nTo limit the results based on grouping, provide a query for that grouping.\nFor example:\n```\npython3 -m canvas.cli.group.list-groups 12345\n\n# Or\npython3 -m canvas.cli.group.list-groups 'My Grouping'\n```\n\n### List Membership in a Grouping\n\nTo list the users inside each group within a grouping, use the `canvas.cli.group.list-grouping-membership` tool.\nFor example:\n```\npython3 -m canvas.cli.group.list-grouping-membership 12345\n\n# Or\npython3 -m canvas.cli.group.list-grouping-membership 'My Grouping'\n```\n\n### List Members in a Group\n\nTo list the users inside a specific group (not a grouping), use the `canvas.cli.group.list-group-members` tool.\nFor example:\n```\npython3 -m canvas.cli.group.list-group-members 12345\n\n# Or\npython3 -m canvas.cli.group.list-group-members 'My Group'\n```\n",
"bugtrack_url": null,
"license": "MIT License Copyright (c) 2023 Eriq Augustine Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the \"Software\"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. ",
"summary": "A suite of tools and Python interface for Instructure's Canvas LMS.",
"version": "0.0.8",
"project_urls": {
"Homepage": "https://github.com/edulinq/py-canvas",
"Repository": "https://github.com/edulinq/py-canvas"
},
"split_keywords": [
"education",
" lms",
" canvas",
" api"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "c4b50877159d925b0351b64a7fc0f1d7ae86fda54f7c1d212ae3d84e197eff69",
"md5": "1b086f0c319460fdc31df95a65384f3f",
"sha256": "cf2d279e0069604844afd519cee41bdfdbcc7cc87ebb7502bcc23be0e78939eb"
},
"downloads": -1,
"filename": "edq_canvas-0.0.8-py3-none-any.whl",
"has_sig": false,
"md5_digest": "1b086f0c319460fdc31df95a65384f3f",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": ">=3.8",
"size": 46033,
"upload_time": "2024-12-19T00:49:08",
"upload_time_iso_8601": "2024-12-19T00:49:08.601710Z",
"url": "https://files.pythonhosted.org/packages/c4/b5/0877159d925b0351b64a7fc0f1d7ae86fda54f7c1d212ae3d84e197eff69/edq_canvas-0.0.8-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "cb4e03461917d7725419669843f01043aef2b399b2766c3e675fae0a4cd83bbd",
"md5": "21e86b61cb3a519680f0aa50c6bae2e7",
"sha256": "d0c25a413dc1480e8902f86cd090532689c1ba3d0682eaa8caf69cb3f5a3606f"
},
"downloads": -1,
"filename": "edq_canvas-0.0.8.tar.gz",
"has_sig": false,
"md5_digest": "21e86b61cb3a519680f0aa50c6bae2e7",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.8",
"size": 29109,
"upload_time": "2024-12-19T00:49:10",
"upload_time_iso_8601": "2024-12-19T00:49:10.773922Z",
"url": "https://files.pythonhosted.org/packages/cb/4e/03461917d7725419669843f01043aef2b399b2766c3e675fae0a4cd83bbd/edq_canvas-0.0.8.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-12-19 00:49:10",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "edulinq",
"github_project": "py-canvas",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"requirements": [
{
"name": "json5",
"specs": [
[
">=",
"0.9.14"
]
]
},
{
"name": "platformdirs",
"specs": [
[
">=",
"3.10.0"
]
]
},
{
"name": "requests",
"specs": [
[
">=",
"2.31.0"
]
]
}
],
"lcname": "edq-canvas"
}