-
Notifications
You must be signed in to change notification settings - Fork 1
/
enrollment.py
108 lines (75 loc) · 3.53 KB
/
enrollment.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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
from logging import Logger
import requests
from course import Course
from enrollment_data import EnrollmentData
terms_url = "https://public.enroll.wisc.edu/api/search/v1/aggregate"
query_url = "https://public.enroll.wisc.edu/api/search/v1"
enrollment_package_base_url = "https://public.enroll.wisc.edu/api/search/v1/enrollmentPackages"
def build_enrollment_package_base_url(term, subject_code, course_id):
return f"{enrollment_package_base_url}/{term}/{subject_code}/{course_id}"
def sync_enrollment_terms(terms, logger: Logger):
logger.info("Fetching latest terms...")
response = requests.get(url=terms_url)
data = response.json()
for term in data["terms"]:
term_code = int(term["termCode"])
if term_code in terms:
logger.debug(f"Skipping duplicate term code: {term_code}")
continue
short_description = term["shortDescription"]
logger.debug(f"Found new term code: {term_code} - {short_description}")
terms[term_code] = short_description
def build_from_mega_query(term_code, terms, course_ref_to_course, logger: Logger):
post_data = {
"selectedTerm": term_code,
"queryString": "",
"filters": [],
"page": 1,
"pageSize": 1
}
response = requests.post(url=query_url, json=post_data)
data = response.json()
course_count = data["found"]
post_data["pageSize"] = course_count
response = requests.post(url=query_url, json=post_data)
data = response.json()
hits = data["hits"]
all_instructors = dict[str, str]()
for hit in hits:
course_code = int(hit["catalogNumber"])
if len(hit["allCrossListedSubjects"]) > 1:
enrollment_subjects = hit["allCrossListedSubjects"]
else:
enrollment_subjects = [hit["subject"]]
subjects = set([subject["shortDescription"].replace(" ", "") for subject in enrollment_subjects])
course_ref = Course.Reference(subjects, course_code)
if course_ref not in course_ref_to_course:
logger.info(f"Skipping unknown course: {course_ref}")
continue
course = course_ref_to_course[course_ref]
enrollment_data = EnrollmentData.from_enrollment(hit, terms)
subject_code = hit["subject"]["subjectCode"]
course_id = hit["courseId"]
enrollment_package_url = build_enrollment_package_base_url(term_code, subject_code, course_id)
response = requests.get(url=enrollment_package_url)
data = response.json()
course_instructors = {}
section_count = len(data)
logger.debug(f"Found {section_count} sections for {course_ref.get_identifier()}")
for section in data:
sections = section["sections"]
for s in sections:
section_instructors = s["instructors"]
for instructor in section_instructors:
name = instructor["name"]
first = name["first"]
last = name["last"]
full_name = f"{first} {last}"
email = instructor["email"]
course_instructors.setdefault(full_name, email)
all_instructors.setdefault(full_name, email)
enrollment_data.instructors = course_instructors
logger.debug(f"Added {len(course_instructors)} instructors to {course_ref.get_identifier()}")
course.enrollment_data = enrollment_data
logger.info(f"Discovered {len(all_instructors)} unique instructors teaching in the latest term")
return all_instructors