-
Notifications
You must be signed in to change notification settings - Fork 9
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
1 changed file
with
136 additions
and
10 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -4,8 +4,55 @@ Platform Plugin Aspects | |
Purpose | ||
******* | ||
|
||
This repository holds various Aspects related plugins for edx-platform. | ||
This repository holds various Aspects plugins for the Open edX platform. | ||
|
||
Sinks | ||
***** | ||
|
||
Sinks are components that listen for events and store them in ClickHouse. The | ||
events are emitted by the Open edX platform via `Open edX events`_ or Django signals. | ||
|
||
Available Sinks | ||
=============== | ||
|
||
- `CourseOverviewSink` - Listens for the `COURSE_PUBLISHED` event and stores the | ||
course structure data through `XBlockSink` in ClickHouse. | ||
- `ExternalIdSink` - Listens for the `post_save` Django signal on the `ExternalId` | ||
model and stores the external id data in ClickHouse. | ||
- `UserProfile` - Listens for the `post_save` Django signal on the `UserProfile` | ||
model and stores the user profile data in ClickHouse. | ||
- `UserRetirementSink` - Listen for the `USER_RETIRE_LMS_MISC` Django signal and | ||
remove the user PII information from ClickHouse. | ||
|
||
Commands | ||
======== | ||
|
||
In addition to being an event listener, this package provides the following commands: | ||
|
||
- `dump_data_to_clickhouse` - This command allows bulk export of the data from the Sinks. | ||
Allows bootstrapping a new data platform or backfilling lost or missing data. | ||
|
||
``python manage.py cms dump_courses_to_clickhouse`` | ||
|
||
- `load_test_tracking_events` - This command allows loading test tracking events into | ||
ClickHouse. This is useful for testing the ClickHouse connection to measure the performance of the | ||
different data pipelines such as Vector, Event Bus (Redis and Kafka), and Celery. | ||
|
||
Do not use this command in production as it will generate a large amount of data | ||
and will slow down the system. | ||
|
||
``python manage.py cms load_test_tracking_events`` | ||
|
||
- `monitor_load_test_tracking` - Monitors the load test tracking script and saves | ||
output for later analysis. | ||
|
||
``python manage.py cms monitor_load_test_tracking`` | ||
|
||
Instructor Dashboard Integration | ||
=============================== | ||
|
||
Dashboards from `Aspects`_ are integrated into the Instructor Dashboard via `Superset Embedded SDK`_. | ||
See `Configuration`_ for more details. | ||
|
||
Getting Started with Development | ||
******************************** | ||
|
@@ -15,24 +62,96 @@ Please see the Open edX documentation for `guidance on Python development <https | |
Deploying | ||
********* | ||
|
||
TODO: How can a new user go about deploying this component? Is it just a few | ||
commands? Is there a larger how-to that should be linked here? | ||
The `Platform Plugin Aspects` component is a django plugin which doesn't | ||
need independent deployment. Therefore, its setup is reasonably straightforward. | ||
First, it needs to be added to your service requirements, and then it will be | ||
installed alongside requirements of the service. | ||
|
||
Configuration | ||
************* | ||
|
||
Instructor Dashboard Configuration | ||
---------------------------------- | ||
|
||
The Instructor Dashboard integration uses the `Open edX Filter`_. To learn more about | ||
the filters, see the `Open edX Filter documentation`_. Make sure to configure the | ||
superset pipeline into the filter as follows: | ||
|
||
.. code-block:: python | ||
PLACEHOLDER: For details on how to deploy this component, see the `deployment how-to`_ | ||
OPEN_EDX_FILTERS_CONFIG = { | ||
"org.openedx.learning.instructor.dashboard.render.started.v1": { | ||
"fail_silently": False, | ||
"pipeline": [ | ||
"platform_plugin_superset.extensions.filters.AddSupersetTab", | ||
] | ||
}, | ||
} | ||
- `SUPERSET_CONFIG` - This setting is used to configure the Superset Embedded SDK. | ||
The configuration is a dictionary that contains the following keys: | ||
|
||
- `internal_service_url` - The URL of the Superset instance (useful in development, omit in production). | ||
- `service_url` - The URL of the Superset instance. | ||
- `username` - The username of the Superset user. | ||
- `password` - The password of the Superset user. | ||
|
||
- `ASPECTS_INSTRUCTOR_DASHBOARDS` - This setting is used to configure the dashboards | ||
that will be displayed in the Instructor Dashboard. The configuration is a list of | ||
dictionaries that contains the following keys: | ||
|
||
- `name` - The name of the dashboard. | ||
- `slug` - The slug of the dashboard. | ||
- `uuid` - The UUID of the dashboard. | ||
- `allow_translations` - A boolean value that determines if the dashboard | ||
is translated in `Aspects`_. | ||
|
||
- `SUPERSET_EXTRA_FILTERS_FORMAT` - This setting is used to configure the extra filters | ||
that will be applied to the dashboards. The configuration is a list of strings that | ||
can be formatted with the following variables: | ||
|
||
- `user` - The user object. | ||
- `course` - The course object. | ||
|
||
- `SUPERSET_DASHBOARD_LOCALES` - This setting is used to configure the available locales | ||
for the dashboards. The configuration is a list of supported locales by `Aspects`_. | ||
|
||
Event Sink Configuration | ||
------------------------ | ||
|
||
- `EVENT_SINK_CLICKHOUSE_BACKEND_CONFIG` - This setting is used to configure the ClickHouse | ||
connection. The configuration is a dictionary that contains the following keys: | ||
|
||
- `url` - The host of the ClickHouse instance. | ||
- `database` - The database name. | ||
- `username` - The username of the ClickHouse user. | ||
- `password` - The password of the ClickHouse user. | ||
- `timeout_secs` - The timeout in seconds for the ClickHouse connection. | ||
|
||
- `EVENT_SINK_CLICKHOUSE_PII_MODELS` - This setting is used to configure the models that | ||
contain PII information. The configuration is a list of strings that contain the | ||
table names where the PII information is stored. | ||
|
||
- `EVENT_SINK_CLICKHOUSE_MODEL_CONFIG` - This setting is used to provide compatibility | ||
with multiple `Open edX`_ models. The configuration is a dictionary that contains the | ||
following a key per model that contains a dictionary with the following keys: | ||
|
||
- `module` - The module path of the model. | ||
- `model` - The model class name. | ||
|
||
Event Sinks are disabled by default. To enable them, you need to enable the following | ||
waffle flag: `event_sink_clickhouse.{{model_name}}.enabled` where model name is the name | ||
of the model that you want to enable. Or, you can enable them via settings by setting | ||
`EVENT_SINK_CLICKHOUSE_{{model_name}}_ENABLED` to `True`. | ||
|
||
.. _deployment how-to: https://docs.openedx.org/projects/platform-plugin-aspects/how-tos/how-to-deploy-this-component.html | ||
|
||
Getting Help | ||
************ | ||
|
||
Documentation | ||
============= | ||
|
||
PLACEHOLDER: Start by going through `the documentation`_. If you need more help see below. | ||
|
||
.. _the documentation: https://docs.openedx.org/projects/platform-plugin-aspects | ||
|
||
(TODO: `Set up documentation <https://openedx.atlassian.net/wiki/spaces/DOC/pages/21627535/Publish+Documentation+on+Read+the+Docs>`_) | ||
Documentation for this component can be found at `Aspects`_. | ||
|
||
More Help | ||
========= | ||
|
@@ -96,3 +215,10 @@ Reporting Security Issues | |
************************* | ||
|
||
Please do not report security issues in public. Please email [email protected]. | ||
|
||
.. _Open edX events: https://github.com/openedx/openedx-events | ||
.. _Edx Platform: https://github.com/openedx/edx-platform | ||
.. _ClickHouse: https://clickhouse.com | ||
.. _Aspects: https://docs.openedx.org/projects/openedx-aspects/en/latest/index.html | ||
.. _Superset Embedded SDK: https://www.npmjs.com/package/@superset-ui/embedded-sdk | ||
.. _Open edX Filter: https://docs.openedx.org/projects/openedx-filters/en/latest/ |