We have relocated to Instructure Developer Documentation Portal. đ Please update your bookmarks. This page will automatically redirect after July 1, 2026.
Courses API
API for accessing course information.
A Term object looks like:
{
  "id": 1,
  "name": "Default Term",
  "start_at": "2012-06-01T00:00:00-06:00",
  "end_at": null
}A CourseProgress object looks like:
{
  // total number of requirements from all modules
  "requirement_count": 10,
  // total number of requirements the user has completed from all modules
  "requirement_completed_count": 1,
  // url to next module item that has an unmet requirement. null if the user has
  // completed the course or the current module does not require sequential
  // progress
  "next_requirement_url": "http://localhost/courses/1/modules/items/2",
  // date the course was completed. null if the course has not been completed by
  // this user
  "completed_at": "2013-06-01T00:00:00-06:00"
}A Course object looks like:
{
  // the unique identifier for the course
  "id": 370663,
  // the SIS identifier for the course, if defined. This field is only included if
  // the user has permission to view SIS information.
  "sis_course_id": null,
  // the UUID of the course
  "uuid": "WvAHhY5FINzq5IyRIJybGeiXyFkG3SqHUPb7jZY5",
  // the integration identifier for the course, if defined. This field is only
  // included if the user has permission to view SIS information.
  "integration_id": null,
  // the unique identifier for the SIS import. This field is only included if the
  // user has permission to manage SIS information.
  "sis_import_id": 34,
  // the full name of the course. If the requesting user has set a nickname for
  // the course, the nickname will be shown here.
  "name": "InstructureCon 2012",
  // the course code
  "course_code": "INSTCON12",
  // the actual course name. This field is returned only if the requesting user
  // has set a nickname for the course.
  "original_name": "InstructureCon-2012-01",
  // the current state of the course, also known as âstatusâ.  The value will be
  // one of the following values: 'unpublished', 'available', 'completed', or
  // 'deleted'.  NOTE: When fetching a singular course that has a 'deleted'
  // workflow state value, an error will be returned with a message of 'The
  // specified resource does not exist.'
  "workflow_state": "available",
  // the account associated with the course
  "account_id": 81259,
  // the root account associated with the course
  "root_account_id": 81259,
  // the enrollment term associated with the course
  "enrollment_term_id": 34,
  // A list of grading periods associated with the course
  "grading_periods": null,
  // the grading standard associated with the course
  "grading_standard_id": 25,
  // the grade_passback_setting set on the course
  "grade_passback_setting": "nightly_sync",
  // the date the course was created.
  "created_at": "2012-05-01T00:00:00-06:00",
  // the start date for the course, if applicable
  "start_at": "2012-06-01T00:00:00-06:00",
  // the end date for the course, if applicable
  "end_at": "2012-09-01T00:00:00-06:00",
  // the course-set locale, if applicable
  "locale": "en",
  // A list of enrollments linking the current user to the course. for student
  // enrollments, grading information may be included if include[]=total_scores
  "enrollments": null,
  // optional: the total number of active and invited students in the course
  "total_students": 32,
  // course calendar
  "calendar": null,
  // the type of page that users will see when they first visit the course -
  // 'feed': Recent Activity Dashboard - 'wiki': Wiki Front Page - 'modules':
  // Course Modules/Sections Page - 'assignments': Course Assignments List -
  // 'syllabus': Course Syllabus Page other types may be added in the future
  "default_view": "feed",
  // optional: user-generated HTML for the course syllabus
  "syllabus_body": "<p>syllabus html goes here</p>",
  // optional: the number of submissions needing grading returned only if the
  // current user has grading rights and include[]=needs_grading_count
  "needs_grading_count": 17,
  // optional: the enrollment term object for the course returned only if
  // include[]=term
  "term": null,
  // optional: information on progress through the course returned only if
  // include[]=course_progress
  "course_progress": null,
  // weight final grade based on assignment group percentages
  "apply_assignment_group_weights": true,
  // optional: the permissions the user has for the course. returned only for a
  // single course and include[]=permissions
  "permissions": {"create_discussion_topic":true,"create_announcement":true},
  "is_public": true,
  "is_public_to_auth_users": true,
  "public_syllabus": true,
  "public_syllabus_to_auth": true,
  // optional: the public description of the course
  "public_description": "Come one, come all to InstructureCon 2012!",
  "storage_quota_mb": 5,
  "storage_quota_used_mb": 5,
  "hide_final_grades": false,
  "license": "Creative Commons",
  "allow_student_assignment_edits": false,
  "allow_wiki_comments": false,
  "allow_student_forum_attachments": false,
  "open_enrollment": true,
  "self_enrollment": false,
  "restrict_enrollments_to_course_dates": false,
  "course_format": "online",
  // optional: this will be true if this user is currently prevented from viewing
  // the course because of date restriction settings
  "access_restricted_by_date": false,
  // The course's IANA time zone name.
  "time_zone": "America/Denver",
  // optional: whether the course is set as a Blueprint Course (blueprint fields
  // require the Blueprint Courses feature)
  "blueprint": true,
  // optional: Set of restrictions applied to all locked course objects
  "blueprint_restrictions": {"content":true,"points":true,"due_dates":false,"availability_dates":false},
  // optional: Sets of restrictions differentiated by object type applied to
  // locked course objects
  "blueprint_restrictions_by_object_type": {"assignment":{"content":true,"points":true},"wiki_page":{"content":true}},
  // optional: whether the course is set as a template (requires the Course
  // Templates feature)
  "template": true
}A CalendarLink object looks like:
{
  // The URL of the calendar in ICS format
  "ics": "https://canvas.instructure.com/feeds/calendars/course_abcdef.ics"
}List your courses CoursesController#index
GET /api/v1/courses
url:GET|/api/v1/courses
  Returns the paginated list of active courses for the current user.
