Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jpb06/dev-friends-backend-starter
Let's do some backend things using nestjs and prisma!
https://github.com/jpb06/dev-friends-backend-starter
jest nestjs prisma workshop
Last synced: 1 day ago
JSON representation
Let's do some backend things using nestjs and prisma!
- Host: GitHub
- URL: https://github.com/jpb06/dev-friends-backend-starter
- Owner: jpb06
- Created: 2021-07-08T20:29:24.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2023-01-26T17:34:47.000Z (almost 2 years ago)
- Last Synced: 2024-11-13T03:08:53.090Z (2 months ago)
- Topics: jest, nestjs, prisma, workshop
- Language: TypeScript
- Homepage:
- Size: 412 KB
- Stars: 2
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# ๐ฅ DevFriends backend workshop
[![Open in Visual Studio Code](https://img.shields.io/static/v1?logo=visualstudiocode&label=&message=Open%20in%20Visual%20Studio%20Code&labelColor=2c2c32&color=007acc&logoColor=007acc)](https://open.vscode.dev/jpb06/dev-friends-backend-starter)
![Last commit](https://img.shields.io/github/last-commit/jpb06/dev-friends-backend-starter?logo=git)Here is a project to do some backend stuffs. Let's have some fun! โจ
## โก Requirements
You will need the following to work on this workshop:
| Item | Description | Documentation |
| --------- | -------------------------------------------------------- | --------------------------------------------- |
| โ๏ธ nodejs | Duh! | |
| ๐ณ Docker | we will use docker to launch a postgres instance | |
| ๐งถ yarn | We will use yarn as the package manager for this project | |## โก How to start
### ๐ถ Firstof, let's start our database using docker
```bash
yarn start:db
```### ๐ถ Launching our tests
```bash
yarn test:watch
```### ๐ถ Launching our backend in dev mode (port 3001)
```bash
yarn start:dev
```### ๐ถ Building our app for production
```bash
yarn build
```## โก Data model
Our sample database contains developers along with their squads, their skills and their ownerships on repositories.
Let's take a look at the schema:
![Diagram](./misc/db-diagram.png)
## โก Give me features to complete now
### ๐ถ Guidelines
| Guideline | Description |
| ------------------------------- | --------------------------------------------------------------------------------------------- |
| ๐ช Use only typescript | No javascript allowed! |
| ๐ช Be modular | nestjs is based on the same principles as angular. Remember modules are cool! |
| ๐ช Follow RESTful principles | Define your endpoints in the most logical way from these principles |
| ๐ช Make sure to validate inputs | Endpoints should return a specific response when input is invalid |
| ๐ช Standardize responses | If a resource is not found, return a 400 response, if something goes wrong, return a 500, etc |
| ๐ช Test your code | Make sure the codebase is properly tested |
### ๐ถ 1) Provide an endpoint to get all squads with their developers
This endpoint should return an array of objects containing squads data and an array of developers.
You will have to use prisma to generate a model; you will then be able to use prisma client to interact with the database.
#### โ Expected output
```
{
result: [
{
id: number,
name: string,
devs: [
{
id: number,
name: string,
role: string
}
]
},
// ...
]
}```
### ๐ถ 2) Provide an endpoint to get a developer
This endpoint should return an object containing the dev infos as well as his squad, his skills and his ownerships.
#### โถ๏ธ Input
```
developer id (number)
```#### โ Expected output
```
{
result: {
id: number,
name: string,
squad: {
id: number,
name: string,
},
skills: [
{
id: number,
name: string,
level: number,
aquiredAt: Date
},
// ...
],
ownerships: [ // repos
{
id: number,
name: string
},
// ...
]
}
}
```
### ๐ถ 3) Provide an endpoint to get all the developers matching a skill
By providing the id of a skill, we expect to get the developers who aquired this skill.
#### โถ๏ธ Input
```
skill id (number)
```#### โ Expected output
```
{
result: [
{
id: number,
name: string,
level: number,
aquiredAt: Date
}
// ...
]
}
```
### ๐ถ 4) Provide an endpoint to change the squad of a developer
This endpoint should change the squad of a developer and return the developer.
#### โถ๏ธ Input
```
developer id (number)
new squad id (number)
```#### โ Expected output
```
{
result: {
id: number,
name: string,
squad: {
id: number,
name: string,
},
}
}
```
### ๐ถ 5) Provide an endpoint to update the owner of a repo
This route is a tricky one. We want to change the owner of a repo by picking, within a squad, the developer having the most experience in a list of skills. If no developer stands out from the crowd, then we shall choose by order of precedence the champion or the squad owner within the squad.
#### โถ๏ธ Input
```
{
idRepo: number,
idSquad: number,
skills: number[]
}
```#### โ Expected output
```
{
result: boolean
}
```
### ๐ถ 6) Add swagger to the stack and fully document each route
We want more documentation! Let's setup a swagger on our api to make sure routes can be easily interacted with and understood.
#### โ Expected result
- Inputs should be documented
- Outputs (possible responses) should all be documented
- A description of the route should be present
### ๐ถ 7) Provide an endpoint to authenticate users
This feature implies to alter the database and its model in order to store a login and a password for each user.
As for the login route:
#### โถ๏ธ Input
```
{
login: string,
password: string
}
```#### โ Expected output
```
{
result: {
token: string
}
}
```
### ๐ถ 8) Secure all the routes
Let's secure our api now! All our routes should be restricted to logged users.
#### โ Expected result
All our routes should now require authentication. A proper response should be returned if the caller is unauthorized.