Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/l2jliga/fastify-decorators
Set of Typescript decorators to build Fastify server with controllers, services and hooks
https://github.com/l2jliga/fastify-decorators
decorators dependency-injection fastify fastify-plugin request-handler typescript
Last synced: 4 days ago
JSON representation
Set of Typescript decorators to build Fastify server with controllers, services and hooks
- Host: GitHub
- URL: https://github.com/l2jliga/fastify-decorators
- Owner: L2jLiga
- License: mit
- Created: 2019-05-11T06:19:35.000Z (over 5 years ago)
- Default Branch: v4
- Last Pushed: 2025-01-01T02:26:44.000Z (21 days ago)
- Last Synced: 2025-01-10T12:50:49.608Z (11 days ago)
- Topics: decorators, dependency-injection, fastify, fastify-plugin, request-handler, typescript
- Language: TypeScript
- Homepage:
- Size: 6.25 MB
- Stars: 290
- Watchers: 5
- Forks: 26
- Open Issues: 14
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Security: SECURITY.md
Awesome Lists containing this project
README
[![Fastify decorators](./assets/logo.png)](https://github.com/L2jLiga/fastify-decorators)
[![npm version](https://badge.fury.io/js/fastify-decorators.svg?colorB=brightgreen)](https://www.npmjs.com/package/fastify-decorators)
[![npm](https://img.shields.io/npm/dm/fastify-decorators.svg?colorB=brightgreen)](https://www.npmjs.com/package/fastify-decorators)[![License: MIT](https://img.shields.io/badge/License-MIT-brightgreen.svg)](https://opensource.org/licenses/MIT)
[![Node.js CI](https://github.com/L2jLiga/fastify-decorators/actions/workflows/nodejs.yml/badge.svg)](https://github.com/L2jLiga/fastify-decorators/actions/workflows/nodejs.yml)
[![codecov](https://codecov.io/gh/L2jLiga/fastify-decorators/branch/v4/graph/badge.svg)](https://codecov.io/gh/L2jLiga/fastify-decorators)> **Framework aimed to provide useful TypeScript decorators to implement controllers, services and request handlers, built with [Fastify].**
## Benefits
- **Fastify compatible** - Built with [Fastify] and supports all its features and plugins
- **JSON Schema validation** - Build [JSON Schemas](https://json-schema.org/) to validate and speedup your requests and replies
- **High performance** - Framework adds as less overhead to Fastify as it can
- **Highly customizable** - Create your controllers, services and their methods as you wish
- **100% TypeScript** - Written in [TypeScript](https://www.typescriptlang.org/) and comes with all the required typings
- **Plugins** - Library provides APIs to extend its functionality
- [**Simple DI**](./plugins/simple-di) - Provides simple Dependency Injection interface to bind your services
- [**TypeDI**](./plugins/typedi) - Provides integration with [TypeDI](https://npmjs.com/package/typedi)## Documentation
- [Getting started](#getting-started)
- [Bootstrapping]
- [Controllers]
- [Request Handlers]
- [Testing]
- [Plugins Development]
- [Migration guide (V4)]## Fastify versions support
| Fastify Decorators | Fastify |
| :----------------: | :-------: |
| 1.x | 2.x |
| 2.x | 2.x |
| < 3.12.x | 3.x |
| >= 3.12.x | 3.x & 4.x |
| 4.x | 4.x |## Alternatives
- **[NestJS]** - A progressive Node.js framework for building efficient, reliable and scalable server-side applications.
- **[Fastify Resty]** - Modern and declarative REST API framework for superfast and oversimplification backend development, build on top of Fastify and TypeScript.## Getting started
Hello! Thank you for checking out fastify-decorators!
This documents aims to be gentle introduction to the fastify-decorators and its usages.
### Prerequisites
- Typescript
- Fastify
- typings for NodeJS (`@types/node` package installed)### Install
Install with npm
```
npm i fastify-decorators --save
```Install with yarn
```
yarn add fastify-decorators
```### Additional TypeScript configuration
Fastify-decorators requires `experimentalDecorators` feature to be enabled. For this you need to update your TypeScript config:
_tsconfig.json_:
```json
{
"compilerOptions": {
"experimentalDecorators": true
}
}
```_Note_: if you struggle which `target` please refer to table below:
| Node version | target |
| ------------ | ------ |
| 14.x | es2020 |
| 16.x | es2021 |
| 18.x | es2022 |`fastify-decorators` itself use `"target": "es2018"` to support NodeJS 10+ (see [Node.js ES2018 Support]).
### Your first server
#### Request handler way
Let's write your first server with request handler:
_Project structure_:
```
├── index.ts
├── handlers
│ └── first.handler.ts
└── tsconfig.json
```_index.ts_:
```ts
import { bootstrap } from 'fastify-decorators';// Require the framework and instantiate it
const instance = require('fastify')();// Register handlers auto-bootstrap
instance.register(bootstrap, {
// Specify directory with our handler
directory: new URL(`handlers`, import.meta.url),// Specify mask to match only our handler
mask: /\.handler\./,
});// Run the server!
instance.listen(3000);
```_handlers/first.handler.ts_:
```ts
import { GET, RequestHandler } from 'fastify-decorators';@GET({
url: '/hello',
})
export default class FirstHandler extends RequestHandler {
async handle() {
return 'Hello world!';
}
}
```#### Controllers way
fastify-decorators also provides way to build controllers with multiple handlers:
_Project structure_:
```
├── index.ts
├── controllers
│ └── first.controller.ts
└── tsconfig.json
```_index.ts_:
```ts
import { bootstrap } from 'fastify-decorators';// Require the framework and instantiate it
const instance = require('fastify')();// Register handlers auto-bootstrap
instance.register(bootstrap, {
// Specify directory with our controllers
directory: new URL(`controllers`, import.meta.url),// Specify mask to match only our controllers
mask: /\.controller\./,
});// Run the server!
instance.listen(3000);
```_controllers/first.controller.ts_:
```ts
import { Controller, GET } from 'fastify-decorators';@Controller({ route: '/' })
export default class FirstController {
@GET({ url: '/hello' })
async helloHandler() {
return 'Hello world!';
}@GET({ url: '/goodbye' })
async goodbyeHandler() {
return 'Bye-bye!';
}
}
```Also, we need to enable `experimentalDecorators` feature in our TypeScript config
_tsconfig.json_:
```json
{
"compilerOptions": {
"experimentalDecorators": true
}
}
```### Build and run server
After all our files done we have to build server before we can run it:
1. Add to our package.json script to build server:
```
"scripts": {
"build": "tsc"
}
```1. Run build script
With npm:```
npm run build
```with yarn:
```
yarn build
```1. Start server
```
node index.ts
```Awesome, that was easy.
[node.js es2018 support]: https://node.green/#ES2018
## License
This project licensed under [MIT License]
[fastify]: https://npmjs.org/package/fastify
[mit license]: https://github.com/L2jLiga/fastify-decorators/blob/master/LICENSE
[nestjs]: https://nestjs.com/
[fastify resty]: https://github.com/FastifyResty/fastify-resty
[bootstrapping]: ./docs/Bootstrapping.md
[controllers]: ./docs/Controllers.md
[request handlers]: ./docs/Request%20Handlers.md
[testing]: ./docs/Testing.md
[migration guide (v4)]: ./docs/Migration%20to%20v4.md
[Plugins Development]: ./docs/Plugins%20Development.md