Request Parameters:
| Parameter | Type | Description | |
|---|---|---|---|
| enrollment_type | string | When set, only return courses where the user is enrolled as this type. For example, set to âteacherâ to return only courses where the user is enrolled as a Teacher. This argument is ignored if enrollment_role is given. 
          Allowed values:  | |
| enrollment_role | string | Deprecated When set, only return courses where the user is enrolled with the specified course-level role. This can be a role created with the Add Role API or a base role type of âStudentEnrollmentâ, âTeacherEnrollmentâ, âTaEnrollmentâ, âObserverEnrollmentâ, or âDesignerEnrollmentâ. | |
| enrollment_role_id | integer | When set, only return courses where the user is enrolled with the specified course-level role. This can be a role created with the Add Role API or a built_in role type of âStudentEnrollmentâ, âTeacherEnrollmentâ, âTaEnrollmentâ, âObserverEnrollmentâ, or âDesignerEnrollmentâ. | |
| enrollment_state | string | When set, only return courses where the user has an enrollment with the given state. This will respect section/course/term date overrides. 
          Allowed values:  | |
| exclude_blueprint_courses | boolean | When set, only return courses that are not configured as blueprint courses. | |
| include[] | string | 
 
          Allowed values:  | |
| state[] | string | If set, only return courses that are in the given state(s). By default, âavailableâ is returned for students and observers, and anything except âdeletedâ, for all other enrollment types 
          Allowed values:  | 
List courses for a user CoursesController#user_index
GET /api/v1/users/:user_id/courses
url:GET|/api/v1/users/:user_id/courses
  Returns a paginated list of active courses for this user. To view the course list for a user other than yourself, you must be either an observer of that user or an administrator.
Request Parameters:
| Parameter | Type | Description | |
|---|---|---|---|
| include[] | string | 
 
          Allowed values:  | |
| state[] | string | If set, only return courses that are in the given state(s). By default, âavailableâ is returned for students and observers, and anything except âdeletedâ, for all other enrollment types 
          Allowed values:  | |
| enrollment_state | string | When set, only return courses where the user has an enrollment with the given state. This will respect section/course/term date overrides. 
          Allowed values:  | |
| homeroom | boolean | If set, only return homeroom courses. | |
| account_id | string | If set, only include courses associated with this account | 
Get user progress CoursesController#user_progress
GET /api/v1/courses/:course_id/users/:user_id/progress
url:GET|/api/v1/courses/:course_id/users/:user_id/progress
  Return progress information for the user and course
You can supply self as the user_id to query your own progress in a course. To query another userâs progress, you must be a teacher in the course, an administrator, or a linked observer of the user.
Create a new course CoursesController#create
POST /api/v1/accounts/:account_id/courses
url:POST|/api/v1/accounts/:account_id/courses
  Create a new course
Request Parameters:
| Parameter | Type | Description | |
|---|---|---|---|
| course[name] | string | The name of the course. If omitted, the course will be named âUnnamed Course.â | |
| course[course_code] | string | The course code for the course. | |
| course[start_at] | DateTime | Course start date in ISO8601 format, e.g. 2011-01-01T01:00Z This value is ignored unless ârestrict_enrollments_to_course_datesâ is set to true. | |
| course[end_at] | DateTime | Course end date in ISO8601 format. e.g. 2011-01-01T01:00Z This value is ignored unless ârestrict_enrollments_to_course_datesâ is set to true. | |
| course[license] | string | The name of the licensing. Should be one of the following abbreviations (a descriptive name is included in parenthesis for reference): 
 | |
