From 1bfc80783b828c402dc021d443f4b2473295c853 Mon Sep 17 00:00:00 2001 From: Vinaya Kumar B Date: Wed, 28 Nov 2018 17:11:53 +0530 Subject: [PATCH 1/6] Issue #SB-9045 fix: Update API documentation --- apis/coursebatchmanapi/coursebatchmanapi.yaml | 93 ++++++++----------- 1 file changed, 39 insertions(+), 54 deletions(-) diff --git a/apis/coursebatchmanapi/coursebatchmanapi.yaml b/apis/coursebatchmanapi/coursebatchmanapi.yaml index f718b75681..4bea25a296 100644 --- a/apis/coursebatchmanapi/coursebatchmanapi.yaml +++ b/apis/coursebatchmanapi/coursebatchmanapi.yaml @@ -56,30 +56,28 @@ paths: required: true type: string description: >- - The Content Type entity is the media type of the resource.Possible media types can be:- - - Application/json - - Multipart/form-data - - Application/x-www-form-urlencoded + Type of the request data. Set as application/json. - name: ts in: header - required: true + required: false type: string - description: 'The time stamp at which the **create batch** request was sent. ' + description: 'Timestamp at which given API request is sent.' - name: X-msgid in: header - required: true + required: false type: string - description: 'It is a Unique ID that identifies the request incase the same API is executed multiple times.' - - name: x-authenticated-user-token + description: 'This ID uniquely identifies a request if the same API is executed multiple times.' + - name: Authorization in: header required: true type: string - description: 'The alphanumeric string to access the API' - - name: Authorization + description: 'Specify authorization key (format: Bearer api-key) received from administrator when performing given API request.' + - name: X-Authenticated-User-Token in: header required: true type: string - description: 'To make use of the API, you require authorization. Raise a request to the administrator for the use of the API. You will receive the authorization key. Specify the key received, here.' + description: >- + Access token of registered user performing given API request. responses: '200': description: 'SUCCESS. The **create batch** operation was successful!' @@ -125,35 +123,27 @@ paths: produces: - application/json parameters: - - name: Content-Type - in: header - required: true - type: string - description: >- - The Content Type entity is the media type of the resource.Possible media types can be:- - - Application/json - - Multipart/form-data - - Application/x-www-form-urlencoded - name: ts in: header - required: true + required: false type: string - description: 'The time stamp at which the **Fetch a batch** request was sent. ' + description: 'Timestamp at which given API request is sent.' - name: X-msgid in: header - required: true + required: false type: string - description: 'It is a Unique ID which identifies the request incase the same API is executed multiple times.' - - name: x-authenticated-user-token + description: 'This ID uniquely identifies a request if the same API is executed multiple times.' + - name: Authorization in: header required: true type: string - description: 'The alphanumeric string for accessing the API' - - name: Authorization + description: 'Specify authorization key (format: Bearer api-key) received from administrator when performing given API request.' + - name: X-Authenticated-User-Token in: header required: true type: string - description: To make use of the API, you require authorization. Raise a request to the administrator for the use of the API. You will receive the authorization key. Specify the key received, here.' + description: >- + Access token of registered user performing given API request. responses: '200': description: 'SUCCESS. The **Fetch a batch** operation was successful!' @@ -196,7 +186,7 @@ paths: summary: Add User to a specific batch tags: - Course Batch APIs - operationId: '{{host}}/course/v1/batch/user/add/{Batch_Id)' + operationId: '{{host}}/course/v1/batch/user/add/{Batch_Id}' produces: - application/json parameters: @@ -268,7 +258,7 @@ paths: summary: Lists the existing batches tags: - Course Batch APIs - operationId: '{{host}}/course/v1/batch/search' + operationId: '{{host}}/course/v1/batch/list' produces: - application/json parameters: @@ -282,36 +272,33 @@ paths: allOf: - $ref: 'https://raw.githubusercontent.com/project-sunbird/project-sunbird.github.io/dev/apis/definitions/envelope.yaml#/ApiResponse' - $ref: '#/definitions/CourseBatchSearchReq' - - name: Content-Type in: header required: true type: string description: >- - The Content Type entity is the media type of the resource.Possible media types can be:- - - Application/json - - Multipart/form-data - - Application/x-www-form-urlencoded + Type of the request data. Set as application/json. - name: ts in: header - required: true + required: false type: string - description: 'The time stamp identifying when the **List the existing batches** request was sent. ' + description: 'Timestamp at which given API request is sent.' - name: X-msgid in: header - required: true + required: false type: string - description: 'It is a Unique ID which identifies the request incase the same API is executed multiple times.' - - name: x-authenticated-user-token + description: 'This ID uniquely identifies a request if the same API is executed multiple times.' + - name: Authorization in: header required: true type: string - description: 'The alphanumeric string for accessing the API' - - name: Authorization + description: 'Specify authorization key (format: Bearer api-key) received from administrator when performing given API request.' + - name: X-Authenticated-User-Token in: header required: true type: string - description: To make use of the API, you require authorization. Raise a request to the administrator for the use of the API. You will receive the authorization key. Specify the key received, here.' + description: >- + Access token of registered user performing given API request. responses: '200': description: 'SUCCESS. The **Lists the existing batches** operation was successful!' @@ -367,8 +354,6 @@ paths: description: >- The Content Type entity is the media type of the resource.Possible media types can be:- - Application/json - - Multipart/form-data - - Application/x-www-form-urlencoded - name: ts in: header required: true @@ -615,10 +600,10 @@ definitions: description: 'possible values are {invite-only and open}' startDate: type: string - description: 'start data of the batch valid format is yyyy-MM-dd' + description: 'start data of the batch valid format is yyyy-mm-dd' endDate: type: string - description: 'end data of batch valid format is yyyy-MM-dd' + description: 'end data of batch valid format is yyyy-mm-dd' createdFor: type: array items: @@ -786,10 +771,13 @@ definitions: type: object properties: createdFor: - description: 'org id can be added' + description: 'Organisation IDs for which batch is created.' type: array items: type: string + startDate: + description: 'batch start date' + type: string endDate: description: 'batch end date can be updated if end date hasnt expired' type: string @@ -803,12 +791,9 @@ definitions: description: '' type: string required: - - createdFor - - endDate - - description - - name - id - - enrollmentType + - startDate + EnrollBatchResponse: description: 'contains response for created batch' type: object From 1a1ce0639337ced99614c398878a7e9dd49c1bb3 Mon Sep 17 00:00:00 2001 From: Vinaya Kumar B Date: Wed, 28 Nov 2018 17:16:29 +0530 Subject: [PATCH 2/6] Issue #SB-8175 fix: Update API documentation --- apis/bulkupload/bulkserviceapi.yaml | 159 ++++++++++++++++++---------- 1 file changed, 103 insertions(+), 56 deletions(-) diff --git a/apis/bulkupload/bulkserviceapi.yaml b/apis/bulkupload/bulkserviceapi.yaml index 87bca98ae6..f7886ed2cf 100644 --- a/apis/bulkupload/bulkserviceapi.yaml +++ b/apis/bulkupload/bulkserviceapi.yaml @@ -43,11 +43,6 @@ paths: consumes: - multipart/form-data parameters: - - name: organisationId - in: formData - required: true - type: string - description: 'This ID identifies an Organisation uniquely. The ID is provided when an organization is registered' - name: user in: formData required: true @@ -55,42 +50,29 @@ paths: format: file description: >- This is a .csv file. - - Each line of the file is a data record, and each record consists of one or more fields, separated by commas. + - Each line of the file is a data record. Each record consists of one or more user fields, separated by commas. Each successfully created user is associated with root org of uploader (org admin). - The format of this file is as : - - firstName, - - lastName, - - phone, - - email, - - userName, - - password, - - phoneVerified, - - emailVerified, - - roles, - - position, - - grade, - - location, - - dob, - - aadhaarNo, - - gender, - - language, - - profileSummary, - - subject, - - Omit (•) - - (•) is used to enhance readibility here. + The CSV file format supported is mentioned below: + - NAME: Name of user + - MOBILE PHONE: Phone number. Either, phone or email is mandatory. + - EMAIL: Email. Either, phone or email is mandatory. + - SCHOOL ID: Organisation ID to which user needs to be associated. + - USER_TYPE: Type of user. Supported user types are 'teacher' or 'other'. + - ROLES: List of valid roles for assignment to user on association to an organisation. + - USER ID: User ID. Required only in case of user update. + - External ID: External ID of user. Either, school ID or external ID is mandatory for user association to organisation. - name: Authorization in: header required: true type: string - description: To make use of the API, you require authorization. Raise a request to the administrator for the use of the API. You will receive the authorization key. Specify the key received, here. - - name: x-authenticated-user-token + description: 'Specify authorization key (format: Bearer api-key) received from administrator when performing given API request.' + - name: X-Authenticated-User-Token in: header required: true type: string description: >- - It is a unique token/key to authenticate the user each time an API is called. For corresponding sessions this token is used, not your actual username/password - + Access token of registered user performing given API request. + responses: '200': description: 'OK ! Successful operation."bulk upload user" operation was successfully executed.' @@ -199,8 +181,6 @@ paths: description: >- The Content Type entity is the media type of the resource.Possible media types can be:- - Application/json - - Multipart/form-data - - Application/x-www-form-urlencoded - name: Authorization in: header required: true @@ -250,6 +230,56 @@ paths: AllowDynamicQueryParameters: false AllowDynamicFormParameters: false IsMultiContentStreaming: false + + /data/v1/upload/statusDownloadLink/{processId}: + get: + description: >- + This API is used to get the upload status for a given request. For a completed upload request, it will provide a link to a file which has the upload status. + - The **_/upload/statusDownloadLink/{processId}_** endpoint executes "get upload status download link" request based on parameters provided as metadata in the request body. + - It is must to provide values for all mandatory fields + summary: Get Upload Status Download Link + tags: + - Bulk Operation APIs + operationId: getUploadStatusDownloadLink + produces: + - application/json + parameters: + - in: path + name: processId + type: string + required: true + description: Valid bulk upload process ID + - name: Content-Type + in: header + required: true + type: string + description: >- + Type of the request data. Set as application/json. + - name: Authorization + in: header + required: true + type: string + description: 'Specify authorization key (format: Bearer api-key) received from administrator when performing given API request.' + - name: X-Authenticated-User-Token + in: header + required: true + type: string + description: >- + Access token of registered user performing given API request. + + responses: + '200': + description: 'OK. Successful operation. The requested operation was successfully executed.' + schema: + $ref: '#/definitions/GetStatusDownloadLinkSuccessResponse' + '400': + description: 'CLIENT_ERROR. The requested operation failed due to bad request from client. Possible reasons for failure: + Invalid process ID.' + schema: + $ref: '#/definitions/BulkUploadErrorResponse' + '500': + description: 'INTERNAL SERVER ERROR. The requested operation failed due to a server error. ' + /org/v1/upload : post: description: >- @@ -272,36 +302,27 @@ paths: format: file description: >- This is a .csv file. - - Each line of the file is a data record. Each record consists of one or more fields, separated by commas. - - This format of this file is as : - - orgName, - - isRootOrg, - - channel, - - externalId, - - provider, - - description, - - homeUrl, - - orgCode, - - orgType, - - preferredLanguage, - - theme, - - contactDetail + - Each line of the file is a data record. Each record consists of one or more organisation fields, separated by commas. Each successfully created organisation is associated with root org of uploader (org admin). - Omit (•) - - (•) is used to enhance readibility here. + The CSV file format supported is mentioned below: + - SCHOOL NAME: Organisation name + - BLOCK CODE: Location code (block) + - SCHOOL ID: Organisation ID. Required only in case of organisation update. + - EXTERNAL ID: External ID of organisation + - STATUS: Status. Supported values are 'active' and 'inactive'. + - DESCRIPTION: Organisation description - name: Authorization in: header required: true type: string - description: 'All User APIs require authorization for use. Specify the authorization key received from the administrator when placing the request for use of the API.' - - name: x-authenticated-user-token + description: 'Specify authorization key (format: Bearer api-key) received from administrator when performing given API request.' + - name: X-Authenticated-User-Token in: header required: true type: string description: >- - It is a unique token/key to authenticate the user each time an API is called. For corresponding sessions this token is used, not your actual username/password - + Access token of registered user performing given API request. + responses: '200': description: 'OK ! Successful operation."bulk org upload " operation was successfully executed.' @@ -491,6 +512,32 @@ definitions: allOf: - $ref: '#/definitions/EmptyResult' - $ref: '#/definitions/ResponseHeader' + + GetStatusDownloadLinkSuccessResponse: + title: Get Status Download Link Success Response + allOf: + - $ref: 'https://raw.githubusercontent.com/project-sunbird/project-sunbird.github.io/dev/apis/definitions/envelope.yaml#/ApiResponse' + - type: object + properties: + result: + type: object + properties: + processId: + type: string + description: ID that uniquely identifies the bulk upload request. + objectType: + type: string + description: Type of object in bulk upload request. Supported types are user, organisation, location, batch enrollment + status: + type: string + description: Specifies current status of bulk upload request. Supported values are {"NOT STARTED", "IN PROGRESS" and "COMPLETED"}. + message: + type: string + description: Descriptive message for current status of bulk upload request. + signedUrl: + description: 'ID of the newly created organisation' + type: string + EmptyResult: title: Empty Result type: object @@ -525,4 +572,4 @@ definitions: properties: result: description: Error message for failed location data bulk upload API request - type: object \ No newline at end of file + type: object From 36c1d73517efdee322180f435e80698717169edb Mon Sep 17 00:00:00 2001 From: Vinaya Kumar B Date: Wed, 28 Nov 2018 17:36:34 +0530 Subject: [PATCH 3/6] Issue #SB-SB-8793 feat: Add email in organisation --- apis/orgapi/orgapi.yaml | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) diff --git a/apis/orgapi/orgapi.yaml b/apis/orgapi/orgapi.yaml index 7e22dcaf28..d8e2b1dbc7 100644 --- a/apis/orgapi/orgapi.yaml +++ b/apis/orgapi/orgapi.yaml @@ -719,6 +719,9 @@ definitions: rootOrgId: description: 'Root organisation ID' type: string + email: + description: 'Contact email of organisation' + type: string address: $ref: '#/definitions/AddressCreateRequest' required: @@ -846,6 +849,9 @@ definitions: updatedDate: description: 'Date and time when organisation is updated' type: string + email: + description: 'Contact email of organisation' + type: string OrgGetResponse: title: Organisation Get API response format @@ -904,6 +910,9 @@ definitions: rootOrgId: description: 'Root organisation ID' type: string + email: + description: 'Contact email of organisation' + type: string required: - organisationId @@ -1119,6 +1128,4 @@ definitions: content: type: array items: - - $ref: '#/definitions/Organisation' From ca5b68d4822d72878de8c411f0f580128d06cf97 Mon Sep 17 00:00:00 2001 From: Vinaya Kumar B Date: Mon, 3 Dec 2018 17:47:39 +0530 Subject: [PATCH 4/6] Issue #SB-8577 feat: Update user APIs --- apis/userapi/userapi.yaml | 469 ++++++++++++++++++++++++++++++-------- 1 file changed, 370 insertions(+), 99 deletions(-) diff --git a/apis/userapi/userapi.yaml b/apis/userapi/userapi.yaml index d80709501d..a17a44ec24 100644 --- a/apis/userapi/userapi.yaml +++ b/apis/userapi/userapi.yaml @@ -44,7 +44,6 @@ paths: description: >- - The body payload comprises of the metadata of the user being created - The body parameter refers to the format of the request, the request body (payload) takes the following media types to make the payload: - - JSON schema: @@ -54,21 +53,12 @@ paths: required: true type: string description: >- - The Content Type entity is the media type of the resource.Possible media types can be:- - - Application/json - - Multipart/form-data - - Application/x-www-form-urlencoded + Type of the request data. Set as application/json. - name: ts in: header - required: true - type: string - description: >- - Timestamp is a sequence of characters or encoded information identifying when the API call occurred, usually it gives date and time of day, mostly accurate to a small fraction of a second - - name: Authorization - in: header - required: true + required: false type: string - description: To make use of any User API, you require authorization. Raise a request to the administrator for the use of the API. You will receive the authorization key. Specify the key received, here + description: 'Timestamp at which given API request is sent.' responses: '200': description: 'OK ! Successful operation."Create User" operation was successfully executed.' @@ -124,21 +114,12 @@ paths: required: true type: string description: >- - The Content Type entity is the media type of the resource.Possible media types can be:- - - Application/json - - Multipart/form-data - - Application/x-www-form-urlencoded + Type of the request data. Set as application/json. - name: ts in: header - required: true - type: string - description: >- - Timestamp is a sequence of characters or encoded information identifying when the API call occurred, usually it gives date and time of day, mostly accurate to a small fraction of a second - - name: Authorization - in: header - required: true + required: false type: string - description: To make use of any User API, you require authorization. Raise a request to the administrator for the use of the API. You will receive the authorization key. Specify the key received, here + description: 'Timestamp at which given API request is sent.' responses: '200': description: 'OK ! Successful operation."Create User" operation was successfully executed.' @@ -165,7 +146,7 @@ paths: AllowDynamicQueryParameters: false AllowDynamicFormParameters: false IsMultiContentStreaming: false - + /user/v1/search: post: description: >- @@ -199,8 +180,6 @@ paths: The Content Type entity is the media type of the resource. Possible media types can be:- - Application/json - - Multipart/form-data - - Application/x-www-form-urlencoded - name: Authorization in: header required: true @@ -379,12 +358,18 @@ paths: get: description: >- This API is used for searching a specific user, the user search is based on the unique ID of the user - - **_/v1/read/{User_ID}_** endpoint executes the "Get User profile" request + - **_/v1/read/{User_ID}_** endpoint executes the "Get User by User ID" request - It is mandatory to provide values for required parameters + - User can pass an optional query parameter 'fields'. The value is a comma separated list of fields whose information is required in response. e.g. fields=completeness,missingFields,topic,organisations,roles + - 'completeness' is to return profile completeness percentage. + - 'missingFields' is to return fields that are missing to achieve 100% profile completeness. + - 'topic' is to return list of topics that are used for announcements. + - 'organisations' is to return organisation and location details. + - 'roles' is to return list of roles with name and ID details. summary: Get User by User ID tags: - User APIs - operationId: Get User by Id + operationId: Get User by User ID produces: - application/json parameters: @@ -393,40 +378,137 @@ paths: type: string required: true description: 'Please append a valid User Id To the Request URL and if user need any specific values like , profile completeness ,missingFields,topic Ex: ?Fields=completeness,missingFields,topic' - - name: x-authenticated-user-token + - name: Content-Type in: header required: true type: string - description: >- - It a unique token/key to authenticate the user each time an API is called. For further sessions this token is exchanged, not the username/password of the user - - name: Content-Type + description: >- + Type of the request data. Set as application/json. + - name: ts + in: header + required: false + type: string + description: 'Timestamp at which given API request is sent.' + - name: X-msgid + in: header + required: false + type: string + description: 'This ID uniquely identifies a request if the same API is executed multiple times.' + - name: Authorization + in: header + required: true + type: string + description: 'Specify authorization key (format: Bearer api-key) received from administrator when performing given API request.' + - name: X-Authenticated-User-Token in: header required: true type: string description: >- - The Content Type entity is the media type of the resource. - Possible media types can be:- - - Application/json - - Multipart/form-data - - Application/x-www-form-urlencoded - - name: ts + Access token of registered user performing given API request. + responses: + '200': + description: 'OK ! Successful operation."Get User by User ID" operation was successfully executed.' + schema: + $ref: '#/definitions/CreateUserSingleResp' + '400': + description: 'BAD REQUEST,"Get User by User ID" operation failed ! The possible reason for failure is that you may have missed providing input for a mandatory parameter.' + schema: + $ref: '#/definitions/UserErrorResponse' + '404': + description: 'Resource not found' + schema: + $ref: '#/definitions/UserErrorResponse' + '500': + description: >- + 'INTERNAL SERVER ERROR. We track these errors automatically and try to set it right at the earliest. Try refreshing the page. If the problem persists contact us at info@sunbird.org.' + schema: + $ref: '#/definitions/UserErrorResponse' + security: + - bearer: [] + x-unitTests: + - request: + method: GET + uri: /user/v1/read/{User_Id} + headers: + x-authenticated-user-token: '{{user_id}}' + Content-Type: application/json + ts: 2017-05-25 10:18:56:578+0530 + Authorization: Bearer {{api_key}} + expectedResponse: + x-allowExtraHeaders: true + x-bodyMatchMode: NONE + x-arrayOrderedMatching: false + x-arrayCheckCount: false + x-matchResponseSchema: true + headers: {} + x-testShouldPass: true + x-testEnabled: true + x-testName: Get User by User ID + x-testDescription: '' + x-operation-settings: + CollectParameters: false + AllowDynamicQueryParameters: false + AllowDynamicFormParameters: false + IsMultiContentStreaming: false + /user/v2/read/{User_ID}: + get: + description: >- + This API is used for searching a specific user, the user search is based on the unique ID of the user + - **_/v2/read/{User_ID}_** endpoint executes the "Get User by User ID v2" request + - It is mandatory to provide values for required parameters + - User can pass an optional query parameter 'fields'. The value is a comma separated list of fields whose information is required in response. e.g. fields=completeness,missingFields,topic,organisations,roles + - 'completeness' is to return profile completeness percentage. + - 'missingFields' is to return fields that are missing to achieve 100% profile completeness. + - 'topic' is to return list of topics that are used for announcements. + - 'organisations' is to return organisation and location details. + - 'roles' is to return list of roles with name and ID details. + - Only necessary fields are returned in the response as per user profile configuration. + summary: Get User by User ID v2 + tags: + - User APIs + operationId: Get User by User ID v2 + produces: + - application/json + parameters: + - in: path + name: User_ID + type: string + required: true + description: 'Please append a valid User Id To the Request URI and if user need any specific values like , profile completeness ,missingFields,topic Ex: ?Fields=completeness,missingFields,topic' + - name: Content-Type in: header required: true type: string description: >- - Timestamp is a sequence of characters or encoded information identifying when the search specific user API call occurred, usually it gives date and time of day, mostly accurate to a small fraction of a second + Type of the request data. Set as application/json. + - name: ts + in: header + required: false + type: string + description: 'Timestamp at which given API request is sent.' + - name: X-msgid + in: header + required: false + type: string + description: 'This ID uniquely identifies a request if the same API is executed multiple times.' - name: Authorization in: header required: true type: string - description: 'To make use of any User API, you require authorization. Raise a request to the administrator for the use of the API. You will receive the authorization key. Specify the key received, here.' + description: 'Specify authorization key (format: Bearer api-key) received from administrator when performing given API request.' + - name: X-Authenticated-User-Token + in: header + required: true + type: string + description: >- + Access token of registered user performing given API request. responses: '200': - description: 'OK ! Successful operation."Get User by Id" operation was successfully executed.' + description: 'OK ! Successful operation."Get User by User ID v2" operation was successfully executed.' schema: - $ref: '#/definitions/CreateUserSingleResp' + $ref: '#/definitions/GetUserResponse' '400': - description: 'BAD REQUEST,"Get User by Id" operation failed ! The possible reason for failure is that you may have missed providing input for a mandatory parameter.' + description: 'BAD REQUEST,"Get User by User ID v2" operation failed ! The possible reason for failure is that you may have missed providing input for a mandatory parameter.' schema: $ref: '#/definitions/UserErrorResponse' '404': @@ -458,13 +540,14 @@ paths: headers: {} x-testShouldPass: true x-testEnabled: true - x-testName: Get User by Id + x-testName: Get User by User ID v2 x-testDescription: '' x-operation-settings: CollectParameters: false AllowDynamicQueryParameters: false AllowDynamicFormParameters: false - IsMultiContentStreaming: false + IsMultiContentStreaming: false + /user/v1/update: patch: description: >- @@ -491,32 +574,33 @@ paths: allOf: - $ref: 'https://raw.githubusercontent.com/project-sunbird/project-sunbird.github.io/dev/apis/definitions/envelope.yaml#/ApiRequest' - $ref: '#/definitions/UpdateUserRequest' - - name: x-authenticated-user-token - in: header - required: true - type: string - description: >- - It is a unique token/key to authenticate the user each time an API is called. For further sessions this token is exchanged, not the username/password of the user - name: Content-Type in: header required: true type: string description: >- - The Content Type entity is the media type of the resource.Possible media types can be:- - - Application/json - - Multipart/form-data - - Application/x-www-form-urlencoded + Type of the request data. Set as application/json. - name: ts in: header - required: true + required: false type: string - description: >- - Timestamp is a sequence of characters or encoded information identifying when the update user API call occurred, usually it gives date and time of day, mostly accurate to a small fraction of a second. + description: 'Timestamp at which given API request is sent.' + - name: X-msgid + in: header + required: false + type: string + description: 'This ID uniquely identifies a request if the same API is executed multiple times.' - name: Authorization in: header required: true type: string - description: 'To make use of any User API, you require authorization. Raise a request to the administrator for the use of the API. You will receive the authorization key. Specify the key received, here.' + description: 'Specify authorization key (format: Bearer api-key) received from administrator when performing given API request.' + - name: X-Authenticated-User-Token + in: header + required: true + type: string + description: >- + Access token of registered user performing given API request. responses: '200': description: 'OK ! Successful operation."Update User" operation was successfully executed.' @@ -1660,20 +1744,25 @@ definitions: allOf: - $ref: 'https://raw.githubusercontent.com/project-sunbird/project-sunbird.github.io/dev/apis/definitions/envelope.yaml#/ApiRequest' - $ref: '#/definitions/CreateUserSingleRespV2' + CreateUserSingleResp: description: Represents the hold single userObject request type: object properties: request: type: object - $ref: '#/definitions/UserReq' + allOf: + - $ref: '#/definitions/UserReq' + CreateUserSingleRespV2: description: Represents the hold single userObject request type: object properties: request: type: object - $ref: '#/definitions/UserReqV2' + allOf: + - $ref: '#/definitions/UserReqV2' + RolesResponse: description: Represents the hold roles response type: array @@ -1682,7 +1771,8 @@ definitions: properties: roles: type: object - $ref: '#/definitions/Role' + allOf: + - $ref: '#/definitions/Role' Role: description: Represents the request body for role @@ -1825,6 +1915,173 @@ definitions: - email - userName - phone + + GetUserResponse: + title: Get User by User ID response + type: object + properties: + email: + type: string + description: User Email ID + firstName: + type: string + description: User's first name + lastName: + type: string + description: User's last name + gender: + type: string + description: User's gender + phone: + type: string + description: User's phone number + phoneVerified: + type: boolean + description: >- + Either email or phone is required for user creation. This attribute is required with value as true in case phone is specified during user creation. + framework: + type: object + allOf: + - $ref: "#/definitions/frameworkData" + channel: + type: string + description: >- + 'Represents the channel value received while creating a root organisation + - if you provide channel value, then you will get associated with that particular root organisation + - if the channel is not provided in request body, the system reads the custodian channel from the system setting else reads it from the environment variable and uses it to associate the user with that root organisation + - if the channel value is not provided in either the request or the envronment variable, then user creation will fail.' + externalIds: + type: array + items: + type: object + allOf: + - $ref: "#/definitions/ExternalId" + profileSummary: + type: string + education: + type: array + items: + type : object + allOf: + - $ref: "#/definitions/Education" + profileVisibility: + type: object + description: 'Represents the profile visibility, it is a map having key as any user attribute and the value can be public or private' + address: + type: array + items: + type: object + allOf: + - $ref: "#/definitions/Address" + description: 'Represents the address, it contains list of address object' + jobProfile: + type: array + items: + type: object + allOf: + - $ref: "#/definitions/JobProfile" + webPages: + type: object + properties: + type: + type: string + url: + type: string + organisations: + type: array + items: + type: object + allOf: + - $ref: "#/definitions/organisation" + roleList: + type: array + items: + type: object + allOf: + - $ref: "#/definitions/roleList" + required: + - firstName + - password + - email + - userName + - phone + + organisation: + title: Organisation details + type: object + properties: + organisationId: + type: string + description: Organisation ID + updatedBy: + type: string + description : Identifier of user who updated user and org mapping + addedBy: + type: string + description : Identifier of user who added user and org mapping + roles: + type: array + items: + type: string + description : List of assigned roles + userId: + type: string + description: User ID + isDeleted: + type: boolean + description : User status (active or inactive) within given organisation + hashTagId: + type: string + description : Same as organisation ID + id: + type: string + description: Same as organisation ID + orgjoindate: + type: string + description : Date and time when user joined the organisation + orgName: + type : string + description : Organisation name + description: + type: string + description : Organisation description + channel: + type: string + description: 'rootOrg channel value' + locationIds : + type: array + items: + type: string + locations: + type: array + items: + type: object + properties: + code: + type: string + description : Location code + name: + type: string + description: Name of location + id: + type: string + description : Location ID + type: + type: string + description : Location type. Supported location types are - state, district, block and cluster + parentId: + type: string + description: Parent location ID in case of district and block location types. + roleList: + type: object + properties: + id: + type: string + description : Role ID + name: + type: string + description : Name of role + UserReqV2: title: User Object type: object @@ -1887,7 +2144,8 @@ definitions: type: array items: type : object - $ref: "#/definitions/Education" + allOf: + - $ref: "#/definitions/Education" profileVisibility: type: object description: 'Represents the profile visibility, it is a map having key as any user attribute and the value can be public or private' @@ -1895,13 +2153,15 @@ definitions: type: array items: type: object - $ref: "#/definitions/Address" + allOf: + - $ref: "#/definitions/Address" description: 'Represents the address, it contains list of address object' jobProfile: type: array items: type: object - $ref: "#/definitions/JobProfile" + allOf: + - $ref: "#/definitions/JobProfile" webPages: type: object properties: @@ -2193,15 +2453,6 @@ definitions: firstName: description: 'Represents the First name of the user' type: string - lastName: - description: ' Represents the Last name of the user' - type: string - gender: - description: 'Represents the Gender of the user, Male|Female' - type: string - avatar: - description: 'Represents the profile picture of the user' - type: string dob: description: 'Represents the Data of Birth of the user' type: string @@ -2212,11 +2463,6 @@ definitions: type: array items: type: string - subject: - description: 'Represents the array of the parameters' - type: array - items: - type: string externalId: description: 'externalId,externalIdType,externalIdProvider are the keys required if the user does not pass the userId' type: string @@ -2231,9 +2477,15 @@ definitions: type: array items: type: object - $ref: '#/definitions/ExternalIdUpdate' + allOf: + - $ref: '#/definitions/ExternalIdUpdate' + framework: + description: Framework details + type: object + allOf: + - $ref: '#/definitions/frameworkData' required: - - userId + - userId ResultStatus: type: object properties: @@ -2258,9 +2510,10 @@ definitions: type: array items: type: object - $ref: '#/definitions/User' + allOf: + - $ref: '#/definitions/User' UserCreateResponse: - description: The response body of Create Content + description: The response body of create user type: object allOf: - $ref: '#/definitions/ResultWithEmptyBody' @@ -2314,7 +2567,8 @@ definitions: type: object properties: request: - $ref: '#/definitions/ProfileVisibility' + allOf: + - $ref: '#/definitions/ProfileVisibility' example: userId: userid private: @@ -2371,19 +2625,7 @@ definitions: required: - request - assignRoleExp: - title: assignRoleExp - example: - userId: userid - organisationId: The valid organisation ID - roles: - - CONTENT_CREATION - - PUBLIC - - CONTENT_CREATOR - - ANNOUNCEMENT_SENDER - AssignRole: - type: object properties: userId: @@ -2393,7 +2635,6 @@ definitions: description: 'The unique ID of the organisation' type: string roles: - description: The role assigned to a user. The role is directly replaced with saved roles, if any. Ensure that the request has a list of all the user roles. To remove all roles assigned to a user, pass an empty array example: @@ -2550,3 +2791,33 @@ definitions: type: string required: - request + + frameworkData: + title: Framework details + type: object + properties: + gradeLevel: + type: array + description: List of grades whose content is of interest to user + items: + type: string + subject: + type: array + description: List of subjects whose content is of interest to user + items: + type: string + medium: + type: array + description: List of mediums whose content is of interest to user + items: + type: string + board: + type: array + description: List of boards whose content is of interest to user + items: + type: string + + required: + - gradeLevel + - medium + - board From e821c2b497796d996f7a4c6c532cb4c91105bf7b Mon Sep 17 00:00:00 2001 From: Basreena Date: Fri, 7 Dec 2018 14:44:54 +0530 Subject: [PATCH 5/6] Update bulkserviceapi.yaml --- apis/bulkupload/bulkserviceapi.yaml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/apis/bulkupload/bulkserviceapi.yaml b/apis/bulkupload/bulkserviceapi.yaml index f7886ed2cf..ce17c3290e 100644 --- a/apis/bulkupload/bulkserviceapi.yaml +++ b/apis/bulkupload/bulkserviceapi.yaml @@ -54,9 +54,9 @@ paths: The CSV file format supported is mentioned below: - NAME: Name of user - - MOBILE PHONE: Phone number. Either, phone or email is mandatory. - - EMAIL: Email. Either, phone or email is mandatory. - - SCHOOL ID: Organisation ID to which user needs to be associated. + - MOBILE PHONE: Phone number. Either phone or email is mandatory. + - EMAIL: Email. Either phone or email is mandatory. + - SCHOOL ID: Organisation ID to which user must be associated. - USER_TYPE: Type of user. Supported user types are 'teacher' or 'other'. - ROLES: List of valid roles for assignment to user on association to an organisation. - USER ID: User ID. Required only in case of user update. From 29975c7783a659c5b584fd094cde58847e4ff760 Mon Sep 17 00:00:00 2001 From: Basreena Date: Fri, 7 Dec 2018 14:48:08 +0530 Subject: [PATCH 6/6] Update bulkserviceapi.yaml --- apis/bulkupload/bulkserviceapi.yaml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/apis/bulkupload/bulkserviceapi.yaml b/apis/bulkupload/bulkserviceapi.yaml index ce17c3290e..fc3d94efd2 100644 --- a/apis/bulkupload/bulkserviceapi.yaml +++ b/apis/bulkupload/bulkserviceapi.yaml @@ -97,7 +97,7 @@ paths: description: >- This API is used for enrolling batches in bulk - The **_/batch/bulk/enrollment_** endpoint executes "bulk batch enrollment" request based on parameters provided as metadata in the request body. - - It is a must to provide values for all mandatory fields + - It mandatory to provide values for all mandatory fields summary: Upload Batches in Bulk tags: - Bulk Operation APIs