Nest framework TypeScript starter repository.
-
Clone the repository:
git clone [email protected]:jordicher/nestjs-typeorm-auth-template.git
-
Open a terminal in the repository API folder:
cd nestjs-typeorm-auth-template
-
Install dependencies:
npm install
-
Copy the
.env.example
file to.env
in the same root folder:cp .env.example .env
-
As it is, it should work, but you can change these parameters:
ACCESS_TOKEN_EXPIRATION
: expiration time of the JWT access tokenREFRESH_TOKEN_EXPIRATION
: expiration time of the JWT refresh tokenJWT_SECRET
: secret key used by JWT to encode access tokenJWT_REFRESH_SECRET
: secret key used by JWT to encode refresh tokenDATABASE_PORT
: port used by the API
-
In the root of the API project, edit the file
.env
and configure these parameters using your Postgres configuration.POSTGRES_NAME=template POSTGRES_PORT=5432 POSTGRES_PASSWORD=templateUserPass POSTGRES_USER=templateUser POSTGRES_HOST=localhost
-
Start the database with docker
$ npm run infra:up
# watch mode
$ npm run start:dev
# production mode
$ npm run start:prod
# e2e tests
$ npm run test:e2e
To create a migration and implement changes in the db.
//run old migrations, this project by default has a user migration
$ npm run migration:run
//generate a migration
$ npm run migration:generate name_new_migration
//run the migration
$ npm run migration:run
This template uses swagger for documentation. To see swagger, if you are using port 8080 for the api, it would be for example => localhost:8080/docs
This template uses jwt tokens and refresh tokens.
To make a route public for everyone you have to add the @Public decorator above the endpoint. Example, users.controller.ts / endpoint post, /users.
We can put three types of validations on the endpoints.
- That it has a valid token, access-token.
- That it has a valid token and is role x, example delete user can only be done by the admin role, Roles decorator.
- That the refresh token is valid.
The access token has to have a short lifetime, while the refresh token has to have a longer lifetime. (you can modify the duration by modifying the project variables).
When logging in, it returns the two tokens. The refresh token is encrypted in the database, and is reset every time the user logs in or out.
When an access token expires, the endpoint will return a custom error. httpStatus = 498 message = Token expired
In this case, a request must be made to auth/refresh-token that contains the refresh token in the header. This will return a valid access token.