| course[is_public] | boolean | Set to true if course is public to both authenticated and unauthenticated users. | |
| course[is_public_to_auth_users] | boolean | Set to true if course is public only to authenticated users. | |
| course[public_syllabus] | boolean | Set to true to make the course syllabus public. | |
| course[public_syllabus_to_auth] | boolean | Set to true to make the course syllabus public for authenticated users. | |
| course[public_description] | string | A publicly visible description of the course. | |
| course[allow_student_wiki_edits] | boolean | If true, students will be able to modify the course wiki. | |
| course[allow_wiki_comments] | boolean | If true, course members will be able to comment on wiki pages. | |
| course[allow_student_forum_attachments] | boolean | If true, students can attach files to forum posts. | |
| course[open_enrollment] | boolean | Set to true if the course is open enrollment. | |
| course[self_enrollment] | boolean | Set to true if the course is self enrollment. | |
| course[restrict_enrollments_to_course_dates] | boolean | Set to true to restrict user enrollments to the start and end dates of the course. This value must be set to true in order to specify a course start date and/or end date. | |
| course[term_id] | string | The unique ID of the term to create to course in. | |
| course[sis_course_id] | string | The unique SIS identifier. | |
| course[integration_id] | string | The unique Integration identifier. | |
| course[hide_final_grades] | boolean | If this option is set to true, the totals in student grades summary will be hidden. | |
| course[apply_assignment_group_weights] | boolean | Set to true to weight final grade based on assignment groups percentages. | |
| course[time_zone] | string | The time zone for the course. Allowed time zones are IANA time zones or friendlier Ruby on Rails time zones. | |
| offer | boolean | If this option is set to true, the course will be available to students immediately. | |
| enroll_me | boolean | Set to true to enroll the current user as the teacher. | |
| skip_course_template | boolean | If this option is set to true, the template of the account will not be applied to this course It means copy_from_course_template will not be executed. This option is thought for a course copy. | |
| course[default_view] | string | The type of page that users will see when they first visit the course 
 other types may be added in the future 
          Allowed values:  | |
| course[syllabus_body] | string | The syllabus body for the course | |
| course[grading_standard_id] | integer | The grading standard id to set for the course. If no value is provided for this argument the current grading_standard will be un-set from this course. | |
| course[grade_passback_setting] | string | Optional. The grade_passback_setting for the course. Only ânightly_syncâ, âdisabledâ, and â are allowed | |
| course[course_format] | string | Optional. Specifies the format of the course. (Should be âon_campusâ, âonlineâ, or âblendedâ) | |
| course[post_manually] | boolean | Default is false. When true, all grades in the course must be posted manually, and will not be automatically posted. When false, all grades in the course will be automatically posted. | |
| enable_sis_reactivation | boolean | When true, will first try to re-activate a deleted course with matching sis_course_id if possible. | 
Upload a file CoursesController#create_file
POST /api/v1/courses/:course_id/files
url:POST|/api/v1/courses/:course_id/files
  Upload a file to the course.
This API endpoint is the first step in uploading a file to a course. See the File Upload Documentation for details on the file upload workflow.
Only those with the âManage Filesâ permission on a course can upload files to the course. By default, this is Teachers, TAs and Designers.
List students CoursesController#students
GET /api/v1/courses/:course_id/students
url:GET|/api/v1/courses/:course_id/students
  Returns the paginated list of students enrolled in this course.
DEPRECATED: Please use the course users endpoint and pass âstudentâ as the enrollment_type.
Returns a list of User objectsList users in course CoursesController#users
GET /api/v1/courses/:course_id/users
url:GET|/api/v1/courses/:course_id/users
  GET /api/v1/courses/:course_id/search_users
url:GET|/api/v1/courses/:course_id/search_users
  Returns the paginated list of users in this course. And optionally the userâs enrollments in the course.
Request Parameters:
| Parameter | Type | Description | |
|---|---|---|---|
| search_term | string | The partial name or full ID of the users to match and return in the results list. | |
| sort | string | When set, sort the results of the search based on the given field. 
          Allowed values:  | |
| enrollment_type[] | string | When set, only return users where the user is enrolled as this type. âstudent_viewâ implies include[]=test_student. This argument is ignored if enrollment_role is given. 
          Allowed values:  | |
