Introduction
In Sunbird Platform, courses can be created by grouping multiple learning resources under course units which are then grouped together to form a course. Course creators have to create courses from the ground up and progress of the course can be tracked only at a course level. This is good enough for short term and small courses which are mainly used for up-skilling courses.
However, courses linked to a curriculum (i.e. referred to as curriculum courses, which are used for online learning of a curriculum like K12 or any degree) run for a longer duration, requires tracking at a more granular level and leverage existing curriculum training resources in the course. In this context, we need to enhance the courses platform with following additional capabilities:
Jump start creation of a course using existing resources like textbooks
Linkable, trackable and reusable course units so that multiple curriculum courses can reuse them (for example, in K12 curriculum courses, same course units can be used in courses for the same subject across different boards)
Monitor progress of learners at intermediate unit levels
Design
Creation of Curriculum Courses
Course micro-service will be enhanced to create a course using an existing “collection”. The collection structure is copied into the course hierarchy and allows the course creator to further edit the course.
Hierarchy structure of the collection is copied and replicated in the course
Resources in the collection are not copied and only linked to the newly created course hierarchy
There are two options for managing the curriculum courses:
New contentType “CurriculumCourse“ | New courseType “CurriculumCourse“ |
---|---|
|
|
Pros: Backward compatibility is automatically taken care of. Existing mobile apps will not see these new type of courses as it is a new content type. | Pros: Easy to enable new metadata for courses. No major code changes for batches and keeps the batches service simple (as batches are associated only with courses). |
Cons: Creating new contentType is configurable in the platform, but it requires changes in the batches service and client apps to handle this new content type. | Cons: To support backward compatibility, we need to add custom logic in search-service: to not return courses of “CurriculumCourse” type by default. |
Course Modules (name TBD)
Courses are currently composed of CourseUnit objects which have a limited visibility. They are available only within the context of the parent, i.e the course. In curriculum courses, we need these intermediate units of the course to be:
Linkable: ability to share the link of an intermediate unit with a learner and the learner can start the course consumption from the shared unit. This is already supported by the platform - details of one unit can be fetched from the platform. Clients need to understand the link pattern and fetch the required details about the unit.
Reusable: ability to link the unit of one course to another course. This will be enabled by introducing a new contentType “Module” and mimeType “collection”. These modules will have the same behaviour as normal collections except that they are mostly used within courses and progress computation happens at module level.
Trackable: ability track learners progress at intermediate units level. This is detailed in the next section.
Progress Computation at module level
In our platform, the batch is used to capture and compute the learner progress of a course. The batch is created for a course by a mentor. When the learners enrol to the batch, the mentor(s) has the ability to monitor the progress of the learners.
The batch progress computation is at the course (root object of the content hierarchy) level only. The collections inside a course are ignored in progress computation and recognising as completed.
Progress computation needs to be enhanced to fetch the progress of intermediate units for a learner.
When a learner enrols to a course batch and starts consuming the content, client apps send the progress of each resource via content state update API calls. The platform uses this information to compute the progress of the learner in the course.
A course can be classified into three parts. the platform already supports progress computation and saving the data for two parts. In course hierarchy we have,
Leaf Nodes (Resource) - The platform receives the progress information of each resource in the course from the client via API.
Root Content (Course) - It is a collection content. The platform uses an async job (Samza) to compute the progress of Root Content. It uses resource progress update and generates an event to Kafka for refreshing the progress.
Collections within Course (Modules)
The Kafka event used to refresh course progress have the below details.
resource identifier and status
course identifier
batch identifier
The resource is a leaf node in the Course Hierarchy. The job will be enhanced to identify all the collections of type “Module” in sub-graph of Course hierarchy and compute progress for all of them at once.
Key Decisions to be made
new contentType or new attribute “courseType” for curriculum courses?
nomenclature for intermediate units within the course - module or something else?
using druid for aggregating progress at unit level?