Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/diegovictor/fastify-api
Project built during Rocketseat's Ignite
https://github.com/diegovictor/fastify-api
fastify javascript js knex node nodejs postgres rocketseat sqlite tests ts typescript vitest
Last synced: 15 days ago
JSON representation
Project built during Rocketseat's Ignite
- Host: GitHub
- URL: https://github.com/diegovictor/fastify-api
- Owner: DiegoVictor
- License: mit
- Created: 2023-02-10T17:35:20.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2025-02-04T22:27:23.000Z (15 days ago)
- Last Synced: 2025-02-04T23:26:09.666Z (15 days ago)
- Topics: fastify, javascript, js, knex, node, nodejs, postgres, rocketseat, sqlite, tests, ts, typescript, vitest
- Language: TypeScript
- Homepage:
- Size: 1020 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Fastify API
[data:image/s3,"s3://crabby-images/1bc50/1bc50df4d9c16d2ab2e1b6f2fa514287e605cfaa" alt="GitHub Workflow Status"](https://github.com/DiegoVictor/fastify-api/actions)
[data:image/s3,"s3://crabby-images/d4f4f/d4f4f21bced1eebeaaa86fda17f7fe013d1f3362" alt="postgres"](https://www.postgresql.org/)
[data:image/s3,"s3://crabby-images/bcfa7/bcfa7cbb53695598379a4091f34f48efca6c19ab" alt="sqlite3"](https://www.sqlite.org)
[data:image/s3,"s3://crabby-images/6b9de/6b9de8ceb0f69424227c15ae3fd70abdfdf1cf56" alt="typescript"](https://www.typescriptlang.org/)
[data:image/s3,"s3://crabby-images/f5b37/f5b37655cee7464d9fb4915def23521e2a81159f" alt="eslint"](https://eslint.org/)
[data:image/s3,"s3://crabby-images/2e923/2e923ac598aa96639f3c896c401404ff9e21bd5a" alt="airbnb-style"](https://github.com/airbnb/javascript)
[data:image/s3,"s3://crabby-images/8d70f/8d70f2a69d3f6b310621983e3c872b1284e43151" alt="vitest"](https://vitest.dev/)
[data:image/s3,"s3://crabby-images/55ebc/55ebc8b54fa5f0e8056c4fae3692abeeac1150c0" alt="coverage"](https://codecov.io/gh/DiegoVictor/fastify-api)
[data:image/s3,"s3://crabby-images/19054/190542483d62a2debecabbe4f65e674e8a9bee0a" alt="MIT License"](https://raw.githubusercontent.com/DiegoVictor/fastify-api/main/LICENSE)
[data:image/s3,"s3://crabby-images/ea2ad/ea2ad7051a04b3895ad2d7d4d7aee930c47eadfb" alt="PRs Welcome"](http://makeapullrequest.com)
[data:image/s3,"s3://crabby-images/2ca39/2ca399a061133a13815f583565763ad93879a1e2" alt="Run in Insomnia}"](https://insomnia.rest/run/?label=Fastify%20API&uri=https%3A%2F%2Fraw.githubusercontent.com%2FDiegoVictor%2Ffastify-api%2Fmain%2FInsomnia_2024-12-16.json)Small and simple transactions API developed with [Fastify](https://www.fastify.io/).
## Table of Contents
* [Installing](#installing)
* [Configuring](#configuring)
* [Migrations](#migrations)
* [.env](#env)
* [Usage](#usage)
* [Routes](#routes)
* [Requests](#requests)
* [Running the tests](#running-the-tests)
* [Coverage report](#coverage-report)# Installing
Easy peasy lemon squeezy:
```
$ yarn
```
Or:
```
$ npm install
```
> Was installed and configured the [`eslint`](https://eslint.org/) and [`prettier`](https://prettier.io/) to keep the code clean and patterned.## Configuring
The application use just one database, you can choose between: [SQLite](https://www.sqlite.org/index.html) and [Postgres](https://www.postgresql.org/), look to [env](#env) to see how.### Migrations
Remember to run the migrations:
```
$ yarn knex:migrate
```
Or:
```
$ npx knex migrate:latest
```
> See more information on [Knex Migrations](https://knexjs.org/guide/migrations.html).### .env
In this file you may configure the environment, your app's port and a url to documentation (this will be returned with error responses, see [error section](#error-handling)). Rename the `.env.example` in the root directory to `.env` then just update with your settings.|key|description|default
|---|---|---
|NODE_ENV|App environment.|`development`
|DATABASE_CLIENT|Postgres (`pg`) or SQLite (`sqlite`).|`sqlite`
|DATABASE_URL|If `DATABASE_CLIENT` is `sqlite` this should be the path to the database file, but if `DATABASE_CLIENT` is `pg` it should be the URL to connect to the database.|`./db/fastify-api.sqlite`
|PORT|Port number where the app will run (optional).|`3000`# Usage
To start up the app run:
```
$ yarn dev:server
```
Or:
```
npm run dev:server
```## Routes
|route|HTTP Method|params|description
|:---|:---:|:---:|:---:
|`/transactions`|POST|Body with user transaction `type`, `title` and `amount`.|Create a new transaction (`credit` or `debit`).
|`/transactions`|GET| - |Get all transactions.
|`/transactions/:id`|GET|`id` of the transaction|Get one transaction.
|`/transactions/summary`|GET| - |Return transactions summary.### Requests
* `POST /connections`Request body:
```json
{
"type": "credit",
"title": "Deposit",
"amount": 1000
}
```# Running the tests
[Vitest](https://vitest.dev) was the choice to test the app, to run:
```
$ yarn test
```
Or:
```
$ npm run test
```## Coverage report
You can see the coverage report inside `tests/coverage`. They are automatically created after the tests run.