The Canvas API, but simpler and more powerful
This project is designed by educators for educators. Each endpoint is a black box that just works. We don't have full API coverage, but we add functions as they are requested.
  
  
  
    Quickstart
  
  
  
1. Get an api instance
In your CACCL project, you should have access to an api instance (via getAPI, for example). Read through the CACCL docs to learn more.
2. Call an endpoint function
All endpoint functions are asynchronous, so we recommend using async/await syntax:
const submissions = await api.course.listStudents();
  
  
  
    API Config
  
  
  
Every endpoint function can take a second argument that overwrites default settings:
| Argument | Type | Description | 
|---|---|---|
| onNewPage | function | this function is called when each page is received from Canvas | 
| maxPages | number | maximum number of pages to fetch | 
| itemsPerPage | number | number of items to request in each page | 
| numRetries | number | number of times to retry failed network requests | 
| canvasHost | string | hostname for Canvas | 
| accessToken | string | access token to use for authentication | 
| authenticityToken | string | Canvas authenticity token (we recommend that you use accessToken instead) | 
In most cases, you will not need to include any of these parameters because the defaults will suffice.
  
  
  
    Tips and Tricks
  
  
  
For giant requests, process data as it arrives:
Instead of waiting until the endpoint function returns with all the pages of data, process it page by page using onNewPage.
const allCourses = await api.account.listCourses({
  accountId: 29,
  onNewPage: (batchOfCourses) => {
    // Increment the number of courses that have been downloaded
    this.incrementNumberOfCourses(batchOfCourses.length);
    // Add the new batch of courses to the table shown to the user
    this.addCoursesToTable(batchOfCourses);
  },
});
Hit any endpoint, even ones that aren't listed in our docs:
Use api.other.endpoint(...) to hit any endpoint in Canvas.
If you find that you're using other endpoints frequently, please request that those endpoints be added to CACCL API as an official function.