-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathexample.py
35 lines (30 loc) · 1.44 KB
/
example.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
from khan_api_wrapper.khan import KhanAcademySignIn, KhanAPI
from pprint import pprint
from datetime import datetime
# First authenticate with Khan Academy. This will only work for the account
# used to register the app, and if the account settings are set up in config.py
consumer_key = "Key from registering app"
consumer_token = "Token from registering app"
khan_identifier = "username_of_account_used_to_register_app"
khan_password = "password_of_account_used_to_register_app"
kauth = KhanAcademySignIn(
consumer_key, consumer_token, khan_identifier, khan_password
)
token, secret = kauth.authorize_self()
# Now instatiate the authenticated khan api class, which can be used to fetch
# protected endpoints
kapi = KhanAPI(consumer_key, consumer_token, token, secret)
# Fetch data from documented api call
user = kapi.user()
# pprint(user)
# Fetch data from undocumented api call. Use these cautiously as they are not
# gauranteed to work. See https://github.com/Khan/khan-api/wiki/Khan-Academy-API-Authentication#the-endpoints-exposed-on-the-api-explorer-dont-seem-to-do-what-i-need-am-i-ableallowed-to-access-any-other-endpoints
params = {
"dt_start": "1970-09-08T07:00:00.000Z",
"dt_end": datetime.utcnow().replace(microsecond=0).isoformat() + "Z",
}
students = kapi.get_student_list(params)
# pprint(students)
# Access the get function directly to use an endpoint of your choice
missions = kapi.get("/api/internal/user/missions")
# pprint(missions)