Simple boilerplate code base for creating APIs with Node.js Express
framework using Sequelize
with PostgreSQL
database.
- Includes
- Prerequisite
- Getting Started
- Local Setup
- Tests & Coverage
- Migrations
- Environment Variables
ESDoc
- Endpoints
- References
- ES6
import/export
implemented withtype: "module"
inpackage.json
- Error handling middlewares implemented
Tests
added withmocha
configuration- Code-coverage using Node.js' built in functionality
c8
Eslint
winston
logger
-
Install
nodemon
globally using below command if not installed alreadynpm i -g nodemon
-
PostgreSQL
You can download or clone this repo using below command:
git clone [email protected]:Chetan07j/node-pg-sequelize.git
-
After cloning enter into folder.
-
Install dependencies
npm install
-
Create file called
.env
-
Copy
.env.example
file content.env
file. -
Run locally
npm run local
-
Run tests (unit/integration)
npm test
-
Run tests with coverage
npm run coverage
-
Running Migrations
npm run migration
-
Undoing Migrations
npm run migration:undo
Variable | Description | Default Value |
---|---|---|
DB_HOST | Database connection host | localhost |
DB_PORT | Database port | 5432 |
DB_NAME | Database name | postgres |
DB_USER | Database username | postgres |
DB_PASS | Database password | postgres |
NOTE: These environment variables are already passed to
npm run local
andnpm test
scripts underpackage.json
with their default values. You can update as per your need.
- Documention is created out of comments added for functions using
esdoc
. - That documentaion is avaialbe as GH Pages site, can be found here.
Create User with Skills
curl --location --request POST 'localhost:3000/v1/users' \
--header 'Content-Type: application/json' \
--data-raw '{
"firstName": "Chetan",
"lastName": "Patil",
"gender": "Male",
"skills": [
{
"name": "Node.js",
"proficiency": "Advanced"
}
]
}'
Get all Users
```sh
# Request
curl --location --request GET 'localhost:3000/v1/users'
#Response
{
"success": true,
"body": [
{
"id": 1,
"firstName": "First1",
"lastName": "Last",
"gender": "Male",
"createdAt": "2022-03-20T10:11:41.860Z",
"updatedAt": "2022-03-20T10:11:41.860Z",
"skills": [
{
"id": 1,
"userId": 1,
"name": "Node.js",
"proficiency": "Advanced",
"createdAt": "2022-03-20T10:11:41.867Z",
"updatedAt": "2022-03-20T10:11:41.867Z"
}
]
}
]
}
```
Get specific User by userId
```sh
# Request
curl --location --request GET 'localhost:3000/v1/users/1'
# Response
{
"success": true,
"body": {
"id": 1,
"firstName": "Chetan",
"lastName": "Patil",
"gender": "Male",
"createdAt": "2022-03-20T20:39:17.912Z",
"updatedAt": "2022-03-20T20:39:17.912Z",
"skills": [
{
"id": 1,
"userId": 1,
"name": "Node.js",
"proficiency": "Advanced",
"createdAt": "2022-03-20T20:39:17.962Z",
"updatedAt": "2022-03-20T20:39:17.962Z"
}
]
}
}
```
Contributions are welcome! Feel free to open an issue or submit a pull request if you have a way to improve this project.
Make sure your request is meaningful and you have tested the app locally before submitting a pull request.
💙 If you like this project, give it a ⭐