/
Course batch permission design

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 participants. As of now we can add mentors to a batch, but we can't remove it. There is no way to remove added mentors/participants from a batch. 

Problem Statement:

  How to add permission to the mentors, so that they can manage the batches.  

  As requirement has changed , so there is no concept of permission , all added mentors will have default access of batch edit. So no changes required for handling permission.

Proposed Solution 1:  

      Inside course-batch table a new map will be added , that map will hold userId and permission details. 

Changes in create batch api: Will add  a new field .

  •  permissions type  (Map)

 Request :

{
"request":{
"courseId":"courseId",
"name":"batch logical name",
"description":"about course batch",
"enrollmentType":"invite-only",
"startDate":"start date",
"endDate":"enddate",

"createdFor":[
"list of org ids"
],
"mentors":[
"lsit of mentors"
],

"permissions": {  // new field

          "userId":["permissionList"]

        }
}
}


   Changes inside course batch table:

           1.1 Column name permissions type Map <text, bit> 

ProsCons
  1. consume less memory
  1.  Overhead of converting bit roles to user friendly string during sending response
  2.  System need to have mapping for bit to string 

             1.2 Column name permissions type Map <text, text> 

ProsCons
  • Permission will be super set of lower permissions 
  • No overhead of permission value conversion at response time
  • No extra mapping 
  • increase in the additional request parameter 
  • Increase complexity to define permission subset 

           1.3 Column name permissions type Map <text, List<text>> 

ProsCons
  • Permission will contains the list of all permissions available to mentors
  • Easy to Manage , any time some permission can be revoked or added. 
  • increase the additional request parameter 
  • it will take little more storage

Solution 2 :

   Change existing request structure , to support permission list, As of now we are taking mentors as list data type , now it will become map that will support mentorId and it's roles.  

 Request :

{
"request":{
"courseId":"courseId",
"name":"batch logical name",
"description":"about course batch",
"enrollmentType":"invite-only",
"startDate":"start date",
"endDate":"enddate",

"createdFor":[
"list of org ids"
],
"mentors":
         {

          "userId": [list of role]

         }

}
}



  Change the structure of mentors object and store data in same table.

ProsCons
  • clean request structure
  • Data migration required 
  • Elasticsearch will have issues for changing data type
  • Need to create V2 version
  • V1 response structure need to be maintained.

Alternative 1Storing mentor permissions in new table 

ProsCons
  • Separation of permission and batch  
  • Increase Db read/write operation 
  • Additional development effort for maintaining new DB table
  • Cassandra is not suitable for reading data from different-2 table.

Solution 3:

       We can introduce a new role , which will allow user to edit course batch, It means when i add a course mentor and that mentor having new roles then system will allow them to edit course batch.


ProsCons
  •   Minimal code change required
  •  There is no separate permission , that need to be manage , it will be define based on user role only.
  •  Need to maintain one more role
  • Cross org roles need to be manage : Ex: suppose batch is created for org1 and we added a mentor who belongs to org2 but both are in same rootOrg , how to handle this?

Problem Statement 2

Current problem with sunbird platform is, you can add user to a course batch, but you can not remove user also there is no provision to add or remove mentors 

Problem Statement:

How to add or remove participants or mentors into a batch 

Accepted design is as follow:

  •   To add participant or mentors , sunbird will use create batch api. So Create batch api need to be enhanced to support participant addition.
  •  To update mentors or participant , sunbird will use updated batch api. In update batch api what ever mentors or participants list user will pass that will be replaced with existing one.
  •  Add mentors or participant will be allowed if batch is not closed yet.
  •  Add mentors or participant will be allowed for invite-only batch.

   

   

Request for create batch api: 
"request": {
    "courseId": "string",
    "name": "string",
    "description": "string",
    "enrollmentType": "string",
    "startDate": "string",
    "endDate": "string",
    "createdFor": [
      "string"
    ],
    "mentors": [
      "string"
    ],
    "participants": [
      "string"
    ]
  }

 

Request for update batch api:
"request": {
    "createdFor": [
      "string"
    ],
    "endDate": "string",
    "startDate": "string",
    "description": "string",
    "name": "string",
    "id": "string",
    "mentors": [
      "string"
    ],
    "participants": [
      "string"
    ]
  }


ProsCons
  • Api call will reduce , only one request to create batch, add mentors and participant
  • removal of mentors and participant can be handle during update batch api call, here also network call reduce
  • Three different operation are merged together , so any one business logic will change , can impact others as well.
  • One api is having different set of responsibility , so requirement for particular changes (mentors addition logic modified), developer need to understand the business logic for batch , participant as well.  


Developer will implement  above solution.



Alternative 1:

           Provide a separate method for removing mentors and participants.

           Request :

                        {

                        "participants": ["list of participants that need to be removed"],

                        "mentors" : ["list of mentors that need to be removed"]

                       } 

ProsCons
  • Separate call based on functionality (as add and remove are two different operations)
  • code readability
  • no changes in existing api. 
  • Caller need to make one more api call for removing mentors/participants.

Alternative 2:

Create one request for Add and remove : In this approach caller need to pass complete list of mentors and participants and system will replace it. 

ProsCons
  • There is only one api call to add or remove
  • Can be more risk in future change request, because two operations are combined in one call.
  • Need to add v2 , can't modify existing v1 add members to batch 


Alternative 3:

   Create one request for Add and remove : In this approach caller need to pass partial list only , based on list data system will decide , it need to be removed or added

 

ProsCons
  • No need to send complete list always
  • There is only one api call to add or remove
  • same as above

 

Alternative 4:

   Create one request for Add and remove : In this approach caller need to pass map of participant and mentors as follow.

   

 Request :

                      {

                        "participants": {

                                       "userId":"operation" // add or removed

                                           }

                        "mentors" : {

                                       "userId":"operation" // add or removed

                                    }

                       } 


Alternative 5:

   Create one request for Add and remove : In this approach caller need to pass  list of map of users as follow.

   

 Request :

                      {

                        "users": [{

                                       "userId":"",

                                       "operation":"add/remove",

                                       "userType":"mentor/participant"

                                    },

                                     ]

                       } 





Task Ref:  SB-6998 - Getting issue details... STATUS



SB-6741 - Getting issue details... STATUS