| enrollment_role | string | Deprecated When set, only return users enrolled with the specified course-level role. This can be a role created with the Add Role API or a base role type of âStudentEnrollmentâ, âTeacherEnrollmentâ, âTaEnrollmentâ, âObserverEnrollmentâ, or âDesignerEnrollmentâ. | |
| enrollment_role_id | integer | When set, only return courses where the user is enrolled with the specified course-level role. This can be a role created with the Add Role API or a built_in role id with type âStudentEnrollmentâ, âTeacherEnrollmentâ, âTaEnrollmentâ, âObserverEnrollmentâ, or âDesignerEnrollmentâ. | |
| include[] | string | 
 Optionally include with each Course the userâs current and invited enrollments. If the user is enrolled as a student, and the account has permission to manage or view all grades, each enrollment will include a âgradesâ key with âcurrent_scoreâ, âfinal_scoreâ, âcurrent_gradeâ and âfinal_gradeâ values. 
 if present. Default is to not include Test Student. 
 such as analytics information 
 well as this directive, the scores returned in the enrollment will be for the current grading period if there is one. A âgrading_period_idâ value will also be included with the scores. if grading_period_id is nil there is no current grading period and the score is a total score. 
 
          Allowed values:  | |
| user_id | string | If this parameter is given and it corresponds to a user in the course, the  | |
| user_ids[] | integer | If included, the course users set will only include users with IDs specified by the param. Note: this will not work in conjunction with the âuser_idâ argument but multiple user_ids can be included. | |
| enrollment_state[] | string | When set, only return users where the enrollment workflow state is of one of the given types. âactiveâ and âinvitedâ enrollments are returned by default. 
          Allowed values:  | 
List recently logged in students CoursesController#recent_students
GET /api/v1/courses/:course_id/recent_students
url:GET|/api/v1/courses/:course_id/recent_students
  Returns the paginated list of users in this course, ordered by how recently they have logged in. The records include the âlast_loginâ field which contains a timestamp of the last time that user logged into canvas. The querying user must have the âView usage reportsâ permission.
Example Request:
curl -H 'Authorization: Bearer <token>' \
     https://<canvas>/api/v1/courses/<course_id>/recent_usersGet single user CoursesController#user
GET /api/v1/courses/:course_id/users/:id
url:GET|/api/v1/courses/:course_id/users/:id
  Return information on a single user.
Accepts the same include[] parameters as the :users: action, and returns a single user with the same fields as that action.
Returns an User objectSearch for content share users CoursesController#content_share_users
GET /api/v1/courses/:course_id/content_share_users
url:GET|/api/v1/courses/:course_id/content_share_users
  Returns a paginated list of users you can share content with. Requires the content share feature and the user must have the manage content permission for the course.
Request Parameters:
| Parameter | Type | Description | |
|---|---|---|---|
| search_term | Required | string | Term used to find users. Will search available share users with the search term in their name. | 
Example Request:
curl -H 'Authorization: Bearer <token>' \
     https://<canvas>/api/v1/courses/<course_id>/content_share_users \
     -d 'search_term=smith'Preview processed html CoursesController#preview_html
POST /api/v1/courses/:course_id/preview_html
url:POST|/api/v1/courses/:course_id/preview_html
  Preview html content processed for this course
Request Parameters:
| Parameter | Type | Description | |
|---|---|---|---|
| html | string | The html content to process | 
Example Request:
curl https://<canvas>/api/v1/courses/<course_id>/preview_html \
     -F 'html=<p><badhtml></badhtml>processed html</p>' \
     -H 'Authorization: Bearer <token>'Example Response:
{
  "html": "<p>processed html</p>"
}Course activity stream CoursesController#activity_stream
GET /api/v1/courses/:course_id/activity_stream
url:GET|/api/v1/courses/:course_id/activity_stream
  Returns the current userâs course-specific activity stream, paginated.
For full documentation, see the API documentation for the user activity stream, in the user api.
Course activity stream summary CoursesController#activity_stream_summary
GET /api/v1/courses/:course_id/activity_stream/summary
url:GET|/api/v1/courses/:course_id/activity_stream/summary
  Returns a summary of the current userâs course-specific activity stream.
For full documentation, see the API documentation for the user activity stream summary, in the user api.
Course TODO items CoursesController#todo_items
GET /api/v1/courses/:course_id/todo
url:GET|/api/v1/courses/:course_id/todo
  Returns the current userâs course-specific todo items.
For full documentation, see the API documentation for the user todo items, in the user api.
Delete/Conclude a course CoursesController#destroy
DELETE /api/v1/courses/:id
url:DELETE|/api/v1/courses/:id
  Delete or conclude an existing course
Request Parameters:
| Parameter | Type | Description | |
|---|---|---|---|
| event | Required | string | The action to take on the course. 
          Allowed values:  | 
Example Response:
{ "delete": "true" }Get course settings CoursesController#api_settings
GET /api/v1/courses/:course_id/settings
url:GET|/api/v1/courses/:course_id/settings
  Returns some of a courseâs settings.
