Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/evans-costa/consumeterai
Um serviço que gerencia medição e leitura individualizada de consumo de água e gás usando a Gemini AI
https://github.com/evans-costa/consumeterai
ai docker fastify gemini-api nodejs postgresql typescript
Last synced: 4 days ago
JSON representation
Um serviço que gerencia medição e leitura individualizada de consumo de água e gás usando a Gemini AI
- Host: GitHub
- URL: https://github.com/evans-costa/consumeterai
- Owner: evans-costa
- Created: 2024-08-27T12:45:39.000Z (5 months ago)
- Default Branch: main
- Last Pushed: 2024-09-16T13:43:28.000Z (4 months ago)
- Last Synced: 2025-01-22T02:14:56.325Z (4 days ago)
- Topics: ai, docker, fastify, gemini-api, nodejs, postgresql, typescript
- Language: TypeScript
- Homepage:
- Size: 441 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
Leitor de Consumo AI
Um serviço que gerencia medição e leitura individualizada de consumo de água e gás, feito com Typescript e Node.js, usando o Google Gemini AI
![Typescript](https://img.shields.io/badge/TypeScript-007ACC?style=for-the-badge&logo=typescript&logoColor=white)
![NodeJS](https://img.shields.io/badge/node.js-6DA55F?style=for-the-badge&logo=node.js&logoColor=white)
![Fastify](https://img.shields.io/badge/fastify-%23000000.svg?style=for-the-badge&logo=fastify&logoColor=white)
![Gemini](https://img.shields.io/badge/Google%20Gemini-8E75B2?style=for-the-badge&logo=googlegemini&logoColor=white)
![Postgres](https://img.shields.io/badge/postgres-%23316192.svg?style=for-the-badge&logo=postgresql&logoColor=white)
![Docker](https://img.shields.io/badge/docker-%230db7ed.svg?style=for-the-badge&logo=docker&logoColor=white)
![Zod](https://img.shields.io/badge/zod-%233068b7.svg?style=for-the-badge&logo=zod&logoColor=white)
![Swagger](https://img.shields.io/badge/-Swagger-%23Clojure?style=for-the-badge&logo=swagger&logoColor=white)
Recursos principais •
Como usar •
Melhorias •
Créditos •
TODO## Recursos principais
- Faça o upload de uma imagem de um medidor de gás ou água
- A IA irá ler a imagem e obter a medição, retornando o valor
- A aplicação irá pedir a confirmação o valor dessa medição
- Salva no banco de dados os dados da medição, com o seu tipo (água ou gás)
- Lista todas as medições pelo código do consumidor## Como usar
Para clonar essa aplicação, você precisará ter instalado na sua máquina o [Node.js](https://nodejs.org/en/download/) (que vem com o [npm](http://npmjs.com)) e o [Docker](https://www.docker.com/get-started/) com [Docker Compose](https://docs.docker.com/compose/install/).
- Da sua linha de comando:
```bash
# Clone este repositório
$ git clone https://github.com/evans-costa/teste-dev-shopper.git# Vá para a pasta do repositório
$ cd teste-dev-shopper
```- Renomeie o arquivo `.env.example` para `.env` e preencha com a API KEY do Gemini
```env
NODE_ENV=developmentPOSTGRES_PORT=5432
POSTGRES_USER=local_user
POSTGRES_DB=local_db
POSTGRES_PASSWORD=local_passwordDATABASE_URL=postgres://$POSTGRES_USER:$POSTGRES_PASSWORD@localhost:$POSTGRES_PORT/$POSTGRES_DB
GEMINI_API_KEY=
```> **📌 Nota:**
> Para gerar uma chave de API do Google Gemini, por favor, siga as instruções contidas [nesse link](https://ai.google.dev/gemini-api/docs/api-key?hl=pt-br).### Ambiente local
Para rodar essa aplicação localmente, siga essas instruções:
- Instale as dependências:
```bash
# Instale as dependências
$ npm install
```
- Rode o seguinte comando:```bash
# Suba os serviços e o servidor
$ npm run dev:local
```Isto irá subir o contêiner com o banco de dados, rodar as migrações, fazer o seed de um usuário na tabela `customers` e subir o servidor no endereço `http://localhost:3000`
### Ambiente conteinerizado
- Alternativamente, você pode subir todos os serviços, tanto a aplicação Node e os serviços do banco de dados, em uma rede de contêineres Docker
- Rode o seguinte comando:```bash
# Suba os serviços e o servidor
$ npm run services:up
```Isso irá subir o contêiner do PostgreSQL, o contêiner do Node e estabelecer a conexão entre eles, assim como instalar as dependências, rodar as migrações e fazer o seed de um usuário na tabela `customers`, além de rodar o servidor no endereço `http://localhost:3000`
### Testando a API
- Você agora pode testar a API da seguinte maneira:
- Use o `customer_code`: `33f02178-e1bd-466d-a9a6-fa3f56cacda1`, criado no momento do seed do banco de dados, para testar os endpoints.
- Acesse `http://localhost:3000/documentation`, onde todos os endpoints da aplicação estão expostos por meio da interface do `SwaggerUI`
**OU**
- No seu cliente API REST de preferência como [Insomnia](https://insomnia.rest/download), [Postman](https://www.postman.com/), [Hoppscotch](https://hoppscotch.io/)...## Melhorias
- Uso de `conventional commits` aliado ao `Husky` e o pacote `commitlint` para automatizar os commits usando o comando `npm run commit`, assim, no momento do commit, as definições já são expostas na CLI;
- Documentação com o uso do Swagger;
- Separação de responsabilidades usando repositórios, controllers e services;
- Tratamento de erros;
- Scripts de linting garantindo qualidade e estilização do código;
- Migrações e seed do banco de dados.## Créditos
Esse como parte do desafio para a vaga de Desenvolvedor Full Stack da Shopper
## TODO
- [ ] Testes automatizados
> GitHub [@evans-costa](https://github.com/evans-costa) ·
> LinkedIn [@evandro-souzac](https://www.linkedin.com/in/evandro-souzac/) ·
> Site [@evandrocosta.dev.br](https://evandrocosta.dev.br)