-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathread_courses.py
84 lines (60 loc) · 2.34 KB
/
read_courses.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
# This program pulls the list of courses from canvas which are tagged 'available''
import dotenv
import os
import requests
import pandas as pd
# load variables from .env file
dotenv.load_dotenv(dotenv.find_dotenv())
# ensure access token is available
TOKEN = os.environ.get('CANVAS_ACCESS_TOKEN')
if TOKEN == None:
print("No access token found. Please set `CANVAS_ACCESS_TOKEN`")
exit()
# retrieve base URL of canvas
BASE_URL = os.environ.get('CANVAS_URL')
# Static settings
# retrieve entries per page
PER_PAGE = int(os.environ.get('CANVAS_PER_PAGE'))
# ensure access token is available
auth_header = {'Authorization': 'Bearer ' + TOKEN} # setup the authorization header to be used later
# ensure that COURSE_STATE is valid
COURSE_STATE = os.environ.get('CANVAS_COURSE_STATE')
if not COURSE_STATE in ["unpublished", "available", "completed", "deleted"]:
print("Invalid course state. Please set `CANVAS_COURSE_STATE` to one of [unpublished, available, completed, deleted]")
exit()
print("Finding courses...")
print("-----------------------------")
# continue to make requests until all data has been received
page = 1
courses = []
while True:
# request urls should always be based of the base url so they do not
# need to be changed when switching between test and production environments
request_url = BASE_URL + '/api/v1/courses'
params = {
"per_page": str(PER_PAGE),
"page": str(page),
"state[]": [COURSE_STATE],
"include[]": ['total_students']
}
r = requests.get(request_url, headers=auth_header, params=params)
# always take care to handle request errors
r.raise_for_status() # raise error if 4xx or 5xx
data = r.json()
if len(data) == 0:
break
courses += data
print("Finished processing page: "+str(page))
page+=1
if len(courses) == 0:
print("No courses found to report on.")
exit()
# from here, a simple table is printed out
# using pandas for convenience
print("Report for "+str(len(courses)) + " courses.")
print("-----------------------------")
courses_df = pd.DataFrame(courses)
result = courses_df.to_string(
columns=['id', 'name', 'course_code', 'total_students'] # more parameter: 'start_at', 'workflow_state', 'end_at'
)
print(result+'\n')