Example Request:
curl https://<canvas>/api/v1/courses/<course_id>/settings \
  -X GET \
  -H 'Authorization: Bearer <token>'Example Response:
{
  "allow_student_discussion_topics": true,
  "allow_student_forum_attachments": false,
  "allow_student_discussion_editing": true,
  "grading_standard_enabled": true,
  "grading_standard_id": 137,
  "allow_student_organized_groups": true,
  "hide_final_grades": false,
  "hide_distribution_graphs": false,
  "hide_sections_on_course_users_page": false,
  "lock_all_announcements": true,
  "usage_rights_required": false,
  "homeroom_course": false,
  "default_due_time": "23:59:59",
  "conditional_release": false
}Update course settings CoursesController#update_settings
PUT /api/v1/courses/:course_id/settings
url:PUT|/api/v1/courses/:course_id/settings
  Can update the following course settings:
Request Parameters:
| Parameter | Type | Description | |
|---|---|---|---|
| allow_final_grade_override | boolean | Let student final grades for a grading period or the total grades for the course be overridden | |
| allow_student_discussion_topics | boolean | Let students create discussion topics | |
| allow_student_forum_attachments | boolean | Let students attach files to discussions | |
| allow_student_discussion_editing | boolean | Let students edit or delete their own discussion replies | |
| allow_student_organized_groups | boolean | Let students organize their own groups | |
| allow_student_discussion_reporting | boolean | Let students report offensive discussion content | |
| allow_student_anonymous_discussion_topics | boolean | Let students create anonymous discussion topics | |
| filter_speed_grader_by_student_group | boolean | Filter SpeedGrader to only the selected student group | |
| hide_final_grades | boolean | Hide totals in student grades summary | |
| hide_distribution_graphs | boolean | Hide grade distribution graphs from students | |
| hide_sections_on_course_users_page | boolean | Disallow students from viewing students in sections they do not belong to | |
| lock_all_announcements | boolean | Disable comments on announcements | |
| usage_rights_required | boolean | Copyright and license information must be provided for files before they are published. | |
| restrict_student_past_view | boolean | Restrict students from viewing courses after end date | |
| restrict_student_future_view | boolean | Restrict students from viewing courses before start date | |
| show_announcements_on_home_page | boolean | Show the most recent announcements on the Course home page (if a Wiki, defaults to five announcements, configurable via home_page_announcement_limit). Canvas for Elementary subjects ignore this setting. | |
| home_page_announcement_limit | integer | Limit the number of announcements on the home page if enabled via show_announcements_on_home_page | |
| syllabus_course_summary | boolean | Show the course summary (list of assignments and calendar events) on the syllabus page. Default is true. | |
| default_due_time | string | Set the default due time for assignments. This is the time that will be pre-selected in the Canvas user interface when setting a due date for an assignment. It does not change when any existing assignment is due. It should be given in 24-hour HH:MM:SS format. The default is â23:59:59â. Use âinheritâ to inherit the account setting. | |
| conditional_release | boolean | Enable or disable individual learning paths for students based on assessment | 
Example Request:
curl https://<canvas>/api/v1/courses/<course_id>/settings \
  -X PUT \
  -H 'Authorization: Bearer <token>' \
  -d 'allow_student_discussion_topics=false'Return test student for course CoursesController#student_view_student
GET /api/v1/courses/:course_id/student_view_student
url:GET|/api/v1/courses/:course_id/student_view_student
  Returns information for a test student in this course. Creates a test student if one does not already exist for the course. The caller must have permission to access the courseâs student view.
Example Request:
curl https://<canvas>/api/v1/courses/<course_id>/student_view_student \
  -X GET \
  -H 'Authorization: Bearer <token>'Get a single course CoursesController#show
GET /api/v1/courses/:id
url:GET|/api/v1/courses/:id
  GET /api/v1/accounts/:account_id/courses/:id
url:GET|/api/v1/accounts/:account_id/courses/:id
  Return information on a single course.
Accepts the same include[] parameters as the list action plus:
Request Parameters:
| Parameter | Type | Description | |
|---|---|---|---|
| include[] | string | 
 
          Allowed values:  | |
| teacher_limit | integer | The maximum number of teacher enrollments to show. If the course contains more teachers than this, instead of giving the teacher enrollments, the count of teachers will be given under a teacher_count key. | 
Update a course CoursesController#update
PUT /api/v1/courses/:id
url:PUT|/api/v1/courses/:id
  Update an existing course.
