This repository contains a Node.js / Express / Angularjs simple webapp for a chat.
It can be used as a nice learning API.
Source code is available and released under the Apache 2.0 License.
The API has been developed in multiple versions:
- 1.0: Easiest to implement. Registration is done via an HTML page or via path variables, messages can be fetched with path variables.
- 2.0: Harder to implement, but more secure, with many more features. Login is done via basic HTTP, users have profiles with pictures, messages can contain attachments, can be fetched only with basic auth headers, and supports pagination.
- Websockets: Extension to 2.0, for real-time message updates, and login information.
Both API 1.0 and 2.0 descriptors are documented and can be tried at:
Swagger Documentation 1.0
Swagger Documentation 2.0
The URI is formed of three parts: {baseURL}/{versionPrefix}/{route}
For instance: To register a user, you would call https://training.loicortola.com/chat-rest/1.0/register/myuser/mypassword
An example instance was published on the following baseURL: https://training.loicortola.com/chat-rest
versionPrefix: /1.0
This API has permissive request Content-Types, and is best fit for beginners.
Description: Register new user to chat service through API
Status | Body |
---|---|
200-OK | JSON response {"status":200,"message":"Registered successfully"} if everything went well. |
400-BAD-REQUEST | with JSON response {"status":400,"message":"...","elements":"..."} if login or/and password already exist |
Description: Connect new user to chat service through API
Status | Body |
---|---|
200-OK | JSON response {"status":200,"message":"Login successful"} if everything went well. |
401-UNAUTHORIZED | with JSON response {"status":401,"message":"...","elements":"..."} if login or/and password provided are not correct |
Description: Retrieve all messages from chat service API
Status | Body |
---|---|
200-OK | JSON Array response [{"uuid":"...","login":"john","message":"Hello world! Ping"},{"uuid":"...","login":"jane","message":"Pong!"}] if everything went well. |
401-UNAUTHORIZED | with JSON response {"status":401,"message":"...","elements":"..."} if login or/and password provided are not correct |
Description: Post new message to chat service API
Request body: {"uuid":"...","login":"jane","message":"Pong!"}
Warning: uuid is mandatory and should be a valid generated uuid!
Status | Body |
---|---|
200-OK | JSON response {"status":200,"message":"Message posted successfully"} if everything went well. |
400-BAD-REQUEST | with JSON response {"status":400,"message":"...","elements":"..."} if any mandatory body fields are absent/invalid or if message has already been posted. |
401-UNAUTHORIZED | with JSON response {"status":401,"message":"...","elements":"..."} if login or/and password provided are not correct |
versionPrefix: /2.0
This API performs authentication using basic authentication (more info: https://en.wikipedia.org/wiki/Basic_access_authentication)
The API searches for Content-Type:application/json header when required, and is best fit for advanced use.
Description: Register new user to chat service through API
Request body: {"login":"foo","password":"bar"}
Warning: requires Content-Type:application/json header!
Status | Body |
---|---|
200-OK | JSON response {"status":200,"message":"Registered successfully"} if everything went well. |
400-BAD-REQUEST | with JSON response {"status":400,"message":"...","elements":"..."} if login or/and password already exist, or fields not properly set. |
Description: Connect new user to chat service through API
Warning: requires Basic Authentication!
Status | Body |
---|---|
200-OK | JSON response {"status":200,"message":"Login successful"} if everything went well. |
401-UNAUTHORIZED | with JSON response {"status":401,"message":"...","elements":"..."} if login or/and password provided are not correct |
Description: Get the profile details of any user (login, email, picture)
Warning: requires Basic Authentication!
Status | Body |
---|---|
200-OK | JSON response {"login": "john", "email": "foo@bar.com", "picture": "https://training.loicortola.com/chat-rest/2.0/files/usr-john.jpg"} if everything went well. |
401-UNAUTHORIZED | with JSON response {"status":401,"message":"...","elements":"..."} if login or/and password provided are not correct |
Description: Update user profile (email, picture, password)
Request body: {"email": "foo@bar.com", "password":"newfoo", "picture":{"mimeType": "image/jpg", "data": "yourbase64profilepicture"}} Warning: requires Basic Authentication!
Warning: requires Content-Type:application/json header!
Status | Body |
---|---|
200-OK | JSON response {"status":200,"message":"Profile updated successfully", "elements": ["picture", "password"]} if everything went well. |
400-BAD-REQUEST | with JSON response {"status":400,"message":"...","elements":"..."} if fields not properly set. |
Description: Retrieve all messages from chat service API
Optional parameters:
- limit: maximum number of results.
- offset: result offset.
- head: head pointer. Offset and limit values will take this message uuid as head reference instead of last posted message.
Warning: requires Basic Authentication!
Status | Body |
---|---|
200-OK | JSON Array response [{"uuid":"...","login":"john","message":"Hello world! Ping"},{"uuid":"...","login":"jane","message":"Pong!", "images": ["https://training.loicortola.com/2.0/files/.../1.png"]}] if everything went well. **NB: images is not a mandatory field. it can hold URLs to the image attachments posted along with a message.** |
401-UNAUTHORIZED | with JSON response {"status":401,"message":"...","elements":"..."} if login or/and password provided are not correct |
Description: Post new message to chat service API
Warning: requires Basic Authentication!
Request body: {"uuid":"...","login":"jane","message":"Pong!", "attachments": [{"mimeType": "image/png", "data": "yourbase64imagecontenthere"}]}
Warning: uuid is mandatory and should be a valid generated uuid!
NB: attachments is not a mandatory field. it can hold image/png or image/jpg content. Warning, size is limited to 1024kb by default.
Status | Body |
---|---|
200-OK | JSON response {"status":200,"message":"Message posted successfully"} if everything went well. |
400-BAD-REQUEST | with JSON response {"status":400,"message":"...","elements":"..."} if any mandatory body fields are absent/invalid or if message has already been posted. |
401-UNAUTHORIZED | with JSON response {"status":401,"message":"...","elements":"..."} if login or/and password provided are not correct |
Description: Retrieve file posted along depending on the file extension.
Status | Body |
---|---|
200-OK | image/* response if everything went well. |
404-NOT-FOUND | if image does not exist. |
Description: Retrieve profile picture.
Status | Body |
---|---|
200-OK | image/* response if everything went well. |
404-NOT-FOUND | if image does not exist. |
namespace: 2.0/ws
This API allows the use of websockets to enhance real-time experience for users.
The Websocket API uses Socket.io as an implementation.
Warning: socket.io has a very original way of declaring its clients. Beware of the difference between host, namespace, and path.
| Event | Payload & Outcomes | | ----- | ------ | ----------- | ------- | |
- Event:
auth_required
- Source:
SERVER
- Description: Once connection is established, server tells client authentication is required.
- Event:
auth_attempt
- Source:
CLIENT
- Description: Client attempts to authenticate to the server.
Payload: {"login":"foo","password":"bar"}
Status | Payload |
---|---|
Success | Server will emit auth_success and active_users_update if everything went well. |
Failure | Server will emit auth_failed if credentials are wrong. |
- Event:
auth_success
- Source:
SERVER
- Description: Server notifies client its authentication was successful, and returns the session-token.
Payload: {"login":"foo","token":"session-token1234","message": "Authentication successful"} | |
- Event:
auth_failed
- Source:
SERVER
- Description: Server notifies client its authentication has failed.
- Event:
outbound_msg
- Source:
CLIENT
- Description: Client sends a new message.
Payload: {"login":"foo","token":"session-token1234","uuid":"message-uuid-1234","message": "Hello World!","attachments": [{"mimeType": "image/png", "data": "yourbase64imagecontenthere"}]}
Status | Payload |
---|---|
Success | Server will emit post_success_msg and broadcast inbound_msg if everything went well. |
Failure | Server will emit bad_request_msg if credentials or message structure are wrong. |
- Event:
inbound_msg
- Source:
SERVER
- Description: Server notifies clients a new message was sent.
Payload: {"login":"foo","uuid":"message-uuid-1234","message": "Hello World!", "images": ["https://training.loicortola.com/2.0/files/.../1.png"]}]} | |
- Event:
user_typing_outbound_msg
- Source:
CLIENT
- Description: Client notifies server of a message being written.
Payload: {"login":"foo","token":"session-token1234"}
Status | Payload |
---|---|
Failure | Server will emit bad_request_msg if credentials or message structure are wrong. |
- Event:
user_typing_inbound_msg
- Source:
SERVER
- Description: Server notifies clients a message is being written by a specific user.
Payload: {"login":"foo"} | |
- Event:
post_success_msg
- Source:
SERVER
- Description: Server notifies emitter-client its message was successfully sent.
Payload: {"uuid":"message-uuid-1234"} | |
- Event:
bad_request_msg
- Source:
SERVER
- Description: Server notifies emitter-client its message was not sent.
Payload: String message with the error reason. | |
- Event:
active_users_update
- Source:
SERVER
- Description: Server broadcasts the list of active users to clients. This event is fired everytime the list of connected users changes.
Payload: ["user1", "user2", "john", "jane"] |
Besides the API, the Chat system has an HTML registration page available at route /
Administrators can monitor activity with the HTML dashboard, and reset memory at /dashboard (requires admin login).
The source code is now released along with the API description.
Please update the configuration with your own in conf/conf.js
Requirements: node, npm
Execute the following commands:
npm install
bower install
gulp
./start.sh
Copyright 2015 Loïc Ortola
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.