saveinmed/backend-old
NANDO9322 0a0c344022 feat(geral): implementa fluxo de aprovação, api de endereços e acesso master
Backend:
- Implementa API de Endereços (`POST /enderecos`) e migration da tabela `addresses`.
- Adiciona bloqueio de login para usuários de empresas não verificadas (status `pending`).
- Criação automática do usuário Master (`seedAdmin`) com empresa verificada.
- Adiciona aliases de rota em PT-BR (`/api/v1/empresas` GET/PATCH, `/api/v1/usuarios` PATCH) para compatibilidade com o frontend.
- Atualiza DTOs para suportar campos em português no registro de empresas e atualização de usuários.
- Endpoint `/auth/me` agora retorna `company_name` e flag `superadmin`.
- Ajusta filtro de repositório para listar empresas por status de verificação.

Frontend:
- Nova página `/usuarios-pendentes` com layout padrão e funcionalidade de aprovação.
- Atualiza [Header](cci:1://file:///c:/Projetos/saveinmed/saveinmed-frontend/src/components/Header.tsx:29:0-337:2) para exibir o nome da empresa do usuário logado.
- Serviço `empresaApiService`: correções de mapeamento (`corporate_name` -> `razao_social`) e novos métodos.
- Tipagem atualizada para incluir campos de empresa no [UserData](cci:2://file:///c:/Projetos/saveinmed/saveinmed-frontend/src/types/auth.ts:15:0-30:1).

Fixes:
- Correção de erro 405 (Method Not Allowed) nas rotas de atualização.
- Correção de erro 404 na listagem de pendentes.
- Resolução de campos vazios na listagem de empresas.
2026-01-21 17:20:06 -03:00
..
cmd Rename backend folder to backend-old 2026-01-16 10:51:52 -03:00
docs Rename backend folder to backend-old 2026-01-16 10:51:52 -03:00
internal feat(geral): implementa fluxo de aprovação, api de endereços e acesso master 2026-01-21 17:20:06 -03:00
.env feat(geral): implementa fluxo de aprovação, api de endereços e acesso master 2026-01-21 17:20:06 -03:00
.env.example Rename backend folder to backend-old 2026-01-16 10:51:52 -03:00
.gitignore Rename backend folder to backend-old 2026-01-16 10:51:52 -03:00
api Rename backend folder to backend-old 2026-01-16 10:51:52 -03:00
BACKEND.md Rename backend folder to backend-old 2026-01-16 10:51:52 -03:00
Dockerfile Rename backend folder to backend-old 2026-01-16 10:51:52 -03:00
go.mod Rename backend folder to backend-old 2026-01-16 10:51:52 -03:00
go.sum Rename backend folder to backend-old 2026-01-16 10:51:52 -03:00
login.json feat(geral): implementa fluxo de aprovação, api de endereços e acesso master 2026-01-21 17:20:06 -03:00
main Rename backend folder to backend-old 2026-01-16 10:51:52 -03:00
README.md Rename backend folder to backend-old 2026-01-16 10:51:52 -03:00

SaveInMed Backend API

Status (pronto x faltando)

Pronto

  • Conteúdo descrito neste documento.

Faltando

  • Confirmar no código o estado real das funcionalidades e atualizar esta seção conforme necessário.

This service handles the core business logic, data persistence, and external integrations for the SaveInMed B2B Marketplace.

🏗 Architecture

The backend follows a layered architecture to ensure separation of concerns and maintainability.

graph TD
    %% Clients
    Client([Client Application])
    
    %% Entry Point
    subgraph "API Layer"
        Router[Router / Middleware]
        AuthH[Auth Handler]
        UserH[User Handler]
        ProdH[Product Handler]
        CartH[Cart Handler]
        OrderH[Order Handler]
        PayH[Payment Handler]
        ShipH[Shipping Handler]
    end

    %% Business Logic
    subgraph "Service Layer"
        AuthS[Auth Service]
        UserS[User Service]
        ProdS[Catalog Service]
        OrderS[Order Service]
        PayS[Payment Service]
        ShipS[Shipping Service]
    end

    %% Data / Infra
    subgraph "Infrastructure Layer"
        DB[(PostgreSQL)]
        MP[Mercado Pago Adapter]
        Asaas[Asaas Adapter]
        Stripe[Stripe Adapter]
        Mapbox[Mapbox Service]
    end

    %% Flows
    Client --> Router
    Router --> AuthH
    Router --> UserH
    Router --> ProdH
    Router --> CartH
    Router --> OrderH
    Router --> PayH
    Router --> ShipH

    AuthH --> AuthS
    UserH --> UserS
    ProdH --> ProdS
    CartH --> OrderS
    OrderH --> OrderS
    PayH --> PayS
    ShipH --> ShipS

    AuthS --> DB
    UserS --> DB
    ProdS --> DB
    OrderS --> DB
    
    PayS --> MP
    PayS --> Asaas
    PayS --> Stripe
    
    ShipS --> Mapbox

    %% Styling
    style Client fill:#f9f,stroke:#333
    style Router fill:#ff9,stroke:#333
    style DB fill:#94a3b8,stroke:#333

🛠 Tech Stack

  • Language: Go 1.24+
  • Framework: Standard Library + Chi/Mux (inferred)
  • Database: PostgreSQL
  • Docs: Swagger/OpenAPI

🚀 Key Features

  • High-performance REST API
  • JWT Authentication
  • Role-Based Access Control
  • Payment Gateway Integration (Mercado Pago, Asaas, Stripe)
  • Real-time Inventory Management

🧪 Tests

go test ./... -cover

Para matriz completa (com/sem banco e Playwright), veja: docs/TESTES.md