Arguments are the same as Courses#create, with a few exceptions (enroll_me).
If a user has content management rights, but not full course editing rights, the only attribute editable through this endpoint will be âsyllabus_bodyâ
If an account has set prevent_course_availability_editing_by_teachers, a teacher cannot change course[start_at], course[conclude_at], or course[restrict_enrollments_to_course_dates] here.
Request Parameters:
| Parameter | Type | Description | |
|---|---|---|---|
| course[account_id] | integer | The unique ID of the account to move the course to. | |
| course[name] | string | The name of the course. If omitted, the course will be named âUnnamed Course.â | |
| course[course_code] | string | The course code for the course. | |
| course[start_at] | DateTime | Course start date in ISO8601 format, e.g. 2011-01-01T01:00Z This value is ignored unless ârestrict_enrollments_to_course_datesâ is set to true, or the course is already published. | |
| course[end_at] | DateTime | Course end date in ISO8601 format. e.g. 2011-01-01T01:00Z This value is ignored unless ârestrict_enrollments_to_course_datesâ is set to true. | |
| course[license] | string | The name of the licensing. Should be one of the following abbreviations (a descriptive name is included in parenthesis for reference): 
 | |
| course[is_public] | boolean | Set to true if course is public to both authenticated and unauthenticated users. | |
| course[is_public_to_auth_users] | boolean | Set to true if course is public only to authenticated users. | |
| course[public_syllabus] | boolean | Set to true to make the course syllabus public. | |
| course[public_syllabus_to_auth] | boolean | Set to true to make the course syllabus to public for authenticated users. | |
| course[public_description] | string | A publicly visible description of the course. | |
| course[allow_student_wiki_edits] | boolean | If true, students will be able to modify the course wiki. | |
| course[allow_wiki_comments] | boolean | If true, course members will be able to comment on wiki pages. | |
| course[allow_student_forum_attachments] | boolean | If true, students can attach files to forum posts. | |
| course[open_enrollment] | boolean | Set to true if the course is open enrollment. | |
| course[self_enrollment] | boolean | Set to true if the course is self enrollment. | |
| course[restrict_enrollments_to_course_dates] | boolean | Set to true to restrict user enrollments to the start and end dates of the course. Setting this value to false will remove the course end date (if it exists), as well as the course start date (if the course is unpublished). | |
| course[term_id] | integer | The unique ID of the term to create to course in. | |
| course[sis_course_id] | string | The unique SIS identifier. | |
| course[integration_id] | string | The unique Integration identifier. | |
| course[hide_final_grades] | boolean | If this option is set to true, the totals in student grades summary will be hidden. | |
| course[time_zone] | string | The time zone for the course. Allowed time zones are IANA time zones or friendlier Ruby on Rails time zones. | |
| course[apply_assignment_group_weights] | boolean | Set to true to weight final grade based on assignment groups percentages. | |
| course[storage_quota_mb] | integer | Set the storage quota for the course, in megabytes. The caller must have the âManage storage quotasâ account permission. | |
| offer | boolean | If this option is set to true, the course will be available to students immediately. | |
| course[event] | string | The action to take on each course. 
 
          Allowed values:  | |
| course[default_view] | string | The type of page that users will see when they first visit the course 
 other types may be added in the future 
          Allowed values:  | |
