Nodetomic Api Swagger
data:image/s3,"s3://crabby-images/b8c27/b8c27f4a37bd41a67e68be4a29295329474ac8d6" alt="Downloads"
RESTful API Nodejs designed for horizontal scalability, based on Swagger, Redis, JWT, Passport, Socket.io, Express, MongoDB. Support multiple cluster
Include libs
data:image/s3,"s3://crabby-images/503bd/503bd8d84eedf3abbeab160ede81a1228d0bad62" alt=""
Horizontal scalability
data:image/s3,"s3://crabby-images/16810/16810c059faa6143d21948c9092ee0751b416fd6" alt="Imgur"
Preview
data:image/s3,"s3://crabby-images/acbc3/acbc365cf306f493d22b7cb3c302164129b23ac0" alt=""
Swagger Api
http://localhost:8000/docs
Technologies
data:image/s3,"s3://crabby-images/6d422/6d422282ba9b856a65bfce57016381fffdaf849e" alt=""
Requirements
Installation
git clone https://github.com/kevoj/nodetomic-api-swagger
cd nodetomic-api-swagger
npm i
Development
Start
npm start
data:image/s3,"s3://crabby-images/006da/006da5f9d2c798b8e05c9119ccd64364a07d6220" alt="Imgur"
Optional: npm run modemon
if you want work with nodemon.
Build
npm run build
data:image/s3,"s3://crabby-images/ccd1a/ccd1abe251464bfc12d12f37e86fef5b75ebbb74" alt="Imgur"
Generate folder dist
. So "dist/client" is optional. You can paste the compilation of a client here, for example of Vue, React, Angular ...
data:image/s3,"s3://crabby-images/5386c/5386c3fd6ad575f5032eb1aae9321af357e182cb" alt="Imgur"
Test
npm test
data:image/s3,"s3://crabby-images/c2dd0/c2dd09b3d8f8c83c57273d82abd038a722c19645" alt="Imgur"
Lint
npm run lint
Pm2 [Development]
Simple
Run pm2 in a single thread and run pm2 console
npm run dev-simple
data:image/s3,"s3://crabby-images/6316a/6316a151299c6e41b0fbbdc09a1355f8363bb97d" alt="Imgur"
Cluster
Run pm2 in multiple threads and run pm2 console
npm run dev-cluster
data:image/s3,"s3://crabby-images/34dc3/34dc3c8b78d6e609515ecd3ada154c669a3a0bbd" alt="Imgur"
Pm2 [Production]
Simple
Run pm2 in a single thread
npm run simple
data:image/s3,"s3://crabby-images/eddb5/eddb5d321a6af8af56980c2794b21576702dbe92" alt="Imgur"
Cluster
Run pm2 in multiple threads
npm run cluster
data:image/s3,"s3://crabby-images/78289/782897cf15fa09dae59b7407426ad9c14c986ba7" alt="Imgur"
Stop
PM2
destroy pm2 simple and pm2 cluster
npm stop
Node
destroyed all process for node
killall node
How to create..
Model
src/api/models/hello.js
import mongoose from 'mongoose';
const Schema = mongoose.Schema;
const HelloSchema = new Schema({
greet: {
type: String,
required: [true, 'Greet is required.']
},
language: {
type: String,
required: [true, 'Language is required.']
}
});
export default mongoose.model('Hello', HelloSchema);
Controller
src/api/controllers/hello.js
import { result, notFound, error } from 'express-easy-helper';
import Hello from '../models/hello';
export function list(req, res) {
return Hello.find().exec()
.then(notFound(res))
.then(result(res))
.catch(error(res));
}
Swagger (Router)
src/api/swagger/hello.yaml
/api/hello:
x-swagger-router-controller: hello
get:
operationId: list
tags:
- Hello
summary: Get list Hello's
description: Returns all hello
responses:
200:
description: Success
404:
description: Not found
500:
description: Error
Swagger (Router + middleware)
src/api/swagger/hello.yaml
/api/hello:
x-swagger-router-controller: hello
get:
operationId: list
security:
- Bearer: []
x-security-scopes:
- admin
tags:
- Hello
summary: Get list Hello's
description: Returns all hello
responses:
200:
description: Success
404:
description: Not found
500:
description: Error
Socket
src/api/sockets/hello.js
export let socket = null;
export let io = null;
export default (_socket, _io) => {
socket = _socket;
io = _io;
on();
}
export function on() {
socket.on('example', function (data) {
emit('cool', data);
});
}
export function emit(event, data) {
io.emit(event, data);
}
Controller + Socket
src/api/controllers/hello.js
import { result } from 'express-easy-helper';
import { emit } from '../sockets/hello';
export function test(req, res) {
emit('hello','world');
return result(res, 'Socket emitted!');
}
License
MIT © Leonardo Rico