mirror of
https://github.com/felipegcoutinho/openmonetis.git
synced 2026-05-09 11:01:45 +00:00
- README: seção "Como rodar" reescrita com 4 modos explicados para leigos - README: seção Docker atualizada (sem .env obrigatório, localhost funciona) - package.json: corrigir env:setup apontando para setup-env.sh deletado → setup.mjs - CHANGELOG 2.3.7: documentar fix do localhost→db e default DATABASE_URL Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
578 lines
22 KiB
Markdown
578 lines
22 KiB
Markdown
<p align="center">
|
|
<img src="./public/images/logo_small.png" alt="OpenMonetis Logo" height="80" />
|
|
</p>
|
|
|
|
<p align="center">
|
|
Projeto pessoal de gestão financeira. Self-hosted, manual e open source.
|
|
</p>
|
|
|
|
> **⚠️ Não há versão online hospedada.** Você precisa clonar o repositório e rodar localmente ou no seu próprio servidor.
|
|
|
|
[](CHANGELOG.md)
|
|
[](https://nextjs.org/)
|
|
[](https://www.typescriptlang.org/)
|
|
[](https://www.postgresql.org/)
|
|
[](https://www.docker.com/)
|
|
[](https://github.com/felipegcoutinho/openmonetis-companion)
|
|
[](LICENSE)
|
|
[](https://github.com/sponsors/felipegcoutinho)
|
|
|
|
---
|
|
|
|
<p align="center">
|
|
<img src="./public/images/dashboard-preview-light.webp" alt="Dashboard Preview" width="800" />
|
|
</p>
|
|
|
|
<p align="center">
|
|
<img src="./public/images/preview-lancamentos-light.webp" alt="Lançamentos" width="800" />
|
|
</p>
|
|
|
|
---
|
|
|
|
## 📖 Índice
|
|
|
|
- [Sobre o Projeto](#-sobre-o-projeto)
|
|
- [Como rodar o OpenMonetis](#-como-rodar-o-openmonetis)
|
|
- [Antes de tudo: preparar o servidor](#-antes-de-tudo-preparar-o-servidor-ubuntu-2404)
|
|
- [Modo 1 — Só quero usar](#modo-1--só-quero-usar-sem-mexer-no-código)
|
|
- [Modo 2 — Quero configurar opcionais](#modo-2--quero-configurar-opcionais-oauth-e-mail-ia)
|
|
- [Modo 3 — Quero contribuir com o código](#modo-3--quero-contribuir-com-o-código)
|
|
- [Modo 4 — Banco remoto](#modo-4--banco-remoto-supabase-neon-railway)
|
|
- [Scripts Disponíveis](#-scripts-disponíveis)
|
|
- [Docker](#-docker)
|
|
- [Backup](#-backup)
|
|
- [Storage S3 Compatível](#-storage-s3-compatível)
|
|
- [Variáveis de Ambiente](#-variáveis-de-ambiente)
|
|
- [Arquitetura](#-arquitetura)
|
|
- [Contribuindo](#-contribuindo)
|
|
- [Apoie o Projeto](#-apoie-o-projeto)
|
|
- [Licença](#-licença)
|
|
|
|
---
|
|
|
|
## 🎯 Sobre o Projeto
|
|
|
|
**OpenMonetis** é um projeto pessoal de gestão financeira que criei para organizar minhas próprias finanças. Cansei de usar planilhas desorganizadas e aplicativos que não fazem exatamente o que preciso, então decidi construir algo do jeito que funciona pra mim.
|
|
|
|
A ideia é simples: ter um lugar onde consigo ver todas as minhas contas, cartões, gastos e receitas de forma clara. Se isso for útil pra você também, fique à vontade para usar e contribuir.
|
|
|
|
> 💡 **Licença Não-Comercial:** Este projeto é gratuito para uso pessoal, mas não pode ser usado comercialmente. Veja mais detalhes na seção [Licença](#-licença).
|
|
|
|
### ⚠️ Avisos importantes
|
|
|
|
**1. Não há versão hospedada online** — Este projeto é self-hosted. Você precisa rodar no seu próprio computador ou servidor.
|
|
|
|
**2. Não há Open Finance** — Não há conexão automática com bancos. Você pode registrar transações manualmente, usar o app companion para capturar notificações bancárias ou importar extratos nos formatos OFX e XLS/XLSX.
|
|
|
|
**3. Requer disciplina** — O OpenMonetis funciona melhor para quem tem disciplina de registrar os gastos regularmente, quer controle total sobre seus dados e gosta de entender exatamente onde o dinheiro está indo.
|
|
|
|
### Funcionalidades
|
|
|
|
💰 **Contas e transações** — Contas bancárias, cartões, dinheiro. Receitas, despesas e transferências. Categorização, extratos detalhados e importação de extratos OFX e XLS/XLSX com detecção automática de categoria.
|
|
|
|
📊 **Dashboard e relatórios** — Widgets interativos de métricas, gráficos de evolução, comparativos por categoria, tendências, uso de cartões, top estabelecimentos. Exportação em PDF e Excel.
|
|
|
|
💳 **Faturas de cartão** — Acompanhe faturas por período, controle limites e vencimentos.
|
|
|
|
🎯 **Orçamentos** — Defina limites por categoria e acompanhe o progresso.
|
|
|
|
💸 **Parcelamentos avançados** — Séries de parcelas, antecipação com cálculo de desconto, análise consolidada.
|
|
|
|
🤖 **Insights com IA** — Análises geradas por Claude, GPT, Gemini ou OpenRouter. Insights personalizados e histórico salvo.
|
|
|
|
👥 **Gestão colaborativa** — Pagadores com permissões (admin/viewer), notificações automáticas por e-mail, códigos de compartilhamento.
|
|
|
|
📝 **Anotações e tarefas** — Notas de texto, listas com checkboxes, sistema de arquivamento.
|
|
|
|
📅 **Calendário financeiro** — Visualize todos os lançamentos em um calendário mensal.
|
|
|
|
📲 **OpenMonetis Companion** — App Android que captura notificações bancárias (Nubank, Itaú, Bradesco, Inter, C6 e outros) e envia automaticamente como pré-lançamentos para revisão — sem digitar nada. [Repositório](https://github.com/felipegcoutinho/openmonetis-companion).
|
|
|
|
<p align="center">
|
|
<img src="./public/images/companion-preview-light.webp" alt="OpenMonetis Companion" width="300" height="600" />
|
|
</p>
|
|
|
|
⚙️ **Personalização** — Tema dark/light e modo privacidade.
|
|
|
|
### Stack técnica
|
|
|
|
- **Next.js** (App Router, Turbopack) + **React** + **TypeScript**
|
|
- **PostgreSQL** + **Drizzle ORM**
|
|
- **Better Auth** (email/senha, OAuth, Passkeys/WebAuthn)
|
|
- **shadcn/ui** (Radix UI) + **Tailwind CSS**
|
|
- **Docker** (multi-stage build)
|
|
- **Biome** (linting + formatting)
|
|
- **Vercel AI SDK** (Claude, GPT, Gemini, OpenRouter)
|
|
|
|
---
|
|
|
|
## 🚀 Como rodar o OpenMonetis
|
|
|
|
O OpenMonetis precisa de dois serviços funcionando ao mesmo tempo para operar: **o app** (a interface e a lógica do sistema) e **o banco de dados** (onde ficam guardados seus lançamentos, contas, categorias etc.). Existem algumas formas de subir os dois, dependendo do que você quer fazer.
|
|
|
|
---
|
|
|
|
### 🖥️ Antes de tudo: preparar o servidor (Ubuntu 24.04)
|
|
|
|
Se você está em um **servidor Ubuntu limpo** (VPS, Oracle Cloud, DigitalOcean...) sem Docker, Node.js ou pnpm instalados, rode esse script primeiro. Ele instala tudo que é necessário automaticamente e pula o que já estiver presente.
|
|
|
|
> ⚠️ **Testado apenas em Ubuntu Server 24.04 LTS.** Em outras distribuições ou versões, instale as dependências manualmente.
|
|
|
|
```bash
|
|
curl -fsSL https://raw.githubusercontent.com/felipegcoutinho/openmonetis/main/scripts/install-deps.sh -o install-deps.sh
|
|
sudo sh install-deps.sh
|
|
```
|
|
|
|
O script instala:
|
|
|
|
| Ferramenta | Como instala |
|
|
|---|---|
|
|
| `git`, `curl`, `ca-certificates` | apt |
|
|
| Docker Engine + Docker Compose | Repositório oficial do Docker |
|
|
| Homebrew | Script oficial (como usuário não-root) |
|
|
| Node.js 22 | Via Homebrew |
|
|
| pnpm | Via corepack |
|
|
|
|
Ao final, o usuário atual é adicionado ao grupo `docker` — faça **logout e login** para a mudança ter efeito antes de continuar.
|
|
|
|
Se já tiver Docker e Node.js 22+ instalados, pule essa etapa.
|
|
|
|
---
|
|
|
|
### Modo 1 — Só quero usar (sem mexer no código)
|
|
|
|
Esse é o caminho mais simples. Você baixa apenas um arquivo de configuração e o Docker faz o resto: baixa a imagem do app pronta do Docker Hub e sobe o banco automaticamente. **Não precisa clonar o repositório nem instalar dependências.**
|
|
|
|
```bash
|
|
# 1. Baixa o arquivo de configuração
|
|
curl -fsSL https://raw.githubusercontent.com/felipegcoutinho/openmonetis/main/docker-compose.yml -o docker-compose.yml
|
|
|
|
# 2. Sobe o app e o banco juntos
|
|
docker compose --profile local up
|
|
```
|
|
|
|
Acesse em: `http://localhost:3000`
|
|
|
|
> O banco sobe com as credenciais padrão. Se quiser usar uma senha personalizada, crie um arquivo `.env` na mesma pasta antes de subir — veja a seção [Variáveis de Ambiente](#-variáveis-de-ambiente).
|
|
|
|
---
|
|
|
|
### Modo 2 — Quero configurar opcionais (OAuth, e-mail, IA)
|
|
|
|
Se quiser ativar login com Google, envio de e-mails, integrações com IA ou outras configurações, use o assistente interativo. Ele faz perguntas passo a passo e gera o arquivo `.env` com tudo preenchido corretamente.
|
|
|
|
**Pré-requisito:** Node.js 22+
|
|
|
|
```bash
|
|
# Mac / Linux / WSL
|
|
curl -fsSL https://raw.githubusercontent.com/felipegcoutinho/openmonetis/main/setup.mjs -o setup.mjs && node setup.mjs
|
|
|
|
# Windows (PowerShell)
|
|
curl -o setup.mjs https://raw.githubusercontent.com/felipegcoutinho/openmonetis/main/setup.mjs ; node setup.mjs
|
|
```
|
|
|
|
O assistente vai perguntar:
|
|
- Banco local (Docker) ou remoto (Supabase, Neon, Railway...)?
|
|
- URL da aplicação
|
|
- Google OAuth (opcional)
|
|
- E-mail via Resend (opcional)
|
|
- Chaves de IA — Claude, GPT, Gemini, OpenRouter (opcional)
|
|
- Domínio público separado para landing page (opcional)
|
|
|
|
Ao final, ele clona o repositório, instala as dependências e aplica o schema no banco. Depois é só subir:
|
|
|
|
```bash
|
|
cd openmonetis
|
|
docker compose --profile local up
|
|
```
|
|
|
|
---
|
|
|
|
### Modo 3 — Quero contribuir com o código
|
|
|
|
Nesse modo o Next.js roda **direto no seu servidor com hot-reload** — toda vez que você salva um arquivo, o sistema atualiza automaticamente sem precisar reiniciar nada. O banco continua rodando dentro do Docker (mais simples), só o app fica fora.
|
|
|
|
```bash
|
|
# 1. Clona o repositório e roda o assistente de configuração
|
|
git clone https://github.com/felipegcoutinho/openmonetis.git
|
|
cd openmonetis
|
|
node setup.mjs
|
|
|
|
# 2. Sobe apenas o banco em background (o app vai rodar fora do Docker)
|
|
pnpm docker:up:db
|
|
|
|
# 3. Inicia o app com hot-reload
|
|
pnpm dev
|
|
```
|
|
|
|
Acesse em: `http://localhost:3000`
|
|
|
|
---
|
|
|
|
### Modo 4 — Banco remoto (Supabase, Neon, Railway...)
|
|
|
|
Se você já tem um banco PostgreSQL hospedado em algum serviço externo, não precisa rodar o banco localmente. Informe a URL do banco durante o `setup.mjs` (escolha a opção "URL remota") e suba só o app:
|
|
|
|
```bash
|
|
node setup.mjs # escolha "URL remota" e cole a URL do seu banco
|
|
|
|
docker compose up
|
|
```
|
|
|
|
---
|
|
|
|
### Comparativo
|
|
|
|
| O que quero fazer | Comandos principais |
|
|
|---|---|
|
|
| Só usar, da forma mais simples | `docker-compose.yml` → `docker compose --profile local up` |
|
|
| Usar com Google OAuth, e-mail ou IA | `node setup.mjs` → `docker compose --profile local up` |
|
|
| Desenvolver e contribuir com o código | `node setup.mjs` → `pnpm docker:up:db` → `pnpm dev` |
|
|
| Usar com banco remoto (Supabase etc.) | `node setup.mjs` → `docker compose up` |
|
|
|
|
---
|
|
|
|
## 📜 Scripts Disponíveis
|
|
|
|
### Desenvolvimento
|
|
|
|
```bash
|
|
pnpm dev # Dev server (Turbopack)
|
|
pnpm build # Build de produção
|
|
pnpm start # Servidor de produção
|
|
pnpm lint # Biome check
|
|
pnpm lint:fix # Biome auto-fix
|
|
```
|
|
|
|
### Banco de Dados
|
|
|
|
```bash
|
|
pnpm db:generate # Gerar migrations
|
|
pnpm db:migrate # Executar migrations
|
|
pnpm db:push # Push schema direto (dev)
|
|
pnpm db:extensions # Habilitar extensões PostgreSQL (rodar uma vez)
|
|
pnpm db:studio # Drizzle Studio (UI visual)
|
|
```
|
|
|
|
### Utilitários
|
|
|
|
```bash
|
|
pnpm backup # Backup completo do banco (ver seção Backup)
|
|
```
|
|
|
|
### Docker
|
|
|
|
```bash
|
|
pnpm docker:up:local # Sobe app + banco PostgreSQL juntos (imagem do Hub)
|
|
pnpm docker:up # Sobe apenas o app com build local
|
|
pnpm docker:up:d # Sobe apenas o app com build local em background
|
|
pnpm docker:up:db # Sobe apenas o banco em background
|
|
pnpm docker:down # Para e remove os containers
|
|
pnpm docker:down:volumes # Para containers e remove volumes (⚠️ apaga dados!)
|
|
pnpm docker:logs # Logs em tempo real (todos os containers)
|
|
pnpm docker:logs:app # Logs do container da aplicação
|
|
pnpm docker:logs:db # Logs do container do banco
|
|
pnpm docker:restart # Reinicia todos os containers
|
|
pnpm docker:rebuild # Rebuild completo forçando recriação
|
|
```
|
|
|
|
---
|
|
|
|
## 🐳 Docker
|
|
|
|
O `Dockerfile` usa multi-stage build (deps → builder → runner) com imagem final ~200MB rodando como usuário não-root.
|
|
|
|
Health checks configurados para ambos os serviços (PostgreSQL via `pg_isready`, app via `GET /api/health`).
|
|
|
|
### Modos de uso
|
|
|
|
**Modo 1 — App + banco local (recomendado para self-hosting)**
|
|
|
|
Puxa a imagem pronta do Docker Hub e sobe app + banco juntos. Não precisa de Node.js instalado nem de arquivo `.env` para começar — as credenciais padrão já estão configuradas.
|
|
|
|
```bash
|
|
# 1. Baixar o docker-compose.yml
|
|
curl -fsSL https://raw.githubusercontent.com/felipegcoutinho/openmonetis/main/docker-compose.yml -o docker-compose.yml
|
|
|
|
# 2. Subir (sem precisar de .env)
|
|
docker compose --profile local up
|
|
|
|
# ou, se tiver o projeto clonado:
|
|
pnpm docker:up:local
|
|
```
|
|
|
|
> Se quiser personalizar senhas ou ativar opcionais, crie um arquivo `.env` na mesma pasta antes de subir. Veja a seção [Variáveis de Ambiente](#-variáveis-de-ambiente).
|
|
|
|
**Modo 2 — App com banco remoto**
|
|
|
|
Use quando o banco está em um provider externo (Supabase, Neon, Railway...). Configure o `DATABASE_URL` no `.env` com a URL do seu banco e suba só o app.
|
|
|
|
```bash
|
|
# DATABASE_URL deve apontar para o banco remoto no .env
|
|
docker compose up
|
|
```
|
|
|
|
**Modo 3 — Build local (desenvolvimento)**
|
|
|
|
Builda a imagem localmente a partir do código-fonte em vez de usar a imagem do Docker Hub. Útil para testar mudanças antes de publicar.
|
|
|
|
```bash
|
|
pnpm docker:up:db # sobe o banco em background
|
|
pnpm docker:up # builda e sobe o app localmente
|
|
```
|
|
|
|
### Comandos úteis
|
|
|
|
```bash
|
|
docker compose exec app sh # Shell da aplicação
|
|
docker compose exec db psql -U openmonetis -d openmonetis_db # Shell do banco
|
|
docker compose ps # Status
|
|
docker compose exec db pg_dump -U openmonetis openmonetis_db > backup.sql # Backup
|
|
docker compose exec -T db psql -U openmonetis -d openmonetis_db < backup.sql # Restore
|
|
```
|
|
|
|
### Customizando Portas
|
|
|
|
```env
|
|
APP_PORT=3001 # Padrão: 3000
|
|
DB_PORT=5433 # Padrão: 5432
|
|
```
|
|
|
|
---
|
|
|
|
## 💾 Backup
|
|
|
|
O backup é uma rotina de infraestrutura — não é uma tela no app. Ele opera diretamente sobre o banco PostgreSQL e é executado via linha de comando.
|
|
|
|
```bash
|
|
pnpm backup
|
|
```
|
|
|
|
### O que é salvo
|
|
|
|
Cada execução gera **3 arquivos** em `backup/`:
|
|
|
|
| Arquivo | Conteúdo | Uso |
|
|
|---|---|---|
|
|
| `openmonetis_YYYY-MM-DD_HH-MM.dump` | Dump custom do PostgreSQL (binário) | Restore completo via `pg_restore` |
|
|
| `openmonetis_YYYY-MM-DD_HH-MM.sql.gz` | Dump SQL completo compactado | Inspeção manual, portabilidade |
|
|
| `openmonetis_YYYY-MM-DD_HH-MM.data.sql.gz` | Apenas os dados da schema `public` | Migração parcial, seed de outro ambiente |
|
|
|
|
### Modos de conexão
|
|
|
|
Configure `DB_MODE` no topo de `scripts/backup.sh`:
|
|
|
|
| Modo | Quando usar | Fonte de dados |
|
|
|---|---|---|
|
|
| `remote` (padrão) | Banco em Supabase, Neon, Railway, etc. | `DATABASE_URL` do `.env` |
|
|
| `docker` | Banco no container local | Container `openmonetis_postgres` |
|
|
|
|
### Upload para Google Drive (opcional)
|
|
|
|
Se o [rclone](https://rclone.org/) estiver instalado e configurado com um remote chamado `gdrive`, os arquivos são enviados automaticamente para `gdrive:BACKUP OPENMONETIS`. Sem o rclone, o backup funciona normalmente e fica apenas local.
|
|
|
|
**Retenção:**
|
|
- Local: 7 dias
|
|
- Google Drive: 30 dias
|
|
|
|
### Automatizar com cron
|
|
|
|
Para rodar o backup automaticamente todo dia às 3h:
|
|
|
|
```bash
|
|
crontab -e
|
|
```
|
|
|
|
```cron
|
|
0 3 * * * cd /caminho/para/openmonetis && pnpm backup >> /var/log/openmonetis-backup.log 2>&1
|
|
```
|
|
|
|
### Restore
|
|
|
|
```bash
|
|
# A partir do .dump (recomendado — mais rápido)
|
|
pg_restore --clean --no-owner --no-privileges \
|
|
-d "postgresql://user:senha@host:5432/openmonetis_db" \
|
|
backup/openmonetis_YYYY-MM-DD_HH-MM.dump
|
|
|
|
# A partir do .sql.gz (banco local via Docker)
|
|
gunzip -c backup/openmonetis_YYYY-MM-DD_HH-MM.sql.gz | \
|
|
docker compose exec -T db psql -U openmonetis -d openmonetis_db
|
|
```
|
|
|
|
---
|
|
|
|
## ☁️ Storage S3 Compatível
|
|
|
|
O suporte a anexos de lançamentos usa upload direto com URL pré-assinada. Essa configuração é opcional, mas passa a ser necessária se você quiser habilitar anexos no app.
|
|
|
|
### Variáveis
|
|
|
|
```env
|
|
S3_ENDPOINT=
|
|
S3_REGION=
|
|
S3_ACCESS_KEY_ID=
|
|
S3_SECRET_ACCESS_KEY=
|
|
S3_BUCKET=
|
|
```
|
|
|
|
### Compatibilidade
|
|
|
|
- O código atual espera um provider com API compatível com S3 e suporte a `PutObject`, `GetObject`, `HeadObject`, `DeleteObject` e URLs pré-assinadas.
|
|
- A implementação usa `endpoint` customizado e `forcePathStyle: true` em [`src/shared/lib/storage/s3-client.ts`](./src/shared/lib/storage/s3-client.ts).
|
|
- Em geral isso cobre MinIO, Cloudflare R2, Backblaze B2 S3-Compatible, DigitalOcean Spaces e AWS S3. Mas foi testado apenas no Supabase Storage.
|
|
- Se o seu provider exigir `virtual-hosted-style` em vez de `path-style`, você vai precisar ajustar essa configuração antes de usar anexos.
|
|
- Se as variáveis de S3 não forem configuradas, mantenha os anexos desabilitados no seu fluxo de uso.
|
|
|
|
---
|
|
|
|
## 🔐 Variáveis de Ambiente
|
|
|
|
Copie `.env.example` para `.env` e configure:
|
|
|
|
### Obrigatórias
|
|
|
|
```env
|
|
DATABASE_URL=postgresql://openmonetis:openmonetis_dev_password@localhost:5432/openmonetis_db
|
|
BETTER_AUTH_SECRET=seu-secret-aqui # openssl rand -base64 32
|
|
BETTER_AUTH_URL=http://localhost:3000
|
|
```
|
|
|
|
### Opcionais
|
|
|
|
```env
|
|
# PostgreSQL (Docker local)
|
|
POSTGRES_USER=openmonetis
|
|
POSTGRES_PASSWORD=openmonetis_dev_password
|
|
POSTGRES_DB=openmonetis_db
|
|
|
|
# S3 Server (opcional, necessario para anexos)
|
|
S3_ENDPOINT=
|
|
S3_REGION=
|
|
S3_ACCESS_KEY_ID=
|
|
S3_SECRET_ACCESS_KEY=
|
|
S3_BUCKET=
|
|
|
|
# Multi-domínio (landing-only no domínio público)
|
|
# PUBLIC_DOMAIN=openmonetis.com
|
|
|
|
# OAuth
|
|
GOOGLE_CLIENT_ID=
|
|
GOOGLE_CLIENT_SECRET=
|
|
|
|
# Email (Resend)
|
|
RESEND_API_KEY=
|
|
RESEND_FROM_EMAIL=
|
|
|
|
# AI Providers
|
|
ANTHROPIC_API_KEY=
|
|
OPENAI_API_KEY=
|
|
GOOGLE_GENERATIVE_AI_API_KEY=
|
|
OPENROUTER_API_KEY=
|
|
```
|
|
|
|
---
|
|
|
|
## 🏗️ Arquitetura
|
|
|
|
O projeto segue arquitetura **feature-first** dentro de `src/`:
|
|
|
|
```
|
|
openmonetis/
|
|
├── src/
|
|
│ ├── app/ # Next.js App Router (rotas finas)
|
|
│ │ ├── api/ # API Routes (auth, health, inbox)
|
|
│ │ ├── (auth)/ # Login e cadastro
|
|
│ │ ├── (dashboard)/ # Rotas protegidas (transactions, cards, accounts, etc.)
|
|
│ │ └── (landing-page)/ # Página inicial pública
|
|
│ │
|
|
│ ├── features/ # Código de domínio por feature
|
|
│ │ ├── dashboard/ # Widgets, queries e métricas
|
|
│ │ ├── transactions/ # Lançamentos, ações em lote, exportação
|
|
│ │ ├── cards/ # Cartões de crédito
|
|
│ │ ├── invoices/ # Faturas
|
|
│ │ ├── accounts/ # Contas bancárias
|
|
│ │ ├── categories/ # Categorias e histórico
|
|
│ │ ├── budgets/ # Orçamentos
|
|
│ │ ├── payers/ # Pagadores e compartilhamento
|
|
│ │ ├── inbox/ # Pré-lançamentos do Companion
|
|
│ │ ├── insights/ # Análises com IA
|
|
│ │ ├── reports/ # Relatórios e exportações
|
|
│ │ ├── notes/ # Anotações
|
|
│ │ ├── calendar/ # Calendário financeiro
|
|
│ │ ├── settings/ # Ajustes do usuário
|
|
│ │ ├── landing/ # Landing page
|
|
│ │ └── auth/ # Formulários de autenticação
|
|
│ │
|
|
│ ├── shared/ # Código reutilizado entre features
|
|
│ │ ├── components/ # UI compartilhada (shadcn/ui, navigation, skeletons...)
|
|
│ │ ├── hooks/ # React hooks globais
|
|
│ │ ├── lib/ # Helpers de domínio (auth, db, payers, schemas, email...)
|
|
│ │ └── utils/ # Utilitários (currency, date, period, math, string...)
|
|
│ │
|
|
│ └── db/
|
|
│ └── schema.ts # Drizzle schema (fonte única de verdade)
|
|
│
|
|
├── public/ # Assets estáticos (imagens, logos, fontes)
|
|
├── drizzle/ # Migrations geradas
|
|
├── scripts/ # Scripts utilitários (migrations, dev)
|
|
├── Dockerfile # Multi-stage build (~200MB, non-root)
|
|
├── docker-compose.yml # Orquestração app + PostgreSQL
|
|
└── proxy.ts # Middleware (auth + multi-domínio)
|
|
```
|
|
|
|
---
|
|
|
|
## 🤝 Contribuindo
|
|
|
|
1. **Fork** o projeto
|
|
2. **Clone** seu fork: `git clone https://github.com/seu-usuario/openmonetis.git`
|
|
3. **Crie uma branch:** `git checkout -b feature/minha-feature`
|
|
4. **Commit:** `git commit -m 'feat: adiciona minha feature'`
|
|
5. **Push:** `git push origin feature/minha-feature`
|
|
6. Abra um **Pull Request**
|
|
|
|
Antes de começar, leia o [`CLAUDE.md`](CLAUDE.md) — ele documenta a arquitetura, convenções de nomenclatura, regras de queries e o checklist para novas features. Use TypeScript, commits semânticos e mantenha o `CHANGELOG.md` atualizado.
|
|
|
|
---
|
|
|
|
## 💖 Apoie o Projeto
|
|
|
|
Se o **OpenMonetis** está sendo útil, considere se tornar um sponsor!
|
|
|
|
[](https://github.com/sponsors/felipegcoutinho)
|
|
|
|
Outras formas de contribuir: ⭐ estrela no repo, reportar bugs, melhorar docs, submeter PRs.
|
|
|
|
---
|
|
|
|
## 📄 Licença
|
|
|
|
**Creative Commons Attribution-NonCommercial-ShareAlike 4.0 International** (CC BY-NC-SA 4.0).
|
|
|
|
[](https://creativecommons.org/licenses/by-nc-sa/4.0/)
|
|
|
|
- ✅ Uso pessoal, modificação, distribuição e fork
|
|
- ❌ Uso comercial, remoção de créditos, mudança de licença
|
|
- 📋 Crédito ao autor, indicar modificações, mesma licença
|
|
|
|
Para o texto legal completo, consulte o arquivo [LICENSE](LICENSE) ou visite [creativecommons.org](https://creativecommons.org/licenses/by-nc-sa/4.0/deed.pt).
|
|
|
|
---
|
|
|
|
## 🙏 Agradecimentos
|
|
|
|
[Next.js](https://nextjs.org/) · [Better Auth](https://better-auth.com/) · [Drizzle ORM](https://orm.drizzle.team/) · [shadcn/ui](https://ui.shadcn.com/) · [Biome](https://biomejs.dev/) · [Vercel](https://vercel.com/)
|
|
|
|
---
|
|
|
|
**Desenvolvido por:** Felipe Coutinho — [@felipegcoutinho](https://github.com/felipegcoutinho)
|
|
|
|
<div align="center">
|
|
|
|
**⭐ Se este projeto foi útil pra você:**
|
|
|
|
Dê uma estrela · [Apoie como sponsor](https://github.com/sponsors/felipegcoutinho) · Compartilhe
|
|
|
|
</div>
|