| course[syllabus_body] | string | The syllabus body for the course | |
| course[syllabus_course_summary] | boolean | Optional. Indicates whether the Course Summary (consisting of the courseâs assignments and calendar events) is displayed on the syllabus page. Defaults to  | |
| course[grading_standard_id] | integer | The grading standard id to set for the course. If no value is provided for this argument the current grading_standard will be un-set from this course. | |
| course[grade_passback_setting] | string | Optional. The grade_passback_setting for the course. Only ânightly_syncâ and â are allowed | |
| course[course_format] | string | Optional. Specifies the format of the course. (Should be either âon_campusâ or âonlineâ) | |
| course[image_id] | integer | This is a file ID corresponding to an image file in the course that will be used as the course image. This will clear the courseâs image_url setting if set. If you attempt to provide image_url and image_id in a request it will fail. | |
| course[image_url] | string | This is a URL to an image to be used as the course image. This will clear the courseâs image_id setting if set. If you attempt to provide image_url and image_id in a request it will fail. | |
| course[remove_image] | boolean | If this option is set to true, the course image url and course image ID are both set to nil | |
| course[remove_banner_image] | boolean | If this option is set to true, the course banner image url and course banner image ID are both set to nil | |
| course[blueprint] | boolean | Sets the course as a blueprint course. | |
| course[blueprint_restrictions] | BlueprintRestriction | Sets a default set to apply to blueprint course objects when restricted, unless use_blueprint_restrictions_by_object_type is enabled. See the Blueprint Restriction documentation | |
| course[use_blueprint_restrictions_by_object_type] | boolean | When enabled, the blueprint_restrictions parameter will be ignored in favor of the blueprint_restrictions_by_object_type parameter | |
| course[blueprint_restrictions_by_object_type] | multiple BlueprintRestrictions | Allows setting multiple Blueprint Restriction to apply to blueprint course objects of the matching type when restricted. The possible object types are âassignmentâ, âattachmentâ, âdiscussion_topicâ, âquizâ and âwiki_pageâ. Example usage:  | |
| course[homeroom_course] | boolean | Sets the course as a homeroom course. The setting takes effect only when the course is associated with a Canvas for Elementary-enabled account. | |
| course[sync_enrollments_from_homeroom] | string | Syncs enrollments from the homeroom that is set in homeroom_course_id. The setting only takes effect when the course is associated with a Canvas for Elementary-enabled account and sync_enrollments_from_homeroom is enabled. | |
| course[homeroom_course_id] | string | Sets the Homeroom Course id to be used with sync_enrollments_from_homeroom. The setting only takes effect when the course is associated with a Canvas for Elementary-enabled account and sync_enrollments_from_homeroom is enabled. | |
| course[template] | boolean | Enable or disable the course as a template that can be selected by an account | |
| course[course_color] | string | Sets a color in hex code format to be associated with the course. The setting takes effect only when the course is associated with a Canvas for Elementary-enabled account. | |
| course[friendly_name] | string | Set a friendly name for the course. If this is provided and the course is associated with a Canvas for Elementary account, it will be shown instead of the course name. This setting takes priority over course nicknames defined by individual users. | |
| course[enable_course_paces] | boolean | Enable or disable Course Pacing for the course. This setting only has an effect when the Course Pacing feature flag is enabled for the sub-account. Otherwise, Course Pacing are always disabled. | |
| course[conditional_release] | boolean | Enable or disable individual learning paths for students based on assessment | |
| course[post_manually] | boolean | When true, all grades in the course will be posted manually. When false, all grades in the course will be automatically posted. Use with caution as this setting will override any assignment level post policy. | |
| override_sis_stickiness | boolean | Default is true. If false, any fields containing âstickyâ changes will not be updated. See SIS CSV Format documentation for information on which fields can have SIS stickiness | 
Example Request:
curl https://<canvas>/api/v1/courses/<course_id> \
  -X PUT \
  -H 'Authorization: Bearer <token>' \
  -d 'course[name]=New course name' \
  -d 'course[start_at]=2012-05-05T00:00:00Z'Example Response:
{
  "name": "New course name",
  "course_code": "COURSE-001",
  "start_at": "2012-05-05T00:00:00Z",
  "end_at": "2012-08-05T23:59:59Z",
  "sis_course_id": "12345"
}Update courses CoursesController#batch_update
PUT /api/v1/accounts/:account_id/courses
url:PUT|/api/v1/accounts/:account_id/courses
  Update multiple courses in an account. Operates asynchronously; use the progress endpoint to query the status of an operation.
Request Parameters:
| Parameter | Type | Description | |
|---|---|---|---|
| course_ids[] | Required | string | List of ids of courses to update. At most 500 courses may be updated in one call. | 
| event | Required | string | The action to take on each course. Must be one of âofferâ, âconcludeâ, âdeleteâ, or âundeleteâ. 
 
          Allowed values:  | 
Example Request:
curl https://<canvas>/api/v1/accounts/<account_id>/courses \
  -X PUT \
  -H 'Authorization: Bearer <token>' \
  -d 'event=offer' \
  -d 'course_ids[]=1' \
  -d 'course_ids[]=2'Reset a course CoursesController#reset_content
POST /api/v1/courses/:course_id/reset_content
url:POST|/api/v1/courses/:course_id/reset_content
  Deletes the current course, and creates a new equivalent course with no content, but all sections and users moved over.
Returns a Course objectGet effective due dates CoursesController#effective_due_dates
GET /api/v1/courses/:course_id/effective_due_dates
url:GET|/api/v1/courses/:course_id/effective_due_dates
  For each assignment in the course, returns each assigned studentâs ID and their corresponding due date along with some grading period data. Returns a collection with keys representing assignment IDs and values as a collection containing keys representing student IDs and values representing the studentâs effective due_at, the grading_period_id of which the due_at falls in, and whether or not the grading period is closed (in_closed_grading_period)
