Skip to content

A Node.js API boilerplate, connected to MongoDB with Mongoose and implemented in Typescript.

Notifications You must be signed in to change notification settings

maninak/NoMoTS-api

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

71 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

NoMoTS logo

NoMoTS API Boilerplate

Table of Contents


Description

NoMoTS is a Node.js API boilerplate, connected to MongoDB with Mongoose and implemented in Typescript.

NoMoTS provides the rich custom tooling needed for node + Typescript development from the get-go. It features support for development, production and test environments and an automatic versioning system following the SemVer specification. Moreover it includes an example CRUD implementation of a simple demo API of Company documents, paired with its integration and unit tests, among numerous other goodies.

All source code is littered with comments to help you understand what's going on and show you the way forward. If you already have experience with express.js you should feel right at home, only with less doubts and fear of touching the code due to the confidence boost that typings can provide.

Technologies

This is a Node.js project written in Typescript and built with the help of gulp. The API is served by an Express web server and is designed to connect to a MongoDB database (see section Environment for more). The database schema validation and connection with the database is achieved with mongoose. Project tests are run by Mocha against the Chai assertion library.

Getting Started

Dependencies

In order to launch NoMoTS API for production or development the following software need to be installed on the machine:

  1. Node.js v6.9.2 or greater [Download] 1.1. If you already have another node version installed you can use the tool n to download additional node versions and easily switch between them
  2. Git [Download]
  3. MongoDB [Download]

Deploy

To deploy in production copy and paste the following single command in your Unix terminal:

git clone https://github.com/maninak/NoMoTS-api.git && cd NoMoTS-api && npm i --only=production && npm build && npm start

This will:

  1. clone the source code
  2. change into the source code directory
  3. install project dependencies
  4. build source code
  5. launch NoMoTS API

Develop

You can get set-up for development and extend the boilerplate by copy-pasting the following three commands into three (3) separate Unix terminals:

Terminal 1:

git clone https://github.com/maninak/NoMoTS-api.git && cd NoMoTS-api && npm i && cp env/dev.template.env env/.env && npm run watch

This will:

  1. clone the source code
  2. change into the source code directory
  3. install project dependencies
  4. launch watch task which upon each source code change will:
    • delete dist folder that contains the resulting files of a previous build (this folder is NOT version-controlled)
    • run a linter against all .ts files, as per the rules specified in tslint.json
    • copy any assets from src/assets into dist/src/assets
    • set development environment variables using the template dev.template.env found in the env folder.
    • transpile all .ts file to .js files (with inline sourcemaps) and place them into the dist folder
    • run all tests found in the test folder

Terminal 2:

npm run localmongo

This will create and use a ephemeral mongo-test folder at the project's root directory and then launch a mongod mongoDB demon that uses this folder as its db directory. This folder is NOT version-controlled.

Terminal 3:

npm run demon

This will launch the API web server using nodemon instead of node and will automatically restart the API upon each source code change (practically every time npm run watch recompiles any changed .ts files).

NPM Scripts

The file package.json found in root directory contains many useful scripts which can be executed from the terminal with the format npm run <script_name>.

Here is a brief description of what each does:

  • postinstall is called automatically upon each npm install command and is hooked to a custom script. This script is useful to enforce repository state that all other tools cannot (e.g. install git hooks, apply simple edits on dependencies' source code using sed etc).,
  • localmongo see section Terminal 2
  • start launches the API web server (must have been built first)
  • demon see section Terminal 3
  • watch see section Terminal 1
  • build builds a production version of the app from source into dist folder.
  • build:dev builds a development version of the app from source into dist folder, including inline javascript source maps.
  • test runs all test present in the test folder
  • release see section Release Versioning
  • clean deletes dist folder
  • clean:node deletes node_modules folder (rm -rf is dangerous, stay safe)
  • clean:purge deletes everything that isn't tracked by git or is ignored by git (useful to fall back to git clone state)

Environment

Upon launch, NoMoTS API looks for the file .env inside the env/ folder from which it loads any specified environment variables. If no file is found, then the application falls back to using hardcoded development values. There is also a suggested production configuration template found in env/prod.template.env.

Contrary to the template files, the env/.env file (if you create one) is NOT version-controlled.

NOTE: Never store private secrets such as API keys, tokens, passwords etc in the *.template.env files! Always store such data in gitignored files for security concerns!

Demo API specification

Headers

For every request wherein API callers supply data in the body you will need to send the data in a valid json format and to have set in your header the following:

Key Value
Content-Type application/json



/companies

Actions

METHOD DESCRIPTION
GET Retrieve all existing Company documents

GET request parameters

PROPERTY TYPE REQUIRED LOCATION
- - - -

Example cURL request:

curl  --request GET \
      --url https://nomots.herokuapp.com/api/companies



/companies/:id

Actions

METHOD DESCRIPTION
GET Retrieve a single existing Company document
PUT Overwrite an existing Company document
PATCH Update the beneficiaries of an existing Company document
DELETE Delete an existing Company document

GET request parameters

PROPERTY TYPE REQUIRED LOCATION
id string true URL parameters

Example cURL request:

curl  --request GET \
      --url https://nomots.herokuapp.com/api/companies/594fd05c485492725edd8d20 \
      --header 'content-type: application/json'

PUT request parameters

PROPERTY TYPE REQUIRED LOCATION
id string true URL parameters
name string true body
address string true body
city string true body
country string true body
email string false body
phone string false body
benef_owners [string] false body

Example cURL request:

curl  --request PUT \
      --url https://nomots.herokuapp.com/api/companies/594fd05c485492725edd8d20 \
      --header 'content-type: application/json' \
      --data '{
          "name": "New Company LTD",
          "address": "Markonian 88",
          "city": "Milan",
          "country": "Italy",
          "email": "info@newcompany.com",
          "phone": "+55 123 45 67 890",
          "benef_owners": [
              "Mitsos",
              "Dick"
          ]
      }'

