This repository has been archived on 2026-06-09. You can view files and clone it, but cannot push or open issues or pull requests.
wedding-app/infra/gitea/.env.example
Claude 5a19753013
feat: split into 3 docker-compose stacks (main / gitea / wedding_photo)
Repo passa a viver dentro de infra/, com três stacks isoladas que
compartilham uma network Docker externa ('infra-net'):

main/        infra base: postgres + redis + minio + minio-init + pgadmin
             + caddy. Postgres roda em modo multi-banco; o init script
             cria os DBs 'wedding' e 'gitea' com roles dedicadas. MinIO
             tem um bucket inicial criado pelo minio-init com anonymous
             download + CORS. Caddy é o único container expondo 80/443
             e roteia por hostname: gitea.{DOMAIN_BASE} / wedding.* /
             pgadmin.* / minio.* / media.* (rewrite de bucket).

gitea/       gitea + act_runner. Gitea liga no postgres compartilhado e
             usa redis pra cache+sessões. O runner ganha um Dockerfile
             pequeno que adiciona docker CLI por cima do
             gitea/act_runner pra workflows poderem chamar 'docker
             build'. Bootstrap do token de runner documentado no
             .env.example.

wedding_photo/  Só a aplicação: 'wedding_app' (FastAPI + SPA) +
             postgres-backup + media-backup. Os bancos e o MinIO vêm
             da stack main/. A app usa extra_hosts: host-gateway pra
             alcançar media.{DOMAIN_BASE} via Caddy mesmo em dev local
             — assim a assinatura S3 fecha com o host que o browser
             usa pra fazer PUT.

Orquestração:
- Makefile no root: 'make up' sobe tudo na ordem (main -> gitea ->
  wedding_photo). 'make up-{main,gitea,wedding}' pra controle
  granular. 'make logs-*', 'make down', 'make status', 'make pull-*'.
- network.sh cria a 'infra-net' antes de qualquer up; idempotente.
- Cada stack tem seu próprio .env.example. As creds compartilhadas
  (DOMAIN_BASE, MINIO_ROOT_*, WEDDING_DB_*) precisam casar entre
  main/.env e o consumidor (gitea/.env ou wedding_photo/.env).
- .gitignore ignora todas as pastas data/ dos volumes.
2026-06-08 23:34:14 +00:00

33 lines
1.3 KiB
Plaintext

# =============================================================================
# infra/gitea/.env — copie pra .env e edite
# =============================================================================
# Casa com infra/main/.env
DOMAIN_BASE=localhost
TZ=America/Sao_Paulo
# Banco no postgres compartilhado (mesmas creds do main/.env)
GITEA_DB_NAME=gitea
GITEA_DB_USER=gitea
GITEA_DB_PASSWORD=troque-essa-senha-forte
# Porta SSH no host (pra git@gitea.localhost:user/repo.git)
GITEA_SSH_PORT=2222
# Cadastro: true = só admin convida; false = qualquer um cria conta
GITEA_DISABLE_REGISTRATION=true
GITEA_REQUIRE_SIGNIN=false
# ----- Gitea Actions Runner -----
# Como pegar o token (bootstrap):
# 1. Suba só o gitea: make up-gitea (runner vai falhar a 1ª vez, ok)
# 2. Acesse https://gitea.localhost e crie o usuário admin (no terminal:
# docker exec -it gitea gitea admin user create --username admin
# --password ... --email ... --admin)
# 3. UI: Site Administration → Actions → Runners → Create new runner
# 4. Copie o token aqui e: make up-gitea (runner registra e fica de pé)
GITEA_RUNNER_TOKEN=
GITEA_RUNNER_NAME=local-runner
# Labels exemplos. Adicione mais se quiser ambientes específicos.
GITEA_RUNNER_LABELS=ubuntu-latest:docker://catthehacker/ubuntu:act-22.04,node:docker://node:22-alpine,python:docker://python:3.12-slim