The list of assignment IDs for which effective student due dates are requested. If not provided, all assignments in the course will be used.
Request Parameters:
| Parameter | Type | Description | |
|---|---|---|---|
| assignment_ids[] | string | no description | 
Example Request:
curl https://<canvas>/api/v1/courses/<course_id>/effective_due_dates
  -X GET \
  -H 'Authorization: Bearer <token>'Example Response:
{
  "1": {
     "14": { "due_at": "2015-09-05", "grading_period_id": null, "in_closed_grading_period": false },
     "15": { due_at: null, "grading_period_id": 3, "in_closed_grading_period": true }
  },
  "2": {
     "14": { "due_at": "2015-08-05", "grading_period_id": 3, "in_closed_grading_period": true }
  }
}Permissions CoursesController#permissions
GET /api/v1/courses/:course_id/permissions
url:GET|/api/v1/courses/:course_id/permissions
  Returns permission information for the calling user in the given course. See also the Account and Group counterparts.
Request Parameters:
| Parameter | Type | Description | |
|---|---|---|---|
| permissions[] | string | List of permissions to check against the authenticated user. Permission names are documented in the List assignable permissions endpoint. | 
Example Request:
curl https://<canvas>/api/v1/courses/<course_id>/permissions \
  -H 'Authorization: Bearer <token>' \
  -d 'permissions[]=manage_grades'
  -d 'permissions[]=send_messages'Example Response:
{'manage_grades': 'false', 'send_messages': 'true'}Get bulk user progress CoursesController#bulk_user_progress
GET /api/v1/courses/:course_id/bulk_user_progress
url:GET|/api/v1/courses/:course_id/bulk_user_progress
  Returns progress information for all users enrolled in the given course.
You must be a user who has permission to view all grades in the course (such as a teacher or administrator).
Example Request:
curl https://<canvas>/api/v1/courses/<course_id>/bulk_user_progress \
  -H 'Authorization: Bearer <token>'Example Response:
[
  {
    "id": 1,
    "display_name": "Test Student 1",
    "avatar_image_url": "https://<canvas>/images/messages/avatar-50.png",
    "html_url": "https://<canvas>/courses/1/users/1",
    "pronouns": null,
    "progress": {
      "requirement_count": 2,
      "requirement_completed_count": 1,
      "next_requirement_url": "https://<canvas>/courses/<course_id>/modules/items/<item_id>",
      "completed_at": null
    }
  },
  {
    "id": 2,
    "display_name": "Test Student 2",
    "avatar_image_url": "https://<canvas>/images/messages/avatar-50.png",
    "html_url": "https://<canvas>/courses/1/users/2",
    "pronouns": null,
    "progress": {
      "requirement_count": 2,
      "requirement_completed_count": 2,
      "next_requirement_url": null,
      "completed_at": "2021-08-10T16:26:08Z"
    }
  }
]Remove quiz migration alert CoursesController#dismiss_migration_limitation_msg
POST /api/v1/courses/:id/dismiss_migration_limitation_message
url:POST|/api/v1/courses/:id/dismiss_migration_limitation_message
  Remove alert about the limitations of quiz migrations that is displayed to a user in a course
you must be logged in to use this endpoint
Example Response:
{ "success": "true" }Get course copy status ContentImportsController#copy_course_status
GET /api/v1/courses/:course_id/course_copy/:id
url:GET|/api/v1/courses/:course_id/course_copy/:id
  DEPRECATED: Please use the Content Migrations API
Retrieve the status of a course copy
API response field:
- 
      
      id
      
      
        The unique identifier for the course copy. 
- 
      
      created_at
      
      
        The time that the copy was initiated. 
- 
      
      progress
      
      
        The progress of the copy as an integer. It is null before the copying starts, and 100 when finished. 
- 
      
      workflow_state
      
      
        The current status of the course copy. Possible values: âcreatedâ, âstartedâ, âcompletedâ, âfailedâ 
- 
      
      status_url
      
      
        The url for the course copy status API endpoint. 
Example Response:
{'progress':100, 'workflow_state':'completed', 'id':257, 'created_at':'2011-11-17T16:50:06Z', 'status_url':'/api/v1/courses/9457/course_copy/257'}Copy course content ContentImportsController#copy_course_content
POST /api/v1/courses/:course_id/course_copy
url:POST|/api/v1/courses/:course_id/course_copy
  DEPRECATED: Please use the Content Migrations API
Copies content from one course into another. The default is to copy all course content. You can control specific types to copy by using either the âexceptâ option or the âonlyâ option.
The response is the same as the course copy status endpoint
Request Parameters:
| Parameter | Type | Description | |
|---|---|---|---|
| source_course | string | ID or SIS-ID of the course to copy the content from | |
| except[] | string | A list of the course content types to exclude, all areas not listed will be copied. 
          Allowed values:  | |
| only[] | string | A list of the course content types to copy, all areas not listed will not be copied. 
          Allowed values:  |