Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/devenock/nestjsrestapi

A RESTful api built using NestJS
https://github.com/devenock/nestjsrestapi

mongodb nestjs typescript

Last synced: 25 days ago
JSON representation

A RESTful api built using NestJS

Awesome Lists containing this project

README

        

# Task Manager

## Description
Task Manager Application built using [Nest](http://nestjs.com/).

## Middleware

This is a function that is called before the route handler.
It has access to the `request`, `response` and the `next` middleware function.

`Nest` middlewares are by default the same as `express` middlewares and can perform the following tasks:
execute any code.
make changes to the request and the response objects.
end the request-response cycle.
call the next middleware function in the stack.
if the current middleware function does not end the request-response cycle, it must call next() to pass control to the next middleware function. Otherwise, the request will be left hanging.

You can implement a custom Nest middleware using a function or a class with the `@Injectable` decorator. The class should implement the `NestMiddleware` interface while the function does not have any specification.

## Exception filters

Nest comes with built in exception layers which is responsible for processing unhandled exceptions across an application.
When an exception is not handled by your application code, it is caught by this layer which then sends a response message to the user.

Out of the box, this functionality is handled by the `global exception filter` which handles exception of type `HttpException`.

## Throwing standard exceptions

Nest provides `HttpException` which is exposed from the `@nestjs/common` package.
For typical HTTP REST/GraphQL API based applications, it's best practice to send standard Http response object when certain error occurs.

## Custom Exceptions
In most cases, you will not need to write your own exceptions and just use the built in one but you have the flexibility to write your own `custom exceptions`.
Custom exceptions inherits from the base `HttpException` class.

## Built In HTTP-Exception

Nest provides a set of in-built exceptions that inherits the base HttpExceptions. These exceptions are exposed through the `@nestjs/common` package.

BadRequestException
UnauthorizedException
NotFoundException
ForbiddenException
NotAcceptableException
RequestTimeoutException
ConflictException
GoneException
HttpVersionNotSupportedException
PayloadTooLargeException
UnsupportedMediaTypeException
UnprocessableEntityException
InternalServerErrorException
NotImplementedException
ImATeapotException
MethodNotAllowedException
BadGatewayException
ServiceUnavailableException
GatewayTimeoutException
PreconditionFailedException

### Exception filters

Built in exceptions can handle many cases but a times you may want to control the exception layer.

## Pipes

A pipe is a class that is annotated using the `@Injectable` decorator which implements the `PipeTransform` interface.

Pipes have got two major use-cases:

`Transform`: Transform input data from one type to another. e.g string to number
`validation`: validates input data and throw exception.

Pipes operate on the `arguments` passed by a controller route handler.

Nest comes with in built pipes that you can use out-of-the box but you can also build your own custom pipes.

## Built In Pipes
ValidationPipe
ParseIntPipe
ParseFloatPipe
ParseBoolPipe
ParseArrayPipe
ParseUUIDPipe
ParseEnumPipe
DefaultValuePipe
ParseFilePipe
These built in pipes are derived from the `@nestjs/common` package.

### Binding Pipes
To use a pipe, we need to use an instance of the pipe class.

In our `ParseIntPipe` example, we want to associate the pipe with a particular route handler method, and make sure it runs before the method is called.

We do so with the following construct, which we'll refer to as binding the pipe at the method parameter level:

```
@Get(':id')
async getTaskById(@Param('id', ParseIntPipe) id: number) {
return this.taskService.findOne(id);
}
```

For example with a query string parameter:

```

@Get()
async findOne(@Query('id', ParseIntPipe) id: number) {
return this.catsService.findOne(id);
}
```

Here's an example of using the ParseUUIDPipe to parse a string parameter and validate if it is a UUID.
```
@Get(':uuid')
async findOne(@Param('uuid', new ParseUUIDPipe()) uuid: string) {
return this.catsService.findOne(uuid);
}
```

## Custom Pipes
As mentioned, you can build your own custom pipes. While Nest provides a robust built-in ParseIntPipe and ValidationPipe, let's build simple custom versions of each from scratch to see how custom pipes are constructed.

We start with a simple ValidationPipe. Initially, we'll have it simply take an input value and immediately return the same value, behaving like an identity function.

```
validation.pipe.ts
JS

import { PipeTransform, Injectable, ArgumentMetadata } from '@nestjs/common';

@Injectable()
export class ValidationPipe implements PipeTransform {
transform(value: any, metadata: ArgumentMetadata) {
return value;
}
}
```

## Installation

```bash
$ yarn install
```

## Running the app

```bash
# development
$ yarn run start

# watch mode
$ yarn run start:dev

# production mode
$ yarn run start:prod
```

## Test

```bash
# unit tests
$ yarn run test

# e2e tests
$ yarn run test:e2e

# test coverage
$ yarn run test:cov
```