Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/diegovictor/functional-api
Study Case API with SOLID and no OOP
https://github.com/diegovictor/functional-api
api api-rest dependency-injection firebase firestore functional-api javascript jest js microservices node nodejs tests ts typescript
Last synced: 4 months ago
JSON representation
Study Case API with SOLID and no OOP
- Host: GitHub
- URL: https://github.com/diegovictor/functional-api
- Owner: DiegoVictor
- License: mit
- Created: 2022-03-22T23:13:44.000Z (almost 3 years ago)
- Default Branch: main
- Last Pushed: 2024-02-22T13:18:28.000Z (12 months ago)
- Last Synced: 2024-02-22T14:30:44.681Z (12 months ago)
- Topics: api, api-rest, dependency-injection, firebase, firestore, functional-api, javascript, jest, js, microservices, node, nodejs, tests, ts, typescript
- Language: TypeScript
- Homepage:
- Size: 1.17 MB
- Stars: 6
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Functional API
[data:image/s3,"s3://crabby-images/4a98b/4a98b4295377dd70d748bb57c7bc5977cc846029" alt="AppVeyor"](https://ci.appveyor.com/project/DiegoVictor/functional-api)
[data:image/s3,"s3://crabby-images/81f0f/81f0f4e7a082f3d70688e5c4c49b4f35dcb6e13e" alt="firebase"](https://firebase.google.com/)
[data:image/s3,"s3://crabby-images/605b8/605b8ae339eb6aa1cb7e7149e33131b8126cdd03" alt="babel"](https://babeljs.io/)
[data:image/s3,"s3://crabby-images/96d0f/96d0f75c10c4bf4c4a35ddaa3c9d9c4d74c17b25" alt="prettier"](https://prettier.io/)
[data:image/s3,"s3://crabby-images/a3fa3/a3fa36a797130b182f6898bc86ec7c9c35a20af8" alt="nodemon"](https://nodemon.io/)
[data:image/s3,"s3://crabby-images/fc722/fc7226be90e56e7eacd345c23edb4d07eb0c30d1" 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/4c23e/4c23e06cb67a06cbe92fa5a3439430d80ec2c5e7" alt="jest"](https://jestjs.io/)
[data:image/s3,"s3://crabby-images/f9889/f9889c71f23cb246f7bbb34ee9b1d1c1330017b7" alt="typescript"](https://www.typescriptlang.org/)
[data:image/s3,"s3://crabby-images/bba1a/bba1af3489474fa006f1e3b541d4cdb3be0f3822" alt="coverage"](https://app.codecov.io/gh/DiegoVictor/functional-api)
[data:image/s3,"s3://crabby-images/19054/190542483d62a2debecabbe4f65e674e8a9bee0a" alt="MIT License"](https://raw.githubusercontent.com/DiegoVictor/functional-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=Functional%20API&uri=https%3A%2F%2Fraw.githubusercontent.com%2FDiegoVictor%2Ffunctional-api%2Fmain%2FInsomnia_2022-06-11.json)Study Case to figure out a simple way to have dependency injection and dependency inversion principle using only functions (not classes here, sorry OOP guys).
> This API makes usage of a external service that generates random names, see more in: [Named API](https://github.com/DiegoVictor/named-api) and [Named Web](https://github.com/DiegoVictor/named-web).## Table of Contents
* [Requirements](#requirements)
* [Installing](#installing)
* [Firebase](#firebase)
* [Service Account](#service-account)
* [Script](#script)
* [Development](#development)
* [Usage](#usage)
* [Deploy](#deploy)
* [Routes](#routes)
* [Running the tests](#running-the-tests)
* [Coverage report](#coverage-report)# Requirements
* Node.js ^18.19.0
* Firebase Account
* [Functions](https://firebase.google.com/docs/functions)
* [Firestore](https://firebase.google.com/docs/firestore)# 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.## Firebase
First, [create a project into Firebase](https://firebase.google.com/docs/android/setup#create-firebase-project), then [create a database](https://firebase.google.com/docs/firestore/quickstart).### Service Account
Create a service account:* [Service Account](https://console.firebase.google.com/project/_/settings/serviceaccounts/adminsdk?authuser=0)
Then save it in `src\config\service-account.json`.
### Script
There is a script (`scripts/main.js`) that setup a feature flag required by the application, to run:
```
$ node scripts/main.js
```
Now your are ready to go# Development
Improve the development velocity running the `watch` script to rebuild the project everytime a file in `src` folder changes.
```
npm run watch
```
Or:
```
yarn watch
```
> Then you can just run the `serve` script once.# Usage
Run the `build` script:
```
npm run build
```
Or:
```
yarn build
```
Then you are ready to start the server:
```
npm run serve
```
Or:
```
yarn serve
```## Deploy
```
npm run deploy
```
Or:
```
yarn deploy
```
> Deploy the functions is very easy, but is requires a [Blaze (pay-as-you-go) plan](https://firebase.google.com/pricing?authuser=0&hl=pt).## Routes
route|HTTP Method|params|description
---|---|---|---
`/featureFlags`|GET| - |Returns all flags in the database.
`/featureFlags/:key`|GET| `key` of the flag.|Returns the specified flag.
`/randomNames`|GET| - | Returns random names in raw text or in base64 format (depends if the flag is enable or not).# Running the tests
[Jest](https://jestjs.io/) was the choice to test the app, to run:
```
$ yarn test
```
Or:
```
$ npm run test
```
> Run the command in the root folder## Coverage report
You can see the coverage report inside `tests/coverage`. They are automatically created after the tests run.