PATCH request parameters

PROPERTY TYPE REQUIRED LOCATION
id string true URL parameters
benef_owners [string] true body

Example cURL request:

curl  --request PATCH \
      --url https://nomots.herokuapp.com/api/companies/594fd05c485492725edd8d20 \
      --header 'content-type: application/json' \
      --data '{
          "benef_owners": [
              "Mitsos",
              "Dick"
          ]
      }'

DELETE request parameters

PROPERTY TYPE REQUIRED LOCATION
id string true URL parameters

Example cURL request:

curl  --request DELETE \
      --url https://nomots.herokuapp.com/api/companies/594fd05c485492725edd8d20



/companies/create

Actions

METHOD DESCRIPTION
POST Create a new Company document

POST request parameters

PROPERTY TYPE REQUIRED LOCATION
name string true body
address string true body
city string true body
country string true body
email string false body
phone string false body
benef_owners [string] false body

Example cURL request:

curl  --request POST \
      --url https://nomots.herokuapp.com/api/companies/create \
      --header 'content-type: application/json' \
      --data '{
          "name": "New Company LTD",
          "address": "Markonian 88",
          "city": "Milan",
          "country": "Italy",
          "email": "info@newcompany.com",
          "phone": "+55 123 45 67 890",
          "benef_owners": [
              "Mitsos",
              "Dick"
          ]
      }'

Contributing

Commit Guidelines

We hold very precise rules over how our git commit messages can be formatted. This leads to more readable messages that are easy to follow when looking through the project history. But also, we use the git commit messages to automatically generate the change log.

You can read more about the git commit guidelines in CONTRIBUTING.md found in project root.

Upon npm install, a commit-msg git hook is automatically installed that lints commit messages as per the rules defined in the CONTRIBUTING.md.

To disable the commit message linter:

  1. Delete the "postinstall" script from inside your package.json
  2. Delete the file commit-msg located at NoMoTS-api/.git/hooks

Commit Message Convention, at a Glance

patches:

git commit -a -m "fix(parsing): fix a bug in the parser"

features:

git commit -a -m "feat(parser): implement new parser \o/"

breaking changes:

git commit -a -m "feat(new-parser): introduce a new parsing library
BREAKING CHANGE: new library does not support foo-construct"

other changes:

You decide, e.g., docs, chore, etc.

git commit -a -m "docs: fixed up the docs a bit"

Git Flow

We use git flow (with default settings) to create feature, bugfix, etc branches.

Git flow can be practiced manually, but to make your life easy it's best to use automated tools that support it like GitKraken or a command-line tool.

Release Versioning

Because of the fact that git commit messages are structured, versioning is done automatically using conventional-changelog.

Running npm run release in your terminal will get the latest available develop, scan its commits, bump bugfix or minor (or none) version number in package.json depending on whether there are new features or not, update the CHANGELOG.md file with the latest changes since last release and merge everything locally in the lastest available master. It then also applies a git-tag with the version number.

If you feel it is needed feel free to make corrections/additions by amending the master commit. If everything looks good, push the master branch upstream with the command git checkout master && git push --follow-tags origin master

Helpful Resources

About

A Node.js API boilerplate, connected to MongoDB with Mongoose and implemented in Typescript.

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Sponsor this project

 

Packages

No packages published