Assume that NS8 has contracted you to build a small RESTful API to support their new user tracking software. There are many node.js frameworks that could help you with this. For example, express, restify etc.
Data does not need to be persisted between server restarts.
-
email
- string
- This field is required to create a new user
- The system must only allow 1 user per unique email address
{ "status": "fail", "message": "email address already exists"}
-
password
- string
- This field is required to create a new user
-
phone number
- string
- This field is optional
- When provided, the phone number must follow this pattern ###-###-####
// email must be an email check('email').isEmail(), check('password').not().isEmpty(), check('phone').isMobilePhone().optional() ], apiCreateUser); ```
- type
- This field is required to create a new event
- The value can be any non-empty string
export class UserEvents {
id: string
userid: string
type: string
created: string
constructor(data: any) {
if (!data.type) {
throw new Error("Type is required for event");
}
this.id = data.id;
this.userid = data.userid;
this.type = data.type;
this.created = data.created;
}
}
The following input json would create a user POST /users
{
"email": "[email protected]",
"password": "passwordIsPizza",
"phone": "333-222-1111"
}
Respone
{
"status": "Success",
"message": "Created new userid: ad8b51d0-d2fb-49bd-a748-546cf3dea8dc"
}
Also creates event
{
"id": "46ae3ed7-824c-402b-bbf9-2973e7315c6a",
"userid": "ad8b51d0-d2fb-49bd-a748-546cf3dea8dc",
"type": "CREATED",
"created": 1552866927637
}
Get Users Summary List GET /users
[
{
"id": "1",
"email": "[email protected]",
"phone": "248-555-1212"
},
{
"id": "2",
"email": "[email protected]",
"phone": "248-555-1212"
},
{
"id": "ad8b51d0-d2fb-49bd-a748-546cf3dea8dc",
"email": "[email protected]",
"phone": "248-555-1212"
}
]
Not complete - The following input json would create an event with the type LOGIN
{
"type": "LOGIN"
}
The following use cases should be satisfied to get user event data
- return all events for all users /events/user/all
[
{
"id": "1",
"userid": "2",
"type": "LOGIN",
"created": 1552881599997
},
{
"id": "2",
"userid": "1",
"type": "LOGIN",
"created": 1552880599999
},
{
"id": "3",
"userid": "2",
"type": "LOGOUT",
"created": 1552881599999
}
]
- return all events for a single user /events/user/:userid
[
{
"id": "1",
"userid": "2",
"type": "LOGIN",
"created": 1552881599997
},
{
"id": "3",
"userid": "2",
"type": "LOGOUT",
"created": 1552881599999
}
]
- return all events for the last day /events/user/day
{
"id": "1",
"userid": "2",
"type": "LOGIN",
"created": 1552881599997
},
{
"id": "2",
"userid": "1",
"type": "LOGIN",
"created": 1552880599999
},
{
"id": "3",
"userid": "2",
"type": "LOGOUT",
"created": 1552881599999
}
]
The json data returned should at least have the following elements - Create Even
where created
is the date the event was created. Choose any date format.