Files
sar/.env.example
julian a1a852c44d feat(c6): notificações e push — Web Push VAPID, badge dinâmico, Share API
FR-6.1/6.2: Sandra recebe push quando pedido entra em pending_approval;
Rafael recebe quando pedido é aprovado ou recusado. Service worker registrado
em background (PWA-ready via public/sw.js).

FR-6.3: Badge na Topbar busca GET /notifications/pending-count (supervisores
veem count de pending_approval; reps veem 0). Intervalo de 30s.

FR-6.4: Botão Compartilhar no OrderDetailPage para pedidos approved/invoiced
(apenas reps). Usa navigator.share() com texto formatado para WhatsApp.

Infra: modelo PushSubscription (Prisma), NotificationsModule (subscribe/
unsubscribe/pending-count + PushService VAPID), VAPID keys em .env,
integração no OrdersService (create → supervisores, approve/reject → repId).

Co-Authored-By: Claude Sonnet 4.6 (1M context) <noreply@anthropic.com>
2026-05-28 12:31:13 +00:00

62 lines
2.0 KiB
Plaintext

# SAR — Variáveis de ambiente (template)
# Copie para .env e ajuste para seu setup local
# Em produção: Vault Agent injeta esses valores no entrypoint (CODING-RULES.md PGD-SEC-002)
# Node environment
NODE_ENV=development
# API
API_PORT=3000
API_HOST=localhost
# Web
VITE_API_URL=http://localhost:3000/api/v1
# Postgres (dev — para Prisma)
DATABASE_URL=postgresql://sar:sar_dev_password@localhost:5432/sar_workspace_dev?schema=public
MIGRATION_DATABASE_URL=postgresql://sar:sar_dev_password@localhost:5432/sar_workspace_dev?schema=public
# Em prod: MIGRATION_DATABASE_URL aponta direto pro Postgres na porta 5432 (sem PgBouncer)
# CODING-RULES.md PGD-DB-001
# Master-login (DEV stub — substituir por IdP real na próxima sessão)
MASTER_LOGIN_URL=http://localhost:3000/auth/dev
MASTER_LOGIN_JWT_SECRET=dev_jwt_secret_change_in_prod_use_vault
JWT_ACCESS_EXPIRATION=900 # 15 min
JWT_REFRESH_EXPIRATION=2592000 # 30 dias
# Valkey (Redis-compat)
REDIS_URL=redis://localhost:6379
# MinIO (S3-compat)
S3_ENDPOINT=http://localhost:9000
S3_REGION=us-east-1
S3_ACCESS_KEY=sar_minio_admin
S3_SECRET_KEY=sar_minio_dev_password
S3_BUCKET=sar-dev
# Email (DEV: Mailpit. Prod: Resend via Vault)
SMTP_HOST=localhost
SMTP_PORT=1025
SMTP_FROM=noreply@sar.dev
# Telemetry (DEV: opcional. Prod: Vault)
OTEL_SERVICE_NAME=sar-api
OTEL_TRACES_SAMPLER=parentbased_traceidratio
OTEL_TRACES_SAMPLER_ARG=1.0
SENTRY_DSN=
# Web Push VAPID (C6) — gerar com: node -e "const wp=require('web-push'); const k=wp.generateVAPIDKeys(); console.log(k)"
# Em prod: Vault injeta. Em dev: opcional — push fica desabilitado se vazio.
VAPID_PUBLIC_KEY=
VAPID_PRIVATE_KEY=
VAPID_CONTACT=mailto:noreply@sar.dev
# Chave pública VAPID para o front-end (mesmo valor de VAPID_PUBLIC_KEY)
VITE_VAPID_PUBLIC_KEY=
# Feature flags (DEV: bypass. Prod: GrowthBook self-host)
GROWTHBOOK_API_HOST=http://localhost:3100
GROWTHBOOK_CLIENT_KEY=
# Workspace context (DEV: workspace fixo de dev)
DEFAULT_WORKSPACE_ID=dev-workspace