Ecosyste.ms: Awesome

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

Awesome Lists | Featured Topics | Projects

https://github.com/jrsousadev/live-chat-api

πŸ’¬ Live chat with Websocket, Nodejs, Prisma and Jest
https://github.com/jrsousadev/live-chat-api

backend jest mongodb nodejs prisma socket-io supertest websocket

Last synced: about 2 months ago
JSON representation

πŸ’¬ Live chat with Websocket, Nodejs, Prisma and Jest

Awesome Lists containing this project

README

        

## 😺 Live chat project API using mongodb, nodejs, prisma, supertest and jest

API Desenvolvida para ser consumida no live-chat-web

## O que foi utilizado no projeto

- [x] Typescript
- [x] Express
- [x] MongoDB
- [x] Mocks
- [x] Supertest
- [x] Jest
- [x] Prisma
- [x] Nodejs

### Regras de negΓ³cio

- [x] Create message
- [x] Get message
- [x] Get last message by chat
- [x] Get all messages by chat
- [x] Delete all messages
- [x] Create chat
- [x] Create group chat
- [x] Get all chats by user
- [x] Get chat
- [x] Create user
- [x] Get user

### Endpoints Message

- [x] [POST] "/api/message"
- [x] [GET] "/api/message/chat/:chatId"
- [x] [GET] "/api/message/lastMessage/:chatId"
- [x] [GET] "/api/message/:id"
- [x] [DELETE] "/api/message/all"

### Endpoints Chat:

- [x] [POST] "/api/chat"
- [x] [POST] "/api/chat/group"
- [x] [GET] "/api/chat/user/:userId"
- [x] [GET] "/api/chat/:id"

### Endpoints Use:

- [x] [POST] "/api/user"
- [x] [GET] "/api/user/:id"

### Arquitetura do Projeto

```
.
β”œβ”€β”€ prisma
β”œβ”€β”€ src/
β”‚ └── app
β”‚ └── modules
β”‚ └── repositories
β”‚ └── utils
β”‚ └── shared
β”‚ └── errors
β”‚ └── routes
β”‚ └── app.ts
β”‚ └── server.ts
β”‚ └── websocket.ts
β”‚ └── config
β”‚ └── database
β”‚ └── domain
β”‚ └── entities
β”œβ”€β”€ tests/
β”‚ └── _database
β”‚ └── _modules
β”‚ └── _repositories
β”‚ └── _seed
└── ...
```

### Iniciando o Projeto

- Clone o repositΓ³rio e instale as dependΓͺncias.
```sh
# install dependencies
> npm i

# copy .env file
> cp .env.example .env

# Generating mongoDB with prisma models
> npm prisma generate

# Init tests
> npm run test

# start project
> npm run dev

# open in
http://localhost:8080/
```