From 5bdd9ac1253e024edae3727ff861ace8fd7cd3b9 Mon Sep 17 00:00:00 2001 From: Edward Zarecor Date: Fri, 4 Nov 2022 17:59:42 -0400 Subject: [PATCH] E0d/refine oep 26 (#405) * fix: Clarify this passage. * fix: I don't think this adds much, could be a footnote. * fix: the X in the domain name should not be capitalized. * fix: remove reference to unplanned work * fix: attributing these statements * fix: no longer relevant technical aside. * fix: updating author/arbiter * fix: update external ID decision * fix: remove reference to FE plugability, language clarification * fix: outdated, better as an ADR * fix: removing ambiguity about this scope * fix: update this link to go to the repo * fix: align language better. * fix: this was hopeful and not implemented. * fix: punctuation error * fix: remove dangling reference Co-authored-by: Edward Zarecor --- .../oep-0026-arch-realtime-events.rst | 32 ++++++++----------- .../oep-0026/caliper-realtime-events.rst | 12 +++---- .../oep-0026/xapi-realtime-events.rst | 9 +----- 3 files changed, 20 insertions(+), 33 deletions(-) diff --git a/oeps/architectural-decisions/oep-0026-arch-realtime-events.rst b/oeps/architectural-decisions/oep-0026-arch-realtime-events.rst index e551f94bf..3bbbfeb2f 100644 --- a/oeps/architectural-decisions/oep-0026-arch-realtime-events.rst +++ b/oeps/architectural-decisions/oep-0026-arch-realtime-events.rst @@ -9,9 +9,10 @@ OEP-26: Real-time Events | Last Modified | 2019-01-16 | +-----------------+--------------------------------------------------------+ | Authors | Nimisha Asthagiri , | -| | Danial Malik | +| | Danial Malik , | +| | Ed Zarecor | +-----------------+--------------------------------------------------------+ -| Arbiter | Ed Zarecor | +| Arbiter | Brian Mesick | +-----------------+--------------------------------------------------------+ | Status | Provisional | +-----------------+--------------------------------------------------------+ @@ -33,7 +34,7 @@ Currently, the Open edX system captures LMS interactions in persisted event stre Of late, there are emerging use cases that require notifying external systems of these LMS events in real-time, preferably in industry standard formats (such as xAPI_ and Caliper_). By **real-time** events, we mean pushing data as fast as possible in an automated and synchronous communication at a speed within a few hundred milliseconds (to satisfy `human perception`_). Use cases, such as Adaptive Learning, do require this sub-second communication time. For other use cases, however, **near-real-time** communication (with a delay of multiple minutes) is sufficient. Unless explicitly called out in the document, near-real-time is included when we refer to real-time. Both are orders of magnitude faster than the current **batch processing** available via the tracking logs. -A transition to real-time events is a natural evolution of Open edX's eventing and API capabilities and its impact on connecting users, organizations, and learning services. In fact, `Gartner reports`_ that by 2020 50% of managed APIs in the industry will be event-driven APIs as necessary supplements to RESTful extensions. +This OEP proposes an evolutionary change to Open edX's eventing system that will enable near realtime event-based feedback loops. Events have the potential to connect users, organizations, and learning services in ways that enrich learning on the platform. This document describes a design proposal for supporting standard real-time events in the Open edX system. @@ -54,14 +55,14 @@ Use Case: Adaptive Learning **Requirement:** Real-time communications (*sub-second*) -As captured in `Open edX Adaptive Learning`_, adaptive learning in Open edX will enable the platform to respond to a learner's interactions in real-time, automatically providing the learner with individualized support. Data analysis from earlier experimental attempts on edX.org and elsewhere show how adaptive learning mechanisms can significantly improve the learner's efficiency, engagement, and retention, while providing a more effective learning experience with metacognitive support for life-long learning. +As captured in `Open edX Adaptive Learning`_, adaptive learning in Open edX will enable the platform to respond to a learner's interactions in real-time, automatically providing the learner with individualized support. Data analysis from earlier experimental attempts on edx.org and elsewhere show how adaptive learning mechanisms can significantly improve the learner's efficiency, engagement, and retention, while providing a more effective learning experience with metacognitive support for life-long learning. .. _Open edX Adaptive Learning: https://openedx.atlassian.net/wiki/spaces/AC/pages/542343170/Adaptive+Learning Integration with Adaptive Engines ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -As an iterative path to this future, the immediate goal is to enable integrations with external adaptive engines. In the far future, we may also implement our own open-sourced adaptive engines. But in the meantime, we would like to establish standard APIs that (1) adaptive engines can use to receive real-time events from the Open edX LMS, (2) the Open edX LMS can use to query adaptive engines on what to present to learners, and (3) train adaptive engines based on standard +As an iterative path to this future, the immediate goal is to enable integrations with external adaptive engines. Currently we are focused on establishing standard APIs that (1) adaptive engines can use to receive real-time events from the Open edX LMS, (2) the Open edX LMS can use to query adaptive engines on what to present to learners, and (3) train adaptive engines based on standard events collected from multiple sources. This document focuses on #1 with the need to send scalable and real-time updates to adaptive engines. This is depicted by the left-hand flow in the diagram below. #3 is described in :ref:`oep-26-lrs`. .. image:: oep-0026/adaptive_learning_lms_basic.png @@ -138,7 +139,10 @@ For details on integrating with Caliper, please see the :ref:`caliper_realtime_e Anonymized User ID ================== -The *LMS user_id* will be used to uniquely identify a user in the Open edX system. This decision is detailed in :ref:`oep-32`. +Users will be identified to external systems using a UUID that is associated uniquely with a single user and the external system type with which the UUID can be shared. This decision overrides :ref:`oep-32` and is captured in `ADR 0001-externalid.rst`_. + +.. _ADR 0001-externalid.rst: https://github.com/openedx/edx-platform/blob/e1c8fb51bec2be3aa8da9750cb52b01728d1a740/openedx/core/djangoapps/external_user_ids/docs/decisions/0001-externalid.rst + Eventing Components =================== @@ -159,9 +163,8 @@ Here is a description of each subcomponent in the Eventing subsystem: 2. `Asynchronous Real-time Eventing Routing Backend`_: Asynchronously routes to each configured communication protocol (e.g., xAPI and Caliper). 3. `Filter Processor`_: Owns the business logic for access control and filtering of events. A common implementation for the Filter may be shared across communication protocol backends. 4. `Translator Processor`_: Translates Open edX native events to standardized Open edX events. Each communication protocol would have its own Translator component implementation. -5. `Validator Processor`_: Validates the generated event using a general-purpose validation library cross-maintained by Open edX real-time eventing consumers. Each communication protocol would have its own Validator component implementation. -6. `Router`_: Routes real-time translated, validated, filtered events to all registered consumers. -7. `Admin UI`_: Provides an administrative interface to configure and manage registered consumers. +5. `Router`_: Routes real-time translated, validated, filtered events to all registered consumers. +6. `Admin UI`_: Provides an administrative interface to configure and manage registered consumers. Synchronous Real-time Eventing Backend -------------------------------------- @@ -203,13 +206,6 @@ Each communication protocol has its own Translator component. This component is .. _oep-26-validator: -Validator Processor -------------------- - -The validation component ensures we continue to support the event output schema expected by all participating real-time eventing consumers. In many ways, this is similar to what `consumer-driven contract testing`_ would enable and uses similar design principles. Essentially, a common validation library can be collaboratively maintained by participating consumers, including consuming adaptive engines. This ensures an end-to-end integration that can be maintained going forward. - -.. _consumer-driven contract testing: https://www.thoughtworks.com/radar/techniques/consumer-driven-contract-testing - Router ------ @@ -227,7 +223,7 @@ Eventually, the registry of consumers may become a self-service portal where con Decisions & Consequences ************************ -* **Event-driven APIs at Scale** - The Context_ section describes the motivation and recent use cases for supporting real-time events. This capability, along with Frontend Pluggability (OEP - TBD), has the potential to provide a dramatic shift in how external services can integrate and extend the Open edX system. +* **Event-driven APIs at Scale** - The Context_ section describes the motivation and recent use cases for supporting real-time events. This capability has the potential to dramatically improve how external services can integrate and extend the Open edX platform. Real-time events will provide a mechanism for loosely coupled integrations with a reliable, standardized contract. A big consideration and concern that is sorely missing from this version of the OEP is explicit recommendations on the infrastructure that will be used to support scalability. On one hand, the advantage is that this agnostic approach allows Open edX instances to reuse the core capabilities (and modular subcomponents) without being tied to a specific scalable technology. On the other hand, we run the risk of needing to reimplement initial implementations if a chosen technology's design is fundamentally counter to our choice of boundaries. @@ -235,7 +231,7 @@ Decisions & Consequences For Enterprise and other use cases, sharing PII may be required. We have chosen to keep those use cases in mind, but not target them initially, with the understanding that future work would be needed to address those needs. -* **Deferring implementation of an LRS** - As mentioned in :ref:`oep-26-lrs`, we are consciously postponing implementation of an Open edX specific LRS at this time. Although the need for an LRS may be forthcoming, this initial iteration defers this work. +* **Implementation of an LRS is out of scope** - As mentioned in :ref:`oep-26-lrs`, creating an Open edX specific LRS not planned. As a consequence, adaptive engines may need to maintain their own LRS if they need to refer back to previous events. Given our business research to date, it seems many adaptive engines are already maintaining their own custom-optimized storage of event data. diff --git a/oeps/architectural-decisions/oep-0026/caliper-realtime-events.rst b/oeps/architectural-decisions/oep-0026/caliper-realtime-events.rst index 092cb8f77..d72033be3 100644 --- a/oeps/architectural-decisions/oep-0026/caliper-realtime-events.rst +++ b/oeps/architectural-decisions/oep-0026/caliper-realtime-events.rst @@ -10,9 +10,7 @@ Caliper Real-time Events Standardized Integration with Caliper ************************************* -Caliper is a standard that enables the collection, storage, and transport of data about learning. As a learning analytics framework, Caliper provides a common-gauge rail for disparate applications to use and share data from student interactions with learning software and administrative systems. - -We have chosen Caliper as one of the primary communication standards for real-time events since many universities and other educational organizations prefer to use tools that require Caliper compliant activity tracking events. +Caliper Analtyics® is a specification defining "a structured approach to describing, collecting and exchanging learning activity data. Establishing a common vocabulary for describing learning interactions is a central objective. Promoting data interoperability, data sharing and data-informed decision making are also important goals."[#caliperDesignGoals]_ The standard has been described as "common-gauge rail for disparate applications to use and share data from student interactions with learning software and administrative systems."[#commonGaugeRail]_ Caliper Learning Analytics Ecosystem ************************************ @@ -26,14 +24,11 @@ Sensor API `Sensor API`_ defines the basic learning events as well as standardizes and simplifies the gathering of learning metrics across the learning environments. These are used for marshaling and transmitting event data from instrumented applications to target endpoints for storage, analysis, and use. -There is a `sensor API library for python`_ that we can use in our routers for generating and propagating events. At present, the Sensor API can only Write/Post data to repository endpoints and does not support reading data from a data repository. - |sensorAPI| See `Sensor API `__ for more information. .. _Sensor API: https://www.imsglobal.org/sites/default/files/caliper/v1p1/caliper-spec-v1p1/caliper-spec-v1p1.html#sensor -.. _sensor API library for python: https://github.com/IMSGlobal/caliper-python The Information Model ********************* @@ -208,7 +203,7 @@ Event Field Mapping Please see the `Open edX Caliper Events`_ document for a detailed view of the mapping between the above Open edX events and their equivalent Open edX Caliper formats. -.. _Open edX Caliper Events: https://docs.google.com/spreadsheets/d/1MgHddOO6G33sSpknvYi-aXuLiBmuKTfHmESsXpIiuU8/view +.. _Open edX Caliper Events: https://github.com/openedx/event-routing-backends/blob/d4cb7c1e2c1b5c80f807206cf47eb358f388627c/docs/event-mapping/Caliper_mapping.rst .. |ecosystem| image:: ./caliper_ecosystem.png :width: 6.5in @@ -216,3 +211,6 @@ Please see the `Open edX Caliper Events`_ document for a detailed view of the ma .. |sensorAPI| image:: ./sensorAPI.png :width: 6.5in :height: 1.13889in + +.. [#caliperDesignGoals] Quoted from https://www.imsglobal.org/spec/caliper/v1p2#design-goals-and-rationale +.. [#commonGaugeRail] Quoted from https://blackboard.secure.force.com/btbb_exportarticlepdf?id=kAE1O000000Xe3LWAS&pdf=true diff --git a/oeps/architectural-decisions/oep-0026/xapi-realtime-events.rst b/oeps/architectural-decisions/oep-0026/xapi-realtime-events.rst index 47f59846b..84f2dfe67 100644 --- a/oeps/architectural-decisions/oep-0026/xapi-realtime-events.rst +++ b/oeps/architectural-decisions/oep-0026/xapi-realtime-events.rst @@ -26,7 +26,7 @@ xAPI includes a specification for a Learning Record Store (LRS), which encapsula .. image:: ./adaptive_learning_lrs_basic.png :alt: The diagram above is enhanced with a new LRS component that receives events from the Open edX "Eventing" component and is accessed by adaptive engines for training purposes, using xAPI for both transactions. -In the short term, however, we will not implement our own LRS. We will look into integration efforts with third party LRS services. +We will not implement our own LRS. We will look into integration efforts with third party LRS services. Statement API ************* @@ -234,10 +234,3 @@ Event Field Mapping Please see the `Open edx xAPI Events`_ document for a detailed view of the mapping between the above Open edX events and their equivalent Open edX xAPI formats. .. _Open edx xAPI Events: https://docs.google.com/spreadsheets/d/1oTClCxuUj1vCzytbmjDaHWFmcI6JZDqqJtZmYVwnOTA/view - -Implementation Note -=================== - -TBD - The development team will assess whether we will use (and start owning) the already implemented (but no longer maintained) `xAPI Python Open Source Library`_. - -.. _xAPI Python Open Source Library: https://xapi.com/python-library/