{
"title": "Title of the task",
"purpose": "<why is this task needed>, optional",
"featureURL": "<live url of the feature>, optional",
"type":"feature | group",
"links": [
// optional
<link1>,
<link2>
],
"endsOn":"<epoch>",
"startedOn":"<epoch>",
"createdAt": "<epoch> timestamp",
"updatedAt": "<epoch> timestamp",
"status": "AVAILABLE | ASSIGNED | IN_PROGRESS | BLOCKED | SMOKE_TESTING | COMPLETED | NEEDS_REVIEW | IN_REVIEW | APPROVED | MERGED | SANITY_CHECK | REGRESSION_CHECK | RELEASED | VERIFIED",
"createdBy":"<userId>",
"assignee":<userId> (in case of individual tasks)",
"percentCompleted": 0,
"dependsOn": [
// optional
<task_id>,
<task_id>
],
"level": 1 | 2 | 3 | 4 | 5 // optional - can be added only if category exists,
"category": <string> // optional (example: "FRONTEND" | "BACKEND"),
"participants": [
// for group tasks
// optional
<user_id>
<user_id>
],
"completionAward": { dinero: 1500, neelam: 1 },
"lossRate": { dinero: 100 } // Loss per day of overshoot after deadline,
'isNoteworthy': true,
'github': {
// optional
'issue': {
'status': <string>,
'assignee': <string>, // optional
'id': <number>,
'closedAt': <string>, // optional
'assigneeRdsInfo': {
// optional
firstName: <string>,
lastName: <string>,
username: <string>
}
}
}
}
Route | Description |
---|---|
GET /tasks | Returns all tasks |
GET /tasks/self | Returns all tasks of a user |
POST /tasks | Creates new task |
PATCH /tasks/:id | Updates tasks |
GET /tasks/:id/details | Get details of a particular task |
GET /tasks/:username | Returns all tasks of the user |
PATCH /tasks/self/:id | Changes in own task |
PATCH /tasks/assign/:userId | Assigns the task based on task availability and skill |
PATCH /tasks/:id/status | Changes the status in own task |
Returns all the tasks
- Params
None - Query
- Optional:
dev=[boolean]
(dev
is passed to get all tasks in the developer mode with features that are flagged) - Optional:
status=[string]
(status
is a case insenstive string with one of the following values [AVAILABLE, ASSIGNED, COMPLETED, IN_PROGRESS, BLOCKED, SMOKE_TESTING, NEEDS_REVIEW, IN_REVIEW, APPROVED, MERGED, SANITY_CHECK, REGRESSION_CHECK, RELEASED, VERIFIED, DONE, UNASSIGNED] which represents the status of the task) - Optional:
assignee=[string]
(assignee
can be assignee username in case of single assignee or multiple comma separated values in case of multiple assignee) - Optional:
title=[string]
(title
can be case sensitive, whole or starting portion of task title) - Optional:
page=[integer]
(page
can either be 0 or a positive integer. Default value is 0) - Optional:
size=[integer]
(size
is the number of tasks requested per page. Range of value is 1-100. Default value is 5) - Optional:
next=[string]
(next
is id of the document to get next page of results from that document) - Optional:
prev=[string]
(prev
is id of the document to get prev page of results from that document) - Optional:
orphaned=[boolean]
( if orphaned is set to true with dev feature flag as true, it will return all the pending tasks which have assigned to users who have departed the discord server. )
- Optional:
- Body
None - Headers
None - Cookie
None - Success Response:
- Code: 200
- Content:
{
message: 'Tasks returned successfully!'
tasks: [
{<task_object>},
{<task_object>}
]
}
-
Code: 204 (for
orphaned=true
when no orphaned tasks exist)- Content:
No Content
- Content:
-
Error Response:
- Code: 500
- Content:
{ 'statusCode': 500, 'error': 'Internal Server Error', 'message': 'An internal server error occurred' }
- Content:
- Code: 404 (for
orphaned=true
withoutdev=true
)- Content:
{ 'message': 'Route not found' }
- Content:
- Code: 500
Returns all the completed tasks of user if query completed=true
is passed, else returns all the active and blocked tasks of the user.
- Params
None - Query
completed=[boolean] - Body
None - Headers
Content-Type: application/json - Cookie
rds-session:<JWT>
- Success Response:
- Code: 200
- Content:
- Code: 200
[
{<task_object>},
{<task_object>},
{<task_object>},
{<task_object>},
{<task_object>}
]
- Error Response:
- Code: 401
- Content:
{ 'statusCode': 401, 'error': 'Unauthorized', 'message': 'Unauthenticated User' }
- Content:
- Code: 404
- Content:
{ 'statusCode': 404, 'error': 'Not Found', 'message': 'User doesn't exist' }
- Content:
- Code: 500
- Content:
{ 'statusCode': 500, 'error': 'Internal Server Error', 'message': 'An internal server error occurred' }
- Content:
- Code: 401
Returns details of a particular task
- Params
Required:id=[string]
- Query
None - Body
None - Headers
Content-Type: application/json - Success Response:
- Code: 200
- Content:
- Code: 200
{
"message":"task returned successfully",
"taskData": [
{<task_object>}
]
}
- Error Response:
- Code: 404
- Content:
{ 'statusCode': 404, 'error': 'Not Found', 'message': 'Task not found' }
- Content:
- Code: 500
- Content:
{ 'statusCode': 500, 'error': 'Internal Server Error', 'message': 'An internal server error occurred' }
- Content:
- Code: 404
Returns all tasks of the requested user.
- Params
Required:username=[string]
- Query
None - Body
None - Headers
Content-Type: application/json - Success Response:
- Code: 200
- Content:
- Code: 200
{
message: 'Tasks returned successfully!'
tasks: [
{<task_object>},
{<task_object>}
]
}
- Error Response:
- Code: 404
- Content:
{ 'statusCode': 404, 'error': 'Not Found', 'message': 'User doesn't exist' }
- Content:
- Code: 500
- Content:
{ 'statusCode': 500, 'error': 'Internal Server Error', 'message': 'An internal server error occurred' }
- Content:
- Code: 404
- Params
None - Query
None - Headers
Content-Type: application/json - Body
{ <task_object> }
- Success Response:
- Code: 200
- Content:
{
message: 'Task created successfully!'
task: {<task_object>}
id: <newly created task id>
userStatus?: {
status : "String",
message : "String"
data: {
"previousStatus"?: "String",
"currentStatus"?: "String",
"futureStatus"?: "String"
}
}
}
- Error Response:
- Code: 500
- Content:
{ 'statusCode': 500, 'error': 'Internal Server Error', 'message': 'An internal server error occurred' }
- Content:
- Code: 500
-
Params
Required:id=[string]
-
Headers
Content-Type: application/json -
Body
{ <task_object> }
-
Success Response:
-
Code: 204
- Content:
<No Content>
- Content:
-
Error Response:
- Code 404
- Content
{ 'statusCode': 404, 'error': 'Not found', 'message': 'No tasks found' }
- Content
- Code: 500
- Content:
{ 'statusCode': 500, 'error': 'Internal Server Error', 'message': 'An internal server error occurred' }
- Content:
- Code 404
-
Params
Required:id=[string]
-
Headers
Content-Type: application/json -
Body
{ status: <new-status> percentCompleted: <number> }
-
Cookie
rds-session:<JWT>
-
Success Response:
- Code: 200
{
message: 'Task updated successfully!'
userStatus?: {
status : "String",
message : "String"
data: {
"previousStatus"?: "String",
"currentStatus"?: "String",
"futureStatus"?: "String"
}
}
}
- Error Response:
- Code: 401
- Content:
{ 'statusCode': 401, 'error': 'Unauthorized', 'message': 'User can not be authenticated' }
- Content:
- Code: 403
- Content:
{ 'statusCode': 403, 'error': 'Forbidden', 'message':'This task is not assigned to you' }
- Content:
- Code: 404
- Content:
{ 'statusCode': 404, 'error': 'Not Found', 'message': 'Task doesn't exist' }
- Content:
- Code: 500
- Content:
{ 'statusCode': 500, 'error': 'Internal Server Error', 'message': 'An internal server error occurred' }
- Content:
- Code: 401
-
Params
Required:userId = <userId>
-
Headers
Content-Type: application/json -
Body
-
Cookie
rds-session:<JWT>
-
Success Response:
- Code: 200
{
message: 'Task assigned',
id: <string>
}
- Error Response:
- Code: 500
- Content:
{ 'statusCode': 500, 'error': 'Internal Server Error', 'message': 'An internal server error occurred' }
- Content:
- Code: 500
-
Params
Required:id=[string]
-
Headers
Content-Type: application/json -
Body
{ status: <new-status> percentCompleted: <number> }
-
Cookie
rds-session:<JWT>
-
Success Response:
- Code: 200
{
message: 'Task updated successfully!'
userStatus?: {
status : "String",
message : "String"
data: {
"previousStatus"?: "String",
"currentStatus"?: "String",
"futureStatus"?: "String"
}
}
}
- Error Response:
- Code: 401
- Content:
{ 'statusCode': 401, 'error': 'Unauthorized', 'message': 'Unauthenticated User' }
- Content:
- Code: 403
- Content:
{ 'statusCode': 403, 'error': 'Forbidden', 'message':'This task is not assigned to you' }
- Content:
- Code: 404
- Content:
{ 'statusCode': 404, 'error': 'Not Found', 'message': 'Task doesn't exist' }
- Content:
- Code: 500
- Content:
{ 'statusCode': 500, 'error': 'Internal Server Error', 'message': 'An internal server error occurred' }
- Content:
- Code: 401