Typescript-restful-starter
Node.js + ExpressJS + TypeOrm + Typescript + JWT + ES2015 + Clustering + Tslint + Mocha + Chai + Supertest
What use is this Starter App?
- JWT for protecting routes.
- Clustering mode for loading many forks depending of the CPU's units.
- Typeorm for ORM.
- ES2015 the lastest javascript version has promises and async/await
- Mocha - Chai for testing
- Supertest to load the entire server into the tests seamlessly
Structure
/app
/controllers (Controllers of the app)
/middlewares (Middlewares for the routes of the app)
/routes (Routes for Controllers of the app)
/service (Services for using in any Controller)
/entity (Models configuration for use)
/repository (Custom queries)
/config
/Router.ts (Config file for Routing)
/Database (DB configuration for use)
/Server.ts (Server configuration)
config.ts (Config file for the app)
tsconfig.json (File configuration typescript)
tslint.json (File configuration rules typescript)
Index.ts (Main file to start the app)
Install
-
First clone this repository.
git@github.com:camesine/Typescript-restful-starter.git
-
Download all dependencies.
npm install
-
Edit the file
./env
and add config database like:
DB=test
PASSWORD=root
PORT_DB=3306
SERVER=127.0.0.1
USER_DB=root
- Edit the file
./config.ts
with your own settings:
const LOCAL_CONFIGURATION = {
DB: "test",
DIALECT: "mysql",
PASSWORD: "",
PORT_DB: 3306,
SERVER: "127.0.0.1",
USER_DB: "root",
};
const PRODUCTION_CONFIGURATION = {
DB: process.env.DB || "prod",
DIALECT: process.env.DIALECT || "mysql",
PASSWORD: process.env.PASSWORD || "",
PORT_DB: Number(process.env.PORT_DB) || 3306,
SERVER: process.env.SERVER || "localhost",
USER_DB: process.env.USER_DB || "root",
};
export const config = {
SECRET: "HltH3R3",
PORT_APP: 1344,
DATABASE: process.env.NODE_ENV === 'PRODUCTION' ? PRODUCTION_CONFIGURATION : LOCAL_CONFIGURATION
}
Start App
When execute any of this commands the app start with clustering, creating many cluster apps depending of the numbers of CPU's your computer had.
Development: In Development mode, the express app is started with nodemon for automatic refresh when changes are made.
npm run dev
Test: Run test in development environment
npm test
Production: Run app in production environment
npm start