Webhooks Subscriptions for Plagiarism Platform
LTI API for Webhook Subscriptions (Must use JWT access tokens with this API).
This is intended for use with Canvas' Plagiarism Detection Platform. For general-purpose event subscriptions see Live Events.
The tool proxy must also have the appropriate enabled capabilities (See appendix).
Webhooks from Canvas are your way to know that a change (e.g. new or updated submission, new or updated assignment, etc.) has taken place.
Webhooks are available via HTTPS to an endpoint you own and specify, or via an AWS SQS queue that you provision, own, and specify. We recommend SQS for the most robust integration, but do support HTTPS for lower volume applications.
We do not deduplicate or batch messages before transmission. Avoid creating multiple identical subscriptions. Webhooks always identify the ID of the subscription that caused them to be sent, allowing you to identify problematic or high volume subscriptions.
We cannot guarantee the transmission order of webhooks. If order is important to your application, you must check the "event_time" attribute in the "metadata" hash to determine sequence.
Lti::SubscriptionsApiController#create
POST /api/lti/subscriptions
POST /api/lti/subscriptions
Scope: url:POST|/api/lti/subscriptions
Creates a webook subscription for the specified event type and context.
Request Parameters:
subscription[ContextId]
Required string
The id of the context for the subscription.
subscription[ContextType]
Required string
The type of context for the subscription. Must be ‘assignment’, ‘account’, or ‘course’.
subscription[EventTypes]
Required Array
Array of strings representing the event types for the subscription.
subscription[Format]
Required string
Format to deliver the live events. Must be ‘live-event’ or ‘caliper’.
subscription[TransportMetadata]
Required Object
An object with a single key: ‘Url’. Example: { “Url”: “sqs.example” }
subscription[TransportType]
Required string
Must be either ‘sqs’ or ‘https’.
Lti::SubscriptionsApiController#destroy
DELETE /api/lti/subscriptions/:id
DELETE /api/lti/subscriptions/:id
Scope: url:DELETE|/api/lti/subscriptions/:id
Lti::SubscriptionsApiController#show
GET /api/lti/subscriptions/:id
GET /api/lti/subscriptions/:id
Scope: url:GET|/api/lti/subscriptions/:id
Lti::SubscriptionsApiController#update
PUT /api/lti/subscriptions/:id
PUT /api/lti/subscriptions/:id
Scope: url:PUT|/api/lti/subscriptions/:id
This endpoint uses the same parameters as the create endpoint
Lti::SubscriptionsApiController#index
GET /api/lti/subscriptions
GET /api/lti/subscriptions
Scope: url:GET|/api/lti/subscriptions
This endpoint returns a paginated list with a default limit of 100 items per result set. You can retrieve the next result set by setting a ‘StartKey’ header in your next request with the value of the ‘EndKey’ header in the response.
Example use of a ‘StartKey’ header object:
Appendixes
Appendix: Webhook Subscription Required Capabilities
A tool must have certain capabilities enabled in order to create webhook subscriptions for a given event type in a given context. These capabilities can only be obtained through the use of a custom tool consumer profile.
All available event types are listed bellow along with the capability that will allow creating subscriptions of the associated type.
QUIZ_SUBMITTED
Event Type
QUIZ_SUBMITTED
Event Typevnd.instructure.webhooks.root_account.quiz_submitted
vnd.instructure.webhooks.assignment.quiz_submitted
GRADE_CHANGE
Event Type
GRADE_CHANGE
Event Typevnd.instructure.webhooks.root_account.grade_change
ATTACHMENT_CREATED
Event Type
ATTACHMENT_CREATED
Event Typevnd.instructure.webhooks.root_account.attachment_created
vnd.instructure.webhooks.assignment.attachment_created
SUBMISSION_CREATED
Event Type
SUBMISSION_CREATED
Event Typevnd.instructure.webhooks.root_account.submission_created
vnd.instructure.webhooks.assignment.submission_created
SUBMISSION_UPDATED
Event Type
SUBMISSION_UPDATED
Event Typevnd.instructure.webhooks.root_account.submission_updated
vnd.instructure.webhooks.assignment.submission_updated
PLAGIARISM_RESUBMIT
Event Type
PLAGIARISM_RESUBMIT
Event Typevnd.instructure.webhooks.root_account.plagiarism_resubmit
vnd.instructure.webhooks.assignment.plagiarism_resubmit
All Event Types
vnd.instructure.webhooks.root_account.all
This documentation is generated directly from the Canvas LMS source code, available on Github.
Last updated