Discover
Design documentation and brainstorming for Sunbird
Browse by topic
-
A-B
-
C
-
D
-
E-F
-
G-M
-
N-O
-
P-Q
-
R
-
S
-
T-V
-
W-Z
Recent updates
Index of pages
Space Index
|
|||||||||||||||||||||||||||||||
0-92019-02-27 RetrospectiveFill in retro details in the table below. Type /date to quickly add the date and @mention participants to help them find the page. Date Team Anand, Ayub, Kartheek, Anil, Mahesh, Chitranshu, Asha, Vinaya, Participants Background Provide context on the pro
3.8.0.0 Sprint2 Retrospective - 2021-04-09
Fill in retro details in the table below. Type /date to quickly add the date and @mention participants to help them find the page. Date Team Participants Background Provide context on the project or initiative the team is discussing in this retro Retrospe
3.9.0.0 Sprint2 Retrospective - 2021-05-06
Fill in retro details in the table below. Type /date to quickly add the date and @mention participants to help them find the page. Date Team Participants Background Provide context on the project or initiative the team is discussing in this retro Retrospe
|
AA/B testing available framework evaluationOverview Jira Ticket: As part of implementation of A/B framework, we have evaluated 4 frameworks' that are available for A/B testing. Planout (by Facebook), Wasabi (by Intuit), Alephbet & sixpack (by seatgeek) We will list down the salient feature and com
A/B Testing framework design
Overview When new usability feature need to be launched or we need to re-vamp/change the current usability dramatically, we cannot go full fledged testing out the idea across the whole audience. To collect the data and feedback on such usability features,
Ability to provide review comments to a content at the page level
Background: Currently, Sunbird supports adding review comments by a content reviewer while rejecting a content. Comments can only be given at the content level. Problem statement: Ability to provide review comments to a content at the page level. Proposed
Access to Sunbird datasets via APIs
Business Requirement Sunbird provides the capability to generate various datasets for reporting purposes. Some of these can be downloaded by users via the UI (the Course progress exhaust, for example), whereas others are used by the Sunbird portal to gene
Access User private data in masked form in search based on roles
Problem Statement Currently when a user is searched, only the basic data is being returned, User's private data is restricted to user only. However User with certain role would like to access user's private data in masked form when searching for other use
Account Recovery workflow in Portal
Overview: Currently, Sunbird uses account recovery flow of Keycloak with minimal customization. Keycloak provides secure account recovery flow, that accepts primary account identifier(Phone or Email) to recovery account. If the user doesn't have access to
Add a course as a resource in the course editor
Background As a content creator, when creating a course I should be able to add another course Solution:- Enabled root node with add child node & add a resource option Config:- "nodeDisplayCriteria": { "contentType": [ "Course", "CourseUnit", "Collection"
Add plugins outward relation with plugins, which has used in the content
Ref: Problem statement: Presently to identify the plugins which are used in the content, we have to parse the complete body object & identify the id of the plugin exist in the plugin-manifest of the content. To do this, we have to run some java/node scr
Adding user to an organisation
Overview : There is a need in sunbird platform to identify user and org based on their external id and provider, instead of identifying them using there ids. Problem statement : Ticket Ref: SC-879 https://project-sunbird.atlassian.net/browse/SC-879 As
Additional Metadata required in Textbook
Overview In view of providing better experience for devices which run on a low configuration and/or low bandwidth, to the offline modes- mobile and desktop apps, the following is decided : 1. Addition of hierarchy.json file inside the ecar, which consists
Adoption of Sunbird DIAL Context
This document explains implementation/adoption of Sunbird DIAL context. Document details about 3 areas. How to extend the Sunbird DIAL Context Vocabulary? Why - Each sunbird adopter wants to update the specific information in the DIAL code context(JSON re
Allow user to specify framework-id while updating framework fields
Overview Currently user is shown the framework fields, associated with root-org channel to which user belongs. As part of the story, we want to allow the user to select the framework, and pass the framework fields accordingly. Changes in existing API For
Allow users to declare their State & District via their profile
Problem statement: As a sunbird user, one should be able to do declare their District (Choose State -> Choose District). Proposed solution 1: Storing the location of the user in separate table & separate API for updating location Pros: Implementation
Announcement Page Route Handling
Background Announcement feature contains pages like Compose,Outbox,Inbox,View Announcement etc. At Present we are handling the child route url changes of announcement with respect to the context of parent page. For example, 1. if user clicks on announceme
API for Metrics Summary
Requirement Ref: Scope is : 1. This will expose one end point to show all metrics summary 2. Internally it will make call to analytics team and merge both static data and data got from analytics team. 3. Since Analytics data will change once in 24 hours,
API throttling
Problem statement To enhance the better use of resources, the system needs API based throttling for self signup where the signup calls can be restricted based on phone number and throttling needs to be time based which translates to something like for a p
API to get user types
Overview As part of user search result enhancements, we will require user to be able to filter based on user-type. For that, we need a way to fetch the available user-types. Approach 1 Create a look-up table within database, and return it from there. Pros
Architecture
Assessment Irrespective of Assessment feature application gives a feature to create Users and Groups Groups are more than one user added together. Till release 1.7.0 The assessment was available to a user who takes the course or lesson on the last page of the cours
Assessment Report - Total scores of the assessment
Introduction This wiki explains that how to calculate the Total score of assessment. Background Currently total score is dependent on telemetry from the player. Listing the telemetry for each assessment for that content and doing the sum of max score for
Assessment scores in courses and certificates(SB-21228 and SH-1368)
Overview This document explains the assumptions and implementation design to provide assessment score related details and its usage in provide merit(progress + assessment) certificates. This includes changes in existing APIs related to course progress and
Association of badge to course
Problem statement: As a sunbird system, it should have capability to associate/disassociate badge to/from course. Whenever any course batch is created, the batch inherits the associated badge. And the participant of the batch gets the same badge on compl
Auto merge in SSO
Overview: Currently, Any user initiating a first time SSO login using an identifier that already exists in the custodian org - causes an auto migration of the account from custodian to the state tenant it can cause erroneous migration to avoid it user's a
|
||||||||||||||||||||||||||||||
BBackend API request and response formatsREQUEST: { "request": { "content": { "name": "test event", "code": "1234", "startDate": "01/03/2021", "endDate": "01/03/2021", "startTime": "11:00", "endTime": "13:00",
Background Network Queue Sync Service
Introduction and Problem Statement Intro: This documents describes the proposed design for tackling data sync over http for mobile client. Problem: Mobile client collects, aggregates and persists data that periodically gets sync’ed to the server. This dat
Badge assertion to user upon batch completion
Problem Statement:- Whenever a participant completes a course-batch, active badge associated with the course at the time of completion should be asserted to the user. As a sunbird system, how would we achieve that? Proposed Solution :- We already have bad
Brainstroming font issues
Brainstorming on expected UX and performance issues after more languages comes on board. As more languages will get added to the portal, few anticipated challenges will need to be figured out before they surface - Challenges expected - More languages wil
Bulk Upload - Content
Problem Statement Related Jira Task - Bulk Content Upload is to be supported in Sunbird, with 3 operation modes API to be made available to check the real-time status of the bulk content upload process API to be made available to list the statuses of pro
Bulk Upload Service
Content Upload
BulkUpload Service download results
Overview User can use bulk upload service for various artifacts like User, Organization, Location etc. Currently, user can access the results of upload through upload/status api, where in user gets all the records uploaded in json format. This can be diff
|
CCache Implementation DesignOverview : Cache is an important aspect of an application to improve the api response time. For any heavily used system we need to have a mechanism to cache some of the data , which is not going to change very frequently. As of now Su
Cache resolve in sunbird content plugins.
Introduction: This wiki explains the design and implementation of resolving sunbird-content-plugins cache. Background: Currently, If any fix/feature goes to contributed plugins other than the core plugins, The developers are publishing the plugins without
Caching read API using Redis
Overview Use of caching for sending Response for the API which are most used and have least frequency of update of underlying data. Benefits : It will reduce the load on database and also improve response time. Will able to keep up all the supported API
Capturing Sign-in Type and User Role of users in Pipeline
Overview : Need to add the fields in telemetry User role and Sign In type for further breakdown of "No of Unique Users Count by district" Problem Statement: Stamp user role in telemetry Stamp Sign In type in telemetry Design: Stamping User Role - Approac
Capturing usage of features for analysis
Introduction In this wiki, we will discuss an approach to compute usage of various features across different components. The usage of features can be captured using telemetry events and then subsequently used for analysis of different feature usage. We wi
Cassandra Audit Logging for Different Data Types
The purpose of this document is to test Cassandra Trigger and ecAudit logging with different data types to evaluate their support. Table schema on which we have performed operations. CREATE TABLE practice.trigger_audit_log ( id int PRIMARY KEY, bolbtype b
Cassandra date columns datatype migration from string to timestamp
Overview In cassandra data store used by course progress monitoring, few columns which are having date in string format. This results in date and timestamp mismatches when comparing with timezones. Thus, in order to maintain standards and to address the d
Cassandra horizontal scaling
Overview This document provides the insights of horizontally scaling cassandra cluster with the observations and recommendations from benchmarking different scenarios. Tests and Observations To test the scenarios, a keyspace with replication factor of 3 a
Cassandra migration and cql to respective component repos
Introduction Currently, all the migration scripts for all the services/repos (sunbird-lms-service, group-service, sunbird-notification-service, and sunbird-course-service) are packaged with the cassandra-migration module jar. And all the migration informa
Cassandra trigger
Problem Statement:- How to record any insert/update/delete i.e.(write) operation in cassandra as an event? Proposed Solution 1 Cassandra trigger can be used for this purpose. We need to create trigger on particular table which will write into another tabl
CBSE Question Bank Solicitation Format
Context: In an effort to seed the question and answer data, as a part of the EQB, CBSE is reaching out to its affiliate schools, asking them for data (questions, answers, marking scheme etc...). Following was the schema that was shared by CBSE. Schema Cl
CDN Approach for design system
Problem Statement Currently, each channel ( Portal, Editors, Players, Keycloak, Static site, Help center, etc ) has its own CSS codebase and therefore following challenges occur - To keep design consistency across all the channels, the team has to do chan
Certificate: Attach to a batch
Introduction: This document describes how to issue/assign the certificate to a batch of the specific course. Background: Jira Issues UI designs: https://project-sunbird.atlassian.net/browse/SH-641 https://project-sunbird.atlassian.net/browse/SH-641 Relate
Certificate: Dynamic rules support
Introduction: This document describes how to add/show certificate rules dynamically based on the certificate type Background: Jira Issue https://project-sunbird.atlassian.net/browse/SH-993 https://project-sunbird.atlassian.net/browse/SH-993 Problem Statem
CF R-1.14 Sprint 3
Changes to course progress calculation for videos/youtube and pdf content Background:- The majority of the support tickets indicate that users have a problem with course progress. They report that they have played the video or viewed the document multiple times but the progress is stuck. Issue link:- https://project-sunbird.atl
Chatbot KT
Session Topic Details 1 Chatbot Repos(Sunbird & partner-private) Deployments 2 Configuration changes - Deployments 3 Chatbot client 4 Chatbot router 5 Rasa Session 1: Topic: Chatbot Repos for backend and client Details: Repository Backend repository https
Chatbot on Sunbird
About This document details the chatbot architecture principles and the functional use cases addressed via chatbot. Use Cases Chatbot on Sunbird is positioned as: a capability which can help users with the discovery of relevant content on the platform vir
CI/CD Processes
Only modified or added branch will be built and updated to the staging and prod instances. To include or remove any of the version - widgets.json file will need to be updated (Not in release 1.9) if removed - the robots.txt file will have to be updated Ea
Collaboration for content creation
Overview: Adding collaborators to the content in sunbird. when added as a collaborator to the content the collaborator will have rights to edit the content. And at a single instance only one person should be able to edit the content. collaborators support
Collection Hierarchy Generalisation
Overview: Collection hierarchy structure should support different type of objects as children. Current Behaviour: A Collection hierarchy supports Content with visibility Default and Collection with visibility as Parent and Default as children. Child Colle
Collection Player Design
Problem statement For the adaptors to experience the collections which are part of knowLG building block there is a need to build a player which will render them, So there is a need to build a collection player which supports all types of collections. Sin
Collections - structure optimization
Introduction: This wiki explains the current structure for collections and the proposed structure changes for optimization and scale. Background & Problem statement: The textbook is realized by Collection node in the Knowledge Platform. The textbook with
Common Reusable Classes
Class Description Margins All Directions m-0 adds margin 0 in all directions m-5 adds margin 5px in all directions m-10 adds margin 10px in all directions m-15 adds margin 15px in all directions m-20 adds margin 20px in all directions Margin Only Top dire
Config Service JS client sdk - Implemenetation design
Existing Solution: The existing implementation of config service integrations in portal are available as helper methods as part of the portal code which is tightly bounded to portal module.So if we want to implement it for content service it requires rewr
Configurable Portal Dashboards Reports Architecture
Introduction This wiki details out the architecture of the configurable reports for portal dashboard and also serves as an implementation guide to configure and set up a report. Overview Currently, the data team generates the data for the weekly reports i
Configuration
Configuration service Target release 1.10 Epic Document status Document owner Gouri Shanker Bajaj Designer Lead designer Developers Lead developer QA Lead tester Background Managing configurations is an important concern in any solution deployment involving several services. S
Configure profile fields to be editable
Overview As sunbird platform gets deployed by different users, they may have specific requirement around which profile fields they want to allow user to edit, which fields re mandatory, what is display name for fields etc. Currently we have the ability to
Configuring Sunbird Email Notification in Content service
Background: Currently, Sunbird email service is used to send the notification to the user on different actions in review workflow. Sunbird uses same default email templates for all workflow actions such as publish, request changes. Problem statement: Emai
Consuming DeviceRegister API in mobile app
Introduction: This wiki explains how DeviceRegister API will be consumed in mobile app Background: DeviceRegister API is used for capturing the IP address details and the device specifications on both mobile and web platforms. Problem Statement: DeviceRe
Consumption Architecture
Architecture Diagram consumption_architecture_2.png Component Diagram consumption_block_diagram.png
Consumption Metrics
This document details the setup processes required to get consumption metrics report generation scripts installed and running on a Virtual Machine. This document is split in two stage: a one time setup and maintenance tasks. One Time Setup Git Fork the br
Container - Design
Introduction The container for the OpenRAP 2.0 has been developed on top of ext-framework. The additions on top of ext-framework are: SDK's like Global, Settings & Download Manager While the ext-framework has been designed to add plugins within a single a
Content
Content - external store data restructuring Introduction: This wiki explains the current structure of external store data for content and the proposed changes in the structure to bring consistency. Background & Problem statement: Content-Type Identifier in Neo4J Identifier in Cassandra Version 0 Ve
Content attribution to Organisations
Target release 1.10 Epic Document status Implementation Document owner Shailesh Kochhar Designer subu palamadai Developers Vinaya Kumar B Manzarul Haque Harish Kumar Gangula QA Lead tester Goals Create incentives for multiple organisations to collaborate
Content Copy API specification - For supporting CurriculumCourse
Overview Content Copy API supports two types of copy: 1. Deep Copy and 2. Shallow Copy As per the current requirement Content has to be copied with same TOC but with different contentType. For Supporting this, we are proposing below request structure to s
Content DB Migration
Background: Problem Statement : For existing users, already content DB is created so, categories filed will not be there and we are using content.category1 so, it will throw undefined error Key Design Problem: Update content DB keys BMGS to category1, cat
Content deletion
Background There is a need to provide the option for content delete in the desktop app so that the user can manage the space in his machine and it should be designed such a way that the deletion should be performed in async fashion so that app main threa
Content Discard API specification
Overview Content Retire API retires the Live as well as Draft version of content. It is actually soft delete. The requirement is to discard the edited version of content, but persisting the live version. Content Discard API DELETE - content/v3/discard/{co
Content Meta data filters
At present if want to filter content based on its meta data in sunbird portal,we have set those filters (like mimeType,contentType,createdBy) from portal/client side itself. In certain context content meta data filters should be set outside of client side
Content Player 2.0
Introduction This documents list the design approach which we are taking to rewrite the content player such that For users: Faster load times, great user experience and leaves less memory footprint on the browser. For Developers: parallel development, dec
Content, Itemset and Question Relationship Refactoring
Introduction: Item set should be a collection of questions where questions will have hasSequenceMember relationship with the member questions. Content should have association relationship with Item set. Background & Problem statement: Currently content ha
Content-Player: NPM Package build
Introduction: This document details the content-player npm package build process Background Content-Player is common module/product used to preview/play the content/question in Portal, Mobile, offline desktop, Editors & Question(editors). The build proces
content-player: Telemetry event details for NCERT quiz - PlaySession
Jira Story: Telemetry information to track a play session Instructions A new "play session id" should be created as and when a user starts playing a content. Student/user should able to fill his details before taking the quiz. Instead of introducing new s
Course batch permission design
Overview: Sunbird course batch api is built to manage batches of courses available. There are two type of batch ( Open , invite only). For open batch there is no mentors and is for self enrollment. For invite only batch creator need to add mentors and par
Course Consumption Modalities
Introduction Use-Cases Use Case Description Problem (The problem this use case will solve for the user) User Persona Why (Why users will choose your product to solve their problem, and what differentiates you from alternatives)
Course Dashboards
Course Enrollment Report Background Purpose of this report is to show the course wise enrollment numbers. Users from any tenant can enrol into an open course batch. In this report only include teachers who belong to the same tenant ID as the report viewer
Course Infra - Async Jobs - Implementation Design
Current Design: course-batch-current-design.png Below are the key design problems: Remove ES for user enrolment data and use only Cassandra table. Computation of metrics at Course and CourseUnit Level. Implementation logic to generate AUDIT events. Report
Course Infra - AUDIT Telemetry
Common AUDIT Event Structure: { "eid": , "AUDIT", "ets": , 1592803822, "ver": "3.0", "mid": , "LP.AUDIT.1592803822" "actor": { "id": "<userid>", "type": "User" }, // Context of the event "context": { "channel": "<default_value>", "pdata": { "id": "org.sun
Courses
Courses Infra - Design Current Design Courses Infra Current.png Following are the key problems with the current design: Writing progress updates and completion percentage to ES is not able to scale to the required needs. ES is not build for massive writes similar to Cassandra.
Courses mentors should be able to administer closed (invite-only) batches across Orgs within a tenant.
Background: Courses mentors should be able to administer closed (invite-only) batches across Orgs within a tenant. Problem Statement: The Content creator organisation should be able to invite the members of the partner organisations to take the course. Pr
Creation of Self Assessment from Workspace
Introduction: This document is an approach not from content framework to solve the creation of self-assessment from the user’s workspace Background: Jira issue: https://project-sunbird.atlassian.net/browse/SB-17128 https://project-sunbird.atlassian.net/br
Credits and attributions
Target release 1.11 Epic Document status Document owner Surendrasingh Sucharia Designer Prajna Hegde Developers Lead developer QA Lead tester Goals Allow a creator to give credit to multiple other people registered or not registered on the system Allow a
CSP Configurations - LERN Details
Objective LERN Building block services can be configured different storage services based on the configurations. Config Service name Config name Data products store in model-config Data-pipeline (flink jobs) cert_cloud_storage_type cert-service CLOUD_STO
|
||||||||||||||||||||||||||||||
DDashboard MetricsAPI for Metrics Summary Static data - JSON format
Dashboard Table configuration
Problem Statement The admin dashboard type of reports should be dependent on the tenant. In the admin dashboard Table, all fields are in string formate when fetched from the JSON even though their datatype is number or Date. Because of this, the sorting o
Dashlets Design Doc
Title Dashlet Selector <sb-dashlet> Use Case Dashlets are reporting widgets that can be embedded in any contextual workflow - whether on a consumption, creation or administration screen. Any solution that needs to use dashlets can configure the dashlet wi
Dashlets Page-Wise Configuration Design Brainstorm
Title Dashlet Page Wise Configuration. Problem Statement Ability to inject dashlets widgets into any page via configuration. Solution is divided into 3 phases :- Create Configuration for the Dashlets <CREATION> Linking the page id to the Dashlets Configur
Data migration across tenants
Overview As part of the ticket - SB-9803 https://project-sunbird.atlassian.net/browse/SB-9803?oldIssueView=true, we are required to merge user/content of 2 tenants into 1. Earlier the state had created 2 tenants, both have users as well as content. There
Data Persistence while processing events using kafka/ queues.
What is Data Persistence ? Persistent data in the field of data processing denotes information that is infrequently accessed, not likely to be modified and should be not lost before processing valuable information from it. Why we need Kafka Queues for pro
DataScience AMJ Road Map
1. Use Case: Profanity Filter Problem: Detect profanity words and flag such Content. RoadMap: Feasibility Track (effort: one week) review https://github.com/vzhou842/profanity-check existing methods: look-up based and model-based create positive and negat
Deep link support in Android 12 devices
Background: Deep links help us provide a seamless experience between the Sunbird portal and the mobile application. Assuming the application is installed, when a user taps a link from an email client or WhatsApp, we want the Android device to route the re
Default Profile Visibility Configuration
Introduction This wiki explains the background, problem statement and design to make default profile visibility settings configurable in sunbird Background Default profile visibility settings is set for all users at the time of user creation. The fields w
Deletion of inactive user/Org accounts
Overview : There are multiple user accounts created by states that have never been used/ been inactive for extended periods for time. As states move to officially onboard users (SSO, self sign up etc.), there is a need to clean up these legacy accounts.Th
Dependent Filter
Dependent Filter Design Deployment Steps for Keycloak User Federation Jira Link : https://project-sunbird.atlassian.net/browse/SC-911 https://project-sunbird.atlassian.net/browse/SC-911 Design Doc : Encrypting data stored within keycloak Note: Take back up of keycloak database. Steps : Checkout https://github.com/project-
Design Document: Notify users on critical actions for trackable collections.
This document will help us to achieve the implementation of the notification feature for any specific activity on groups workflow. Background: As per the ticket https://project-sunbird.atlassian.net/browse/SB-24361 https://project-sunbird.atlassian.net/br
Design - Relational metadata to asset linked to a collection
Introduction: Relational metadata that can be added to the relation between an asset and the folder to which it is linked. These attributes have to be stored as part of the relation between the asset and the folder to which it is linked. Some examples for
Design Brainstorm: Migrating all the content's previewUrl to streamingUrl based on the mimeType
Introduction: Video file of all the content with mimeType:video, is streamed and uploaded into cloud store. The streamed file url is getting updated into streamingUrl field of content metadata. Background & Problem Statement: As part of video streaming im
Design Discussion Template
Introduction: Introduction to this wiki page. The blocks this wiki page contains Background: Explain the background or existing structure/design and implementation for this feature/problem. Problem Statement: Explain the problem for which we are preparing
Design document: Activity dashboard
This document will help us to implement the activity dash board for groups Background As per ticket https://project-sunbird.atlassian.net/browse/SB-24224 https://project-sunbird.atlassian.net/browse/SB-24224 we need to show the activity dashboard to the a
Design for a lightweight healthcheck api in portal and content service.
Problem Statement Currently, the health check API is checking that the dependent service is healthier or not to determine that this service is healthy ex: In the portal, the health check is trying to determine that the following service is up and running.
Design for adding org name for 'my courses'
Problem Statement User in sunbird system can see the courses he is enrolled into however it does not reflect the organisation name in the list. There should be enhancement to enable for showing the org name with the courses. Proposed Solution 1 Currently
Design for automated reports from Druid
Introduction: This document describes the design to generate the data for the portal dashboards from Druid OLAP data store and export the report data to cloud storage. This mainly consists of following modules Configure Report API - This API will be used
Design for course batch stats
Approach 1 Nested participant object in one documents Create an index and add settings curl -X PUT http://localhost:9200/cbatchstats/ -H 'Content-Type: application/json' -H 'Postman-Token: a39bca1e-1412-45f2-bf3a-814109bd31c3' -H 'cache-control: no-cache'
Design for easy way to update content
Problem Statement Currently to update the content implementation team needs to make multiple calls, which makes it a difficult process. Additionally there is no auditing in place to track as content was updated by whom. There should be an easier way to up
Design for getting batch status inside my enroll course.
Overview We need to include Batch Status attribute in response of API to fetch user enrolled courses (/course/v1/user/enrollment/list/{{userId}}). /course/v1/user/enrollment/list/{{userId}}?batchDetails=[fields comma separated ]&orgDetails=name,email
Design for One time password (OTP)
sendotp.png Problem statement: As a sunbird system it should have capability to generate and validate generated OTP. As per current requirement OTP can be generated for mobile number or email. Proposed Solution 1: Sunbird will expose a new end-point to
Design for verify OTP
Problem statement: As a sunbird system it should be able to do the verification of generated OTP. Proposed Solution: Sunbird will expose new api to verify OTP. Both Generate OTP and Verify OTP can be a single micro-service. New api structure will be
Design Systems
Design to get list of ongoing and upcoming open batches. Problem statement : Consumer want to show count of upcoming and ongoing open batches for a course. Since course is stored under learning platform and created batch from course are stored under sunbird-LMS. There are two different system and they don't
Design: Last access time for collection & resources
Overview To organise the any order of tractable collection w.r.t user’s last access date and time on the user enrolment list . We have two solution approach. Referenced ticket: https://project-sunbird.atlassian.net/browse/SB-26283 https://project-sunbird.
Design: Addition information on certificate QR scan
Introduction Currently, upon scanning the QR code on the certificate only the user name, course completed by the users plus the completion date is shown to the user. This needs to be enhanced to show the users' profile information so that it can help admi
Design: Display the page wise comments for content editor
Background The page wise reviewer comments for a resource content should be displayed in the content editor. Key design problems Show the reviewer's comments, name, reviewer's profile icon and date for each stage. 3.png Solution 1: Read all the Comment o
Design: Question and QuestionSet - Lifecycle
Introduction: The sunbird platform enabled the content creators to create questions and select multiple questions and create an assessment content using them. But, there is no lifecycle management and review workflow for question object to enable crowed s
Design: Separation of question-set & collection editor
Introduction This document describes the key design problem statement and design for the separation of the question set and collection editor. Jira LINK: Background Currently, both collection & questionSet editors are using a single code base. All the BB’
Desktop app functional automation testing
Introduction: Desktop App testing should be automated by writing integration tests. The benefits of this are the following: Faster Feedback Accelerated Results Testing Efficiency Improvement Higher Overall Test Coverage Reusability of Automated Tests Ear
Developer's Doc - How to set up and use the portal chatbot client library
This document will help you to how to set up and use a portal chatbot client library. Background: This is built as an Angular library. Where this angular library can be integrated into any Angular application(like sunbird portal). Once we integrate this l
Developer's Doc: How to set-up and use Discussions-UI library
This document will help to set up and use the Discussion-UI library. Background: Discussion-UI library is an angular base library that will help any platform to configure and use a discussion forum. In the Sunbird use case, any of the learning sections ca
Developer's Doc: How to setup and use Discussions-middleware
This document will help the developer ( or third-party vendors ) to set up and use Discussion-middleware. Background: This discussions-middleware works like an API proxy. All the discussions-forum related APIs will go via this proxy. Git Repository: https
Dialcode context
Introduction: This document describes how to get the DIAL code context information. Background: At present, the dial-service is not storing any information/context about the DIAL code linked to what(ex Textbook, Textbook unit, etc). So if we want to get t
DIK-4503: Certificate re-issue script
Steps: Download the below script and csv file. chmod +x ./cert-re-issue.sh Fetch authToken(keycloak token) and bearer key Run the below command. ./cert-re-issue.sh <csvfile.csv> <authToken> <bearerkey>
Discover
Design documentation and brainstorming for Sunbird Browse by topic Index of pages
Discussion Forum
This document describes about Discussion Forum architecture Background: Problem Statement: Key design problems: How to create an independent widget that will be having end-to-end functionality How to use existing user service/DB instead of creating new us
Discussion Forum context object configuration
Introduction https://project-sunbird.atlassian.net/browse/SB-22678 https://project-sunbird.atlassian.net/browse/SB-22678 This wiki is for adding the logged in user identifier also some extra info data into sbCategory collection (The one that we are storin
Discussion Forum Doc
Introduction To make discussion within a context and every logged in user can be participated. Architecture Diagram Untitled Diagram.drawio (11).png Hierarchy of discussions The below diagram explains the category & topics created for a Course & Batch. Th
Discussion Forum Load Testing
Introduction This document describes the key design problem statement and probable solutions for Discussion-UI library load testing with Sunbird Portal Background Load testing for discussion-ui https://project-sunbird.atlassian.net/browse/SB-21738 https:/
Discussion Forum Middleware Error Codes
Introduction This document describes how to construct Error codes for all operations Background Jira Issues https://project-sunbird.atlassian.net/browse/SB-21578 https://project-sunbird.atlassian.net/browse/SB-21578 Examples Of Error code PFT_CCRT10 >> PB
Discussion forum notifications
Introduction This document describes the key design problem statement and probable solutions for discussion forum notifications https://project-sunbird.atlassian.net/browse/SB-25091 https://project-sunbird.atlassian.net/browse/SB-25091 . Problem Statement
Discussion Forum: Deployment
it Nodebb Setup To setup nodebb we have to fallow the below steps go to nodebb folder and the execute the commands ./nodebb setup ./nodebb start Install nodebb plugins To install required nodebb plugins using npm Stop the nodebb application by running ./n
Discussion forum: Deployment process for all the services.
This document will help to deploy all the services which are parts of the Discussion forum nodebb (along with the plugins) Discussion Middleware sunbird portal Nodebb: Git repository: https://github.com/project-sunbird/sunbird-nodebb https://github.com/pr
Discussion Forum: Generalisation of Course & Groups integration logic
Introduction This document describes the key design problem statement and probable solutions for Discussion-UI library integration with Sunbird Portal (or any partner application). Background No API exists to create the forum, add privileges, create group
Discussion Forum: Integration
scThis document describes integrating the Discussion library into any application NodeBB Category & Topic creation: The below diagram explains the category & topics created for a Course & Batch. The same can be used for any other types like Group, Quiz, e
Discussion forum: Key processes to enable/disable DF.
This document will help to configure (enable/disable) discussion forum for any of the learning process (i.e. groups, course, textbook, etc.) For Groups: Enabling discussion forums for groups will be done via UI. Now to call the create forum API, first, we
Discussion Forum: NodeBB setup
This document will help to setup, config and use NodeBB Background Discussion Forum library uses NodeBB for for DB related operations. So NodeBB needs to be installed for local development. Local setup of Sunbird-Discussion-UI(playgroung application) Refe
Discussion Forum: Router Approach
DF_router.jpg
Discussion Forum: Telemetry Events
This document details about telemetry events generated from discussion-ui library & how to capture the event Event emitted by Discussion-UI library Interact { "eid": "INTERACT", "edata": { "id": "category-card", "type": "CLICK", "pageid": "discussion-cate
Discussion Forum: Widget Creation
This document will help to create the Discussion-UI library Widgets. Prerequisite: Discussion-UI library to be setup and running. Note: Refer to this wiki for setup: Developer's Doc: How to set-up and use Discussions-UI library Architecture Diagram: Copy
Discussion Forum: Widget Integration
This document will help to use the Discussion-UI library widgets. Prerequisite: Discussion-UI library to be setup and running. Note: Refer to this wiki for setup: Developer's Doc: How to set-up and use Discussions-UI library Steps to use Discussion-UI lib
Discussion middleware session
Introduction This document describes the design of discussion middleware session. https://project-sunbird.atlassian.net/browse/SB-22319 https://project-sunbird.atlassian.net/browse/SB-22319 Problem Statement Storing the required information of nodebb and
Displaying Books In Groups Based On Subject
Introduction This wiki explains that how to display search result based on subject. SB-10221 https://project-sunbird.atlassian.net/browse/SB-10221 Problem Statement Display the books in groups based on subject by using content search API. Proposed Design
Docs Versioning
Download csv in course dashboard page Problem Statement 1: Extend this design to support the download for batches stats upto 1L participants. By default elastic search support max 10k records , in one search query. Use Elastic search scroll api . 'Scroll API ' can be used to retrieve large
Download manager implementation design
This document explains the download manager implementation inside OpenRAP container and the interaction with the plugins and plugin states for a content download with different stages in detail. While downloading a file(content) and the different possibl
Druid Data Model - Collection Summary
Data Model: Dimension In Druid Field In Report Description Data Type 1 content_org organisation Published By or Course Publisher Name or tenant String 2 user_org orgname User Organisation name String 3 batch_id batchid Unique Batch Identifier String 4 col
Druid Data Model - Content Model Snapshot
Data Model: Field Data Type Field in Druid 1 author String author 2 badgeAssertions.assertionId String badgeAssertions_assertionId 3 badgeAssertions.badgeClassId String badgeAssertions_badgeClassId 4 badgeAssertions.badgeClassImage String badgeAssertions_
Druid Data Model - Course Batch
Introduction: This wiki explains ingestion specification for the Course Batch and its related objects to compute required metrics and compose dashboards using Druid. Design: Below are the objects related to course batch Course Course Batch Enrollment User
Druid Data Model - Summary Events
Data Model: Dimension in Druid Field in Summary event Description Data Type 1 ets ets Event timestamp Long 2 eid eid Event Id String 3 ver ver Version String 4 syncts syncts Sync timestamp Long 5 uid uid User Id String 6 context_date_range_from context.da
Druid Data Model - Telemetry Events
Data Model: Dimension in Druid Field in Telemetry Description Data Type 1 ets ets Event timestamp Long 2 eid eid Event Id String 3 syncts syncts Sync Timestamp Long 4 @timstamp @timstamp Sync Timestamp in String String 5 actor_id actor.id Actor Id of the
Dynamic content streaming quality based on internet connectivity for videos
|
Ee-Schooling - BatchesIntroduction Course based learning is enabled in sunbird platform via batches. A course batch enables the following functionality: Enrolling learners into courses Tracking the progress of learners by mentors Open batches that allow any user to enrol for a
e-Schooling - Curriculum Courses
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
Elasticsearch Backup & Restore In Azure and Local Environment
Azure Environment: Backup: Create Azure Storage Account and Blob Container: Log in to the Azure portal and navigate to the Storage Accounts service. Create a new storage account or use an existing one. Within the storage account, create a blob container n
Elasticsearch mapping update job steps
Problem Statement Since we are moving to multi index format and static mapping there should be a way in accordance with CI/CD to update mapping whenever a new field is added as required. Solution Approach A jenkins job can be added to update mapping for i
Elasticsearch Type Mapping
Overview : Type mapping inside elasticsearch can be dynamic or static. Both mapping has it's own pros and cons. For initial usage dynamic mapping is fine, because we won't have complete knowledge of data model and it's usability. But for production, dyna
Elasticsearch upgrade in Sunbird Platform
Problem Statement Sunbird is using ES 5.4.3 whereas other platforms (LP/DP) are running on ES 6.3. Hence the Sunbird ES 5.4.3 needs to be upgraded to 6.3. Solution Approach To accomplish the upgrade we can take below approach Full cluster restart Steps ht
Elasticsearch Version Upgrade: 6.8.22 to 7.17.13
Introduction This document serves as a comprehensive guide for upgrading Elasticsearch within Sunbird Lern [Specifically in userorg, lms and data-pipeline]. We will transition from version 6.8.23 to the more secure version 7.17.13. Overview The primary go
Elasticsearch Version Upgrade: 6.8.23 to 7.17.13
Introduction This document serves as a comprehensive guide for upgrading Elasticsearch within Sunbird Knowlg [Specifically in knowledge-platform, knowledge-platforms-jobs and sunbird-dial-service]. We will transition from version 6.8.23 to the more secure
Email Notification for User addition, Mentor Addtion and removal from a Batch.
Proposed Solution for Release-1.11.0 The proposed solution for Email notification for the batch process is described in the following diagram lms-email.png In the LMS service, we are creating the batch and adding mentors and users to the batch. in the sam
Enable dynamic updation of learners' course progress
Introduction This wiki explains current design of course batches, problems with it and proposed changes to the design and implementation to resolve the current issues and able to handle scale. Background & Problem statement: In current state changes store
Enable player to support scorm
How does SCORM Work SCORM is a specification that defines How distributable learning content should be packaged How the content can be embedded in a LMS How does the embedded content communicate with the LMS The standards / specifications of this communic
Enable Question-Sets for video content
The document has moved. Please follow this link Enable Question-Sets for video content
Enable transcripts for video content
Introduction This wiki explains the design and implementation of the enable transcriptions for video content. https://project-sunbird.atlassian.net/browse/SB-26446 https://project-sunbird.atlassian.net/browse/SB-26446 Key Design Problems: How to store tra
Enable transcripts(sub-title) in video player
Introduction This wiki explains the design and implementation of enabling the transcripts in the video player. Key Design Problems: How the player should enable/render the transcripts files for the selection. How to handle the transcripts-related changes
Enable user account updates as part of SSO
Problem Statement Related Jira Task - { "jti": "<random_string>", "iss": "<issuer_id>", "sub": "<user_external_id>", "aud": "<base_url>", "iat": 1498556656, "exp": 1498560256, "name": "<name_of_the_user>", "state_id": "<channel_name_of_the_tenant>", "sch
Encrypting data stored within keycloak
Jira Link: SC-911 Encryption of data in keycloak https://project-sunbird.atlassian.net/browse/SC-911 Overview Sunbird uses Keycloak as tool for identity management services. The default storage mechanism stores the user-data in plain format within its loc
Enhancing logging in Sunbird Desktop App
Background: Currently, Deskstop App has a logging system in place. That is configurable and allows storing of backups on log rotation. Desktop App stores all type('all' | 'trace' | 'fatal' | 'error' | 'off' | 'info' | 'warn' | 'debug') of logs in app.log
Environment Stability - RCA
ETL job not being executed for 1.14 pre-prod deployment - steps were missed though provided in the deployment tracker Swarm update due to change in a particular node by Azure Refactoring of the variable values (500 variables to 60 variables), Communicatio
EQB Architecture
Background Problem: Questions are fundamental to learning -- both in terms of assessing learner's progress as well as in terms of generating curiosity. Boards like CBSE have repository of questions, which are so far accessible to just the affiliated schoo
Error log sync in Sunbird Desktop App
Overview: Currently, Deskstop App has a logging system that stores the log in the file system. These logs have the type of log, error message, time-stamp. We can debug the errors locally by accessing the log files. Problem statement: As part of the er
Error Message Localisation
Problem Definition: All the error messages coming from the platform should be localised based on the configured language. Key area to be analysed: Error Code Naming convention How to be called from different module How to segregate different code Error Co
ETB 2.0 - Reserve Dial-code API specification
Overview As per the current design discussion, LP will be providing two APIs for reserving the dialcodes for textbook and releasing a specific number of dialcodes from the textbook respectively. For storing the reserved dialcodes list against a textbook,
ETB 2.0 - Upload TOC, Update TOC & Download TOC using CSV
Overview : Textbook Creator can upload a pre-defined formatted csv file with details of TOC hierarchy against a Textbook id. System should: Generate the TOC hierarchy using csv file. Download complete textbook hierarchy in csv format. Update TOC unit meta
ETB 2.0: LP & DIAL code
Target release OND Epic Link to related JIRA epic or feature Document status Document owner Mohit Garg Designer subu palamadai Developers Rayulu Villa QA Lead tester Goals DIAL code request to be generated from the system using ETB editor. Background and
ETL job to add state, district of non custodian user into user DB
Overview As part of enhancing the user profile data and having the location data available along with user profile, we need to update the existing user location data. Currently we allow custodian org users to update their state and district after register
Event based system
problem Statement Current system is not event driven. And all background jobs are handled by one or more actors , it can have following problems: Each background job is calling different actor and doing predefined set of actions. (So it's tightly coupl
Event-based background jobs
Problem statement : Current system is not event driven. And all background jobs are handled by one or more actors , it can have following problems: Each background job is calling different actor and doing predefined set of actions. (So it's tightly cou
Events on Sunbird
This document covers the design and modifications needed to support events related use cases in Sunbird. Below use cases have been considered when creating the spec A single event listed (eg: a ask me anything session) A collection of events (eg: a multi-
Experimentation Capability on Portal
Background: Currently, Sunbird has one portal instance that has all the modules and has multiple tenant support. If a tenant request any changes to an existing feature or a new feature, all tenants will get these changes as well. Problem statement: Sunbi
Extensibility
The extensibility architecture in Sunbird allows creating plugins which hook into Sunbird's core and provide the means to extend Sunbird with new functionality.
|
||||||||||||||||||||||||||||||
FFCM Notification FlowTo broadcast a global level notification to all/specified users for providing set of information based upon the sunbird platform. Registering the device to Notification server Registering device for receiving the notification broadcast from notification s
File lists
File URL Validation Introduction This wiki explains the URL validate and get metadata API specification. Background As part of upload file using Url link, there is requirement to validate the URL (youtube, google drive, azure and aws). Based on the provider of the URL we wil
Fill in The Blank - Multiples and Variations - Nov, 2018
Grouping of Blanks JIRA Issue https://project-sunbird.atlassian.net/browse/SB-8987 https://project-sunbird.atlassian.net/browse/SB-8987 source document: https://docs.google.com/document/d/1KSM125In96unii6c-8sKzBEpli8quufp1UJywX4J4bo/edit https://docs.goog
Filters in admin dashboard
Filters in Charts Background Purpose of this report is to add filtering capabilities to charts in the admin dashboard so that users can narrow down the data set to their time period/ labels (Course name , class , subject name etc). Proposed Solution: To r
Flink jobs for certificates generation and processing
Overview This wiki details the design approach on issuing/generating certificates via flink job. Design The current certificate-generator samza job and cert-service(generateCertificate) API is refactored as flink jobs. Below diagram depicts the flow. desi
Form API's
Update on Form Service Schema Current Column Proposed Columns type (varchar) type (varchar) subtype (varchar) subtype (varchar) action (varchar) action (varchar) component (varchar) component (varchar) root_org (varchar) root_org (varchar) framework (varc
Framework Details.
Background: Presently BMGS is hardcoded for Framework request. If we want to change this label as category1, category2, category3 and category4 then we have to change the framework request. Jira ticket: Problem Statement : 1.What is the new API request fo
FTB Data Model Design
Data Model image2018-12-7_16-9-25.png Example 1 { "data": { "question": { "text": "Complete the sequence: 21, 23, __1__, __2__, 29", "audio": "", "image": "" }, "answers": [ [ "25" ], [ "27" ] ], "data":{ "expAnswers": [ [ "25" ], [ "27" ] ], "expAnsIndic
Fuzzy Search and Nearest Neighbors
Problem: Typical relational database systems are set theoretic in nature. Effectively, the query under consideration defines a set, and each result in the query is a member of that set. These sets are not fuzzy, meaning that a record (a row in a table) be
|
GGet all Channels for an instance - API Implementation DesignThere should be an API available to get all the available channels of an instance which will be helpful for effective content filtering based on channels. The request structure of the api should be like below: POST /v1/channel/list { "request" : { "sta
gh-pages branch
This branch will store the generated site Only the updated version folder will get updated. latest stable/ & 1.9 ( latest version no.) folder will be duplicate symlinked. Purpose of creating latest/ folder is that if someone refers the latest URL somewhe
Google Sheets – FeatureId list used for the release items/tasks
Link Google Sheets: FeatureId List https://docs.google.com/spreadsheets/d/1a1rsveNFKCHZGG5F35OnxI6O-lgtOFD3AlCJPXhmOpE/edit#gid=0 Date Aug 30, 2019 https://accounts.google.com/favicon.ico docs.google.com/spreadsheets/… https://docs.google.com/spreadsheets
Google Sign in Flow in Portal
Overview: User sign in to Sunbird/Diksha is handled by the portal. Currently, the portal uses Google plus API to fetch the user profile when the user tries to sign-in using google. Problem statement: Google has shut down Google Plus API from 7 March 2019.
Groups: Tech Documentation - Add activity
This document will help to understand how to add an activity in a group Background We can enable any activity type for a group We can configure form API for that Form creation This form will be used to populate the activity types that can be added for a g
|
||||||||||||||||||||||||||||||
HHardcoded BMGS removal in Sunbirded Mobile AppBackground: Presently Sunbird uses hardcoded of BMGS. If User wants to use this application for hospital or different organisations, Then we have to remove hardcode of BMGS and make it as dynamic. Jira ticket: https://project-sunbird.atlassian.net/jira/so
Hawkeye Superset Automation
Objective Hawkeye superset is used to generate Analytics job config and report service config. From the initial implementation Hawkeye code was built on top of the exisiting forked repo from Apache superset. From this automation implementation, superset c
Hide buttons 'Sign in with Google' and 'Sign Up' for older mobile app version.
Problem Hide buttons 'Sign in with Google' and 'Sign Up' for older version mobile app on the login page. Solution This can be done by passing the query parameter with the login URL and displaying buttons only when the parameter has expected value. Imple
Hosting
sunbird.org website will be served from gh-pages of sunbird.org-web . The proxy server will map this gh-pages to sunbird.org. www-qa.sunbird.org website will be served from the www-staging folder of sunbird-docs-qa s3 bucket. The proxy server will map thi
How to define the schema and context for a DIAL?
How to define the schema and context? There are two ways to define and upload the schema in blob. Fork sunbird-dial-service https://github.com/project-sunbird/sunbird-dial-service/schemas repo Create the your own repo and follow the same structure of sche
How-to articles
HTML & CSS Guidelines (v1.0) Google Doc (Contains same) - https://docs.google.com/document/d/1RqZqAQAmUhJqaMCL26iIvx9MS03MxKbby9My_Fbt1Do/edit# https://docs.google.com/document/d/1RqZqAQAmUhJqaMCL26iIvx9MS03MxKbby9My_Fbt1Do/edit JIRA Card - https://project-sunbird.atlassian.net/bro
|
IImage Generation APIProblem Statement QR code image generation POC is done in Java using Zxing library. Design a way to expose this usecase for consumption. Approach 1 Package the code as a executable jar Input - Predetermined set of parameters in a String array Output - Gen
Implementation - Knowlg player app integrate with player V1
Background Currently, we are showing pdf, epub, and video players in the knowledge player app. To display the interactive, HTML, h5p, and youtube content, we need to integrate the v1 player in the knowledge player app. Design To integrate the v1 player fo
Implementation design for Location Capture: Device and User
Introduction: This documents describes the design for capturing Device and User location. This design requires following changes Get Device Profile API - To return back the IP resolved location for the device. Device Register API Enhancements - API to sav
Implementation Design for Notification Service
Target release 1.12.0 Epic Document status Document owner Loganathan Shanmugam Design Link Notification Service https://project-sunbird.atlassian.net/wiki/spaces/SBDES/pages/654409823/Notification+Service Developers Rajeev Sathish Loganathan Shanmugam May
Implementation design for updating the district details from derived location for District Level Report
Introduction: This document describes the design of updating the DRUID query in Analytics script for the District Level Report. PRD Link : District Level Report Implementation Design Link for Derived Location : Implementation design for Location Capture:
Implementation Design of Question Editor and findings
Confluence Doc: Design: Separation of question-set & collection editor https://project-sunbird.atlassian.net/wiki/spaces/SBDES/pages/3181051923/Design+Separation+of+question-set+collection+editor As per the above document, we’ve finalized the following ap
Implementing Gzip compression
Overview Sunbird APIs are consumed via mobile app as well as web application, where in even web-application can be loaded from mobile or tabs. Most of the api is based on exchange of request/response in json format. Motivation is to reduce the size of res
Improve logging quality
Jira Ticket: Overview As part of the ticket we need to improve overall logging quality of sunbird platform. Currently, we face problems in two particular areas: To change logging level, property file need to be changed, which means we need to build & depl
In app notifications
Problem Statement: The broadcast message at the app launch will be used in the below following cases for ex - Examples of use: 1. When Sunbird instance goes down, show a message about (the reason and) when it's going to come back up. 2. When Sunbird insta
Indexing Content Model to Druid
Introduction: In this wiki, we are going to discuss methods to index Content model to Druid and its challenges. Since the content model is not time series data, updating the indexed data in Druid is not possible and this would pose challenges to query dat
inQuiry - Add New Cloud Storage - Implementation Changes & Testing
Background This document explains what components of Sunbird inQuiry (version: release-5.2.0) uses Cloud Storage and how to integrate new Cloud Storage. inq_2.jpeg Above diagram shows inQuiry components (marked in yellow colour) and its connections with c
inQuiry - provision & installation script
Background: inQuiry need to document all steps for server installation to provide ease of installation experience for adopters. Problem Statement: As of now, below problems identified in scripts and variables: inQuiry provision & installation scripts are
inQuiry- [Design]- API Implementation of QuML Multi-language
Background: inQuiry need to enable multi-language support for Questions & QuestionSets where data like question content (body), hints, instructions can be stored in multiple language. So that user can select the language of their choice (user may select o
inQuiry: CSP migration & verification steps
As part of CSP migration below data will be migrated: Graph DB: "appIcon","posterImage","artifactUrl","downloadUrl","variants","previewUrl","pdfUrl" Cassandra DB: hierarchy column will be migrated in questionset_hierarchy table. None of the external data
inQuiry: Release-5.2.0 Configuration details
Configuration Added: Please check the configuration files and add below configuration. For variable information, Please refer to Variable Section. assessment-service: cloud_storage_container: "{{ cloud_storage_content_bucketname }}" cloudstorage { metadat
Installation
Installation CI - Requirements Some of the steps in sunbird installation that can be automated. Creation of VM in Azure or AWS with the minimum requirement Note down the private IP address and also make sure that the basic required ports are open and are accessible. Install the Minimum
Installation CI and Sanity Testing - Implementation Design
Target release 1.9.0,1.10.0 Epic Document status Document owner Rajeev Sathish Designer Lead designer Developers Lead developer QA Lead tester Goals To Make sure that an Adaptor is able to install Sunbird Server Installation by following the Documentation
Issue Certificate To State Teachers/ All Users
Problem Statement : Certificate issuer should be able to choose whether the certificates are issued to only state teachers or all users. Solution Approach : Solution 1 : While adding a certificate template to a course-batch, we can add a new sub-section
|
||||||||||||||||||||||||||||||
J |
KKeycloak and Kong AnalysisDoes Kong go to the DB for every jwt token validation No, One consumer can have multiple keys and it's going to DB only once per key and later use the values from cache. Kong tables Consumers table id custom_id username created_at 4b189b85-a560-40f9-99
Knowledge Platform License Support
Problem Definition Knowledge Platform should support multiple types of License. License should be passed by the Creator of the content. If the license is not passed by user, default license for the tenant should be considered for the content. If tenant is
Knowlg - Add New CSP Storage - Implementation Changes & Testing
Background This document details the integration points for any new CSP provider with the Sunbird-Knowledge platform. (Latest as of December 2022. Sunbird-Knowlg release-5.2.0) https://imgr.whimsical.com/object/QDRp2uJZiyjGbcraBaP6nj In the above diagram,
Knowlg - CSP & CNAME
CNAME: CNAME records can be used to alias one name to another. CNAME stands for Canonical Name. All the Data in the DB & response should be CSP agnostic. Presently the data stored in DB & API response is having the CSP provider details. Presently we are s
Knowlg - Domain Agnostic Data
Introduction This wiki explains the current format of the absolute path stored in DBs (Neo4J, Cassandra, ES) and the proposed design to make it domain-agnostic. Background & Problem Statement Knowlg uses URL storage in various scenarios to save and access
Knowlg mirco-services: Open questions
Background Present(in the year 2022) the sunbird knowledge setup is not adoptor friendly to setup/deploy. The reason is because of the cost involved in setup & complexity of the multiple DB’s invovled. How to make knowlg micro-services easy to install & b
Knowlg Mobile app and website players features interoperability
Problem statement The current Knowlg mobile app is capable of playing the static content added to the app as data and it doesn’t have the option to play the content created on the Knowlg website all the players integrated into the mobile app are also capa
Knowlg player app for Mobile PDF player
Introduction This wiki explains the design and implementation of pdf players for mobile devices.. Background: As of now we are experiencing content players player as part of the sunbirded mobile app , to make our building block independent and to test mob
Kong App ID Plugin
Problem Different application consuming the API’s but the backend has no idea who is consuming it and from where the request coming is from. Solution This problem can be solved if an application sends its ID with an API request. Implementation To impleme
KP documentations
|
||||||||||||||||||||||||||||||
LLaunching of Experimentation on Portal.Background: Currently, Sunbird has one portal instance that has all the modules and has multiple tenant support. If a tenant request any changes to an existing feature or a new feature, all tenants will get these changes as well. Problem statement: Sunbi
Learner Service Data Models Comparison
The purpose of this document is to review schema of data synched between Cassandra and Elasticsearch by Learner Service. Also, this would serve the purpose of identifying unused or irrelevant fields that can be removed. The fields requiring discussion are
Learning Platform
Licensing and Attribution on DIKSHA for Resources and Textbooks Problem Definition: This story defines the appropriate licensing and attribution details to be provided at the time of content creation and to be displayed at the time of content consumption on DIksha. Current structure of metadata: As per current structu
Life of a Plugin
Sunbird provides an extensible core – this allows new functionality to be built independently of the core development as a plugin. The plugin can be installed into Sunbird and run as part of the core application. This document covers the life of a plugin
Lightening of Spine Ecar
Introduction This wiki explains the provisioning of light weighted spine ecar. Background For every collection type content, knowledge platform generates spine ecar. It is bundle of menifest.json (details of the TextBook and its units) and folders for all
Linking content to ETB through a CSV file
Link to issue: Problem Statement As ETB content is done through CSV upload, there are chances of issue in the input data. So before processing the data it is desirable to validate the data before starting the linking process. Here is the flow which valida
List the Bookmarked and Recently Played Content in Mobile App
Problem Statement: User can can bookmark the content. Content/collections inside of other collections (include courses, textbooks etc.) can also be bookmarked. User can see recently viewed content. Only leaf-node content that was actually PLAYED should be
LMS Service
Loading of spine optimally (mobile app) Introduction This wiki explains the downloading the light weighted spine ecar if available. And downloading of thumbnails when user visit the detail page then consider those downloaded thumbnail as a part of exported ecar. SB-7105 https://project-sunbird.
Local Notification Configuration Data Structure
Overview Local notification purpose is to notify users to sue the mobile app for better learning experience. Here user will get notification on timely basis, and the notification will be purely locally generated. For this, when the user installs the appli
Lock Service
Introduction This page explains the design of lock service and types of locks that are possible with mechanism to lock a resource and unlock it with different possibilities. Background When a user want to lock a resource if we take an example of a content
Login Flow In Mobile App
Overview: Currently sunbird supports Google, SelfSignUp and State state account for user registration. In case of state user, even though they already have a state account they need to register in sunbird. Problem statement: When launch the login page u
LR-122: Lern repo and pod name correction to match the component name
Introduction Currently all the component names, repo names, pod names, and service names are not in sync with respect to naming. Background & Problem Statement Adopters are confused because the names are not in sync. e.g., currently sunbird-lms-service is
LR-324: BatchService: Refactoring of SB Lern Batch Service - Druid Dependency
Introduction This wiki explains how to decouple Druid service calls by using the Sunbird-Obsrv API service. Background & Problem Statement Currently, the LERN Batch Service connects directly to the Druid data store to fetch collection summary aggregate da
LR-325: DIAL Service QR Code Image List
Introduction This wiki explains the design for fetching QR code images via DIAL Service Background & Problem Statement At the moment LERN Batch Service is connecting to cassandra ‘dialcodes.dialcode_images’ table for fetching QR Code Image URLs and also r
LR-556 Local setup of LMS - Ubuntu & Mac - Mock service setup
Introduction This wiki explains how the content mock API service is used to make the development environment seamless and easy to start working on, without relying on the content service APIs. Background & Problem Statement Right now, the LERN Batch Servi
|
MMake Content Review Checklist configurableBackground: Make Content Review Checklist is not configurable in the portal. Problem Statement: Content Review Checklist is not configurable in the portal. Proposed Solution: It has to be made configurable. Following are the different levels of configurat
Manage Learn - Add New CSP Storage - Implementation Changes & Testing
Context This document details how to enable any new CSP provider for Manage Learn capabilities which is part of Sunbird Ed Manage Learn capabilities currently support Azure, AWS, OCI, and GCP ML Core Service interacts with cloud storage for upload/downloa
Mapping type removal in Elasticsearch
Problem Statement Mapping types has been deprecated in Elasticsearch https://www.elastic.co/guide/en/elasticsearch/reference/master/removal-of-types.html and are up for complete removal in future releases. To accommodate this, There are changes required i
Master Key APIs
Background Currently content update is done by the user who created it which creates problem and is complex in scenarios where an admin want to update content by retired user. There should be an easy way to allow users to update content at the same time i
Menu configuration deploy to blob steps
This wiki help QA team to verify below ticket and also https://project-sunbird.atlassian.net/browse/SB-21295 https://project-sunbird.atlassian.net/browse/SB-21295 This below steps need follow to get deploy/run with following steps: Step 1: Modify the conf
Menu options configurable - Dev-Ops CD flow development
Introduction: Makes chatbot menu options configurable so it can easy to maintain without a dev engineer. So we can add/edit existing menu options. It has the following advantages: It will help with a faster deployment process. Quick change based on the re
Merge Course Batch Data - Implementation Design
Impacted tables - content_consumption, user_courses Data Model batchid text, userid text, active boolean, addedby text, completedon timestamp, completionpercentage int, contentstatus map<text, int>, courseid text, datetime timestamp, delta text, enrolledd
Messaging Interface
Target release Epic Document status Draft Specification Document owner Shailesh Kochhar Contact Shailesh Kochhar, Pramod Verma Overview Different kinds of collaboration possible Real-time, syncronous Threaded conversations, asyncronous Q&A, asyncronous Th
Migrating Badgr from V1 to V2
Download and install PostgreSQL (https://www.postgresql.org/download/). https://www.postgresql.org/download/). Create a database using pgAdmin 4 (e.g. ‘badgrDB’). Install virtualenv. sudo pip install virtualenv virtualenvwrapper Run following commands to
Migration from QUML 0.5 to QUML 1.0 version
Requirement Old 'PracticeQuestionSet' contents created on the platform do not show print options in the application. Such 'PracticeQuestionSet' are to be modified to show print options. Solution To achieve this, Questions should be updated in QUML version
Migration guide for new tables for courses enrolments(release-3.1.0)
Overview To reduce the usage of elasticsearch, the cassandra schema for user enrolments and course consumption were re-structured. Please follow the below steps to migrate the existing data needs to be migrate to the newly created tables. Steps to Follow:
Migration script for svg templates (release-3.4.0)
Overview As of release-3.4.0, all svg template creation and consumption is done using asset APIs. This document talks about the APIs to be used to migrate the existing svg templates. Steps Create the svg template with same identifier and name, with below
MMCQ: More than one correct answer for Multiple Choice Question
Overview: This page explains the design of MMCQ. Currently, MCQ supports single answer selection. But MMCQ plugin to allow users more than one correct answers the multi-choice question to the stage. Problem Statement: Statement 1: Since current MCQ imple
Modals
Invision Designs https://app.invisionapp.com/d/main#/console/16496654/342077612/preview https://app.invisionapp.com/d/main#/console/16496654/342077612/preview ng2-semantic documentation https://edcarroll.github.io/ng2-semantic-ui/#/modules/modal https://e
Multi-Lingual Support
Objective Achieve multi-lingual support in inQuiry Fields that needs multilingual support body answer instructions feedback hints User Flow Scenario 1 : Create and consume questions & question set in any language Creator / Editor A dropdown will be presen
Multilingual UI / Localization
Document status Document owner Lakhan Mandloi Developers Lakhan Mandloi & Aman Kumar Sharma Related JIRA cards Background As more states/tenants are coming on-board, user interfaces needs to be translated as per the requirements. Basic Assumptions Engli
Multiple Certificate Templates for Course
Problem Statement : Course Creator should be able to attach more than one certificate template to a course or course-batch so that users receive different certificates based on the defined filter criteria for each template. The creator should also be able
|
||||||||||||||||||||||||||||||
NNavigation plugin refined layoutOverview: The following wiki describes the existing problem/Issues with navigation plugin and different ways to fix it. Problem statement: To design the navigation plugin in such a way that, navigation buttons could be placed at any desired position with
NCF to All Frameworks in Portal
Target release 1.13 Epic Document status Document owner Harish Kumar Gangula Background Today, the generic portal and the custodian org has NCF framework as the default framework. This isn't ideal because the NCF framework is a catch-all framework which d
NCF to All Page - Mobile
Target release 1.13 Epic Document status Document owner Anil Gupta Background Today, the generic portal and the custodian org has NCF framework as the default framework. This isn't ideal because the NCF framework is a catch-all framework which doesn't hav
Neo4J Causal Cluster Analysis and POC
Introduction The HA cluster of neo4j is a master-slave cluster with single master node which handles all writes. Due to the continuous increase in number of writes to this node, there is a high possibility of master node going down. Also, single master ac
New dynamic forms for Academic and Non-Academic content
Background: Design link:- https://whimsical.com/Swkqpz6rnePYg9nPEFjv64 https://whimsical.com/Swkqpz6rnePYg9nPEFjv64 Jira link:- https://project-sunbird.atlassian.net/browse/SH-364 https://project-sunbird.atlassian.net/browse/SH-364 Problem Statement: Show
Nodebb mention plugin update
After updating the nodebb version to v1.18.6 we have to update the nodebb-plugin-mentions. Follow the below steps to update the nodebb-plugin-mentions. Step:1 Login to nodebb with admin credentials. and open admin page. image-20220113-043525.png Step:2 Go
Notification Service
Target release 1.12.0 Epic Document status Document owner Rajeev Sathish Designer Lead designer Developers Rajeev Sathish Loganathan Shanmugam Mayank Morya QA @QA Goals To build a Notification Service which will be independent service and any other servic
|
OObsrv SandboxThe following is where you can find documentation for data center installation of Obsrv. (Obsrv cannot be installed on a laptop and it is not meant to be) https://github.com/ManojKrishnaChintaluri/Community/blob/update-doc/use/obsrv-deployment-using-helm
Offline course progress tracking
Track course progress when the user is offline and sync up with the server when internet is available. Current Implementation - The current implementation is completely online, where the content is consumed completely in a course after the content is clos
Offline desktop app windows packaging
This document explains the step by step process to create the exe file for offline desktop app for windows operating system Pre-requisites Minimum windows version - Windows 7 Minimum RAM required - 2GB(Should show warning if the RAM size is less than 2GB
Offline Desktop Application
Configuration Installation Following are the minimal configurations required for installing the offline desktop application. All of the below configuration properties will have default values and are prompted during installation. APPLICATION_PORT=9000 DB_
On boarding
Context The current desktop application is generic for all states - and a user has to spend time filtering through a set of boards, mediums, classes, and subjects every time they land on the app to get content that is relevant for them to solve this probl
On logout from a specific tenant, redirect to the tenant landing page instead of the generic landing page.
Background In Sunbird, if tenant is configured, for a logged in users, when they logout they are redirected to the generic landing page, instead of tenant landing page because the default keycloak logout function generates the logout URL as index page of
Open batch un-enrollment design
Overview: As of now open batch is allowing user to do the enrollment , but there is no option for un-enrollment. Problem Statement: Allow user to do the un-enrollment from open batch , if batch is not closed or user haven't completed it. Proposed So
Open for enrollment course batch test to supporting 100K Participant :
This documents is about the POC done on limitation of course batch. By term " limitation of course batch" here we mean how many participants can enroll in an open-batch. We only considered the limitation for storing and retrieving data from a course batc
OpenRAP 2.0 - Architecture
Operation Optimize docker image for Sunbird LMS service Overview The current size of docker image of sunbird-lms service is approximately 1.16-1.17GB, But the compressed JAR of learnin-service having max size 250MB approx . We have to find the approach to optimize the docker image .This can be done by removin
Organisation/User Configuration
Problem statement: As of now organisation upload sample file is static file , so changes for any attributes required changes in portal as well. We need to make sample file generation as dynamic. The reason behind making file generation dynamic is , diffe
OTP API Throttling
Overview We need to restrict number of OTP message generated for particular e-mail or mobile. Purpose is simply to avoid misuse through Approach 1 Create one table, otp_throttling with columns (type, key, count) Each time generate OTP is called: Check if
Ownership of Aggregate content (course, collection, book)
Introduction This wiki explains the design and implementation to provide attributions to the entities to whom it belongs to. Background When a content is created it has three metadata properties which point to the entities involved in creating the content
|
||||||||||||||||||||||||||||||
PP2: Telemetry 'Interact' data for Library/Resources/Courses tabBackground In Sunbird for a logged in user, when the user Clicks on 'Library tab', as of now only the 'Impression' data is generated, the requirement is to generate the telemetry for click ('INTERACT') on Library and Course tabs Proposed Solution INTERACT
Page Assemble Api
Problem Statement : AS page api is constructed with list of sections. So before creating page user need to first create sections and then associate those sections with page. As of now all page api is public , so without any key it can be acc
Page Assemble API For ordering the Courses
Once LMS is deployed, please follow below steps. Please note, the below curls are pointing to dev env Run Neo4jElasticSearchSyncTool jenkins job with below settings -> command: syncbatch -> parameters: --objectType batch-detail-update -> to update all cou
Page Management
Design for Page Management.
Partial Cassandra Writes
Overview This document contains observation on Batch execution with different configuration for partial writes. Tests and Observations For testing different scenarios keyspace and table created CREATE KEYSPACE test WITH replication = {'class':'SimpleStrat
Platform Components
Player iframe integration - List of events and Data Introduction: Player integration in sunbird-portal data exchange and telemetry log using window.postMessage() and window.addEventListener() Problem statement: As per the web standards, the communication between iframe and window should be done via post me
Players Mandatory & optional configuration
Introduction Currently, to play the contents we need to pass all the config data to the player. In this config there are some mandatory and options fields. This wiki explains those mandatory and optional fields. PDF player configuration The following conf
Portal : Form Configuration Object
Schema definition Schema { "title": "Portal Form configuration schema - Example - Home page", "description": "The schema comprises the entire JSON document for Home page and associated sections", "type": "object", "properties": { "index": { "type": "integ
Portal config source setup - Design
Story link : Existing Solution In the existing config service integrations of portal by default config service was set as primary config source by default and it will fallback to environment variables configuration in any of the following cases: if the e
Portal telemetry events
Portrait & landscape mode of player Introduction Players should render in portrait and landscape mode both and this functionality should be able to verify in web portal. Background: Currently we are verifying this portrait and landscape mode in mobile devices only. There is no such function
Postman environment variables
Link docs.google.com/spreadsheets/… https://docs.google.com/spreadsheets/d/1EMHyzgYL8NSvlv8DePZyn8pCgpBLoiHbxJx_bqetSc0/edit#gid=342081003 Date Aug 24, 2022 https://docs.google.com/spreadsheets/d/1EMHyzgYL8NSvlv8DePZyn8pCgpBLoiHbxJx_bqetSc0/edit#gid=34208
PR Build
Whenever there is any pr request on any of the version branch, this build will be triggered. that particular pr changes will be built and it will be deployed to pr site Site generation process Pull pr code pull theme code merge code as per the Jekyll gene
Product requirements
Profiles Switching Introduction: This document describes the design approach of creating and switching of Managed User’s account Background: Jira Issue: https://project-sunbird.atlassian.net/browse/SH-68 https://project-sunbird.atlassian.net/browse/SH-68 https://project-sun
Program Configuration
Creation API curl --location --request POST 'https://dev.sunbirded.org/plugin/program/v1/create' \ --header 'Content-Type: application/json' \ --data-raw '{ "request": { "config": { "_comments": "", "loginReqired": true, "framework": "NCFCOPY", "roles": [
Program list API
Overview This document is to provide information about the program list API’s request and response. API Spec A. Programs excluding org nominations [All projects] - contrib admin POST: program/v1/list { "request": { "filters": { "nomination":{ "organisatio
Program-service: wrapper API for open-saber to reduce API calls
Overview This document is to provide information about the user list API’s request and response. Problem To get the user profile details currently three API’s getting called First API calls to get the organization open-saber id by Diksha organization id.
Programs portal: Architecture
Programs portal is to launch the programs using programs configuration. Programs Configuration: Architecture diagram: https://drive.google.com/file/d/1mZNG8UkX3IeEnVqLiKaSZbIUrnx8vGFn/view https://drive.google.com/file/d/1mZNG8UkX3IeEnVqLiKaSZbIUrnx8vGFn
Project plans
Project task report blueprint Proxy Server A Nginx proxy will be needed. Wildcard DNS pointing to the proxy server will be needed Reason for proxying sunbird.org http://sunbird.org (Marketing website) - We can set Permanent rewrite URL with HTTP status 301 302 from sunbird.org http://sunbird.org t
|
QQR Code SpecificationsSize of the QR Code is determined by: Length of the data to be encoded Error correction level (L, M, Q, H) Pixels per block Margin (White space around QR code) Following options can be provided to the user w.r.t the text embedded in the QR code image Text
QR Image Generation
QR Code Specifications Image Generation API Samza Job
Question list API spec
POST /question/v1/list Request Body { "request": { "search": { "identifier": string[] } } } Response 200 { "id": "api.question.list", "ver": "1.0", "ts": "2021-02-02T19:28:24ZZ", "params": { "resmsgid": "8b75d237-1028-4e38-a94a-9ff4ca784d76", "msgid": nul
|