Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/marlinsk/nestjs-backend-local-file-upload
Aplicação de upload de arquivos, onde o arquivo é armazenado localmente dentro do back-end. Aplicação desenvolvida com node.js, nest.js, multer, docker-compose, postgresql, prisma orm.
https://github.com/marlinsk/nestjs-backend-local-file-upload
docker docker-compose express javascript multer nestjs nodejs postgresql prisma typescript upload-file
Last synced: about 2 months ago
JSON representation
Aplicação de upload de arquivos, onde o arquivo é armazenado localmente dentro do back-end. Aplicação desenvolvida com node.js, nest.js, multer, docker-compose, postgresql, prisma orm.
- Host: GitHub
- URL: https://github.com/marlinsk/nestjs-backend-local-file-upload
- Owner: Marlinsk
- Created: 2023-07-07T04:16:13.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2023-07-22T16:32:06.000Z (over 1 year ago)
- Last Synced: 2024-11-10T02:14:07.700Z (2 months ago)
- Topics: docker, docker-compose, express, javascript, multer, nestjs, nodejs, postgresql, prisma, typescript, upload-file
- Language: TypeScript
- Homepage:
- Size: 346 KB
- Stars: 2
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Aplicação back-end NestJs de upload de arquivos
O grande recurso dessa aplicação é servir como um tipo de canal para salvar arquivos, que são enviados via web. Para esse canal funcionar em uma aplicação desenvolvida em **Node.js** e **Nest.js**, utiliza-se o **Express.js middleware multer**, através dele podemos tratar e manipular diferentes tipos e formatos de arquivos que o back-end captura em uma **requisição HTTP**. Para poder salvar o arquivo recebido, existem duas formas, a primeira através de integração com algum serviço de cloud como por exemplo um **Bucket** na **AWS**, a segunda opção é salvar em uma pasta de uploads dentro da aplicação. A opção de salvar o arquivo dentro da aplicação não é muito recomendável ser feito em aplicações que são alocadas dentro de conteineres, pois se o container cair, os arquivos somem ou são corrompidos, por isso utiliza-se essa técnica em projetos de escala menor ou de estudos, mas vale a pena fazer para entender como tudo funciona por baixo dos panos. Nesta aplicação, optei por utilizar a segunda opção, por ser gratuita e não ser dependente de um serviço de cloud.## Descrição
A aplicação tem dois componentes de funcionalidade, sendo elas o com o banco de dados, onde é salvo os dados importantes do arquivo como por exemplo o nome e o caminho do arquivo, isso é feito para auxiliar na gestão do arquivo por meio de requisição HTTP, tendo esses dados salvos em um banco de dados, fica fácil do back-end buscar esse arquivo na pasta. O outro componente serve para salvar o arquivo na pasta de upload, esse componente na ocasião pega o nome original do arquivo e renomeia a partir de um conjunto de caracteres e depois o salva na pasta de uploads, isso é feito na ocasião para não ocorrer problemas de nome de arquivo igual dentro do sistema. A forma como esses arquivos são geridos são a partir dos dados salvos no banco de dados.## Clonando o projeto em sua máquina
Execute o comando abaixo para clonar o projeto:
```
git clone https://github.com/Marlinsk/upload-file-nestjs-application.git
```
Após clonar o repositório instale as dependências executando comando abaixo:
```
npm install
```
> Finalizando isso vamos para a próxima etapa que é gerar o banco de dados utilizando o docker compose.## Criação do banco de dados com Docker 🐳
Execute o seguinte comando no terminal para criar uma imagem com o banco de dados PostgreSQL:
```
docker-compose -f docker-compose.yml up -d
```
> Após a execução a imagem do banco de dados da aplicação será gerada no seu Docker.## Criando a estrutura básica do banco de dados 🐘
Crie um arquivo **.env** e cole o schema abaixo para se conectar com o banco de dados:
```
DATABASE_URL="postgresql://prisma:prisma@localhost:5433/upfiledb?schema=public"
```
Para criar as tabelas no banco de dados, execute o seguinte comando:
```
npx prisma db push
```## Rodando a aplicação 🚀
**Obs.:** Antes de por a aplicação para rodar, certifique-se que a imagem do banco de dados docker esteja rodando, caso contrário ocorrerá um erro.Para executar o servidor rode o seguinte comando:
```
npm run start:dev
```
> Se estiver tudo ok aparecerá a seguinte mensagem no terminal: Server starting 🚀 http://localhost:3000.## Rotas HTTP da aplicação 🚏
Descrição das rotas da aplicação junto da instrução de como fazer a requisição pelo **Postman**.**POST** Upload file
Rota de upload do arquivo
> /
Para poder fazer a requisição nesta rota via **Postman,** acesse a aba body e clique em form-data, feito isso basta colocar o nome do campo na coluna **Key** para file e mudar o tipo dele para arquivo, feito isso aparecerá na coluna **Value** o **Select files**, clique nele e selecione o arquivo que deseja fazer upload, após isso só fazer a requisição.
**Obs.:** Em outras ferramentas, basta procurar uma opção de form-data na aba de corpo da requisição.
**GET** List all files
Lista todos os dados dos arquivos salvos na pasta **uploads**
> /
Basta fazer uma requisição http do tipo **GET** sem nenhum parâmetro na url
**GET** Get file
Busca um arquivo salvo na pasta **uploads** pelo id
> /:id
Faça uma requisição http do tipo **GET** com o id na url
**PATCH** Change file
Substitui o arquivo salvo com aquele id
> /:id
Repita o mesmo processo ensinado na requisição POST, mas passando o id na url do arquivo que deseja mudar, feito isso faça a requisição http no tipo PATCH.
**DELETE** Remove file
Remove o arquivo a partir do id dele registrado no banco
> /:id
Faça a requisição passando o id, fazendo isso o arquivo é removido junto com o dado salvo no banco de dados.