e9f836db87
Tests · Go / test (push) Successful in 9s
Tests · Integration / integration (push) Successful in 10s
Tests · UI / test (push) Successful in 20s
Tests · Go / test (pull_request) Successful in 8s
Tests · Integration / integration (pull_request) Successful in 11s
Tests · UI / test (pull_request) Successful in 19s
Service-agnostic refinement of the owner's idea: the sign-in service returns a set of supported game languages with the user identity, and the lobby gates the New Game variant choice by it (en -> English; ru -> Russian + Эрудит). - Connector hosts two bots in one container (one per service language, each its own token + game channel; the same telegram_id spans both). ValidateInitData tries each token and returns the validating bot's service_language + supported_languages. Per-language config (TELEGRAM_BOT_TOKEN_EN/_RU, channels). - supported_languages rides the Session (fbs, session-scoped, not persisted); the UI offers only the matching variants on New Game — gating only the START of a new game (auto-match + friend invite), not accept/open/play; backend does not enforce. - service_language persisted (accounts.service_language, migration 00010, written every login, last-login-wins) and routes the user-facing Notify push back through the right bot (push-target coalesces with preferred_language). - Admin SendToUser/SendToGameChannel gain an operator-chosen language selector in the console (unrelated to ValidateInitData). - Non-Telegram logins carry the gateway default set (GATEWAY_DEFAULT_SUPPORTED_LANGUAGES, all variants). Wire (committed regen): ValidateInitDataResponse +service_language +supported_languages; Session +supported_languages; SendToUser/SendToGameChannel +language. Docs (ARCHITECTURE/FUNCTIONAL/_ru/READMEs) + PLAN updated; stage marked done.
63 lines
2.7 KiB
YAML
63 lines
2.7 KiB
YAML
# Deploy descriptor for the Telegram connector (the platform side-service).
|
|
#
|
|
# Networking mirrors the sibling ../15-puzzle/deploy/docker-compose.yml:
|
|
# - The `vpn` sidecar (developer/amneziawg-sidecar) holds the tunnel and provides
|
|
# the netns shared by `app` (network_mode: "service:vpn"). All of the
|
|
# connector's egress to api.telegram.org therefore leaves through the tunnel.
|
|
# - `vpn` is the one attached to the external `edge` network, with the alias
|
|
# `telegram`, so the other services reach the connector's gRPC port at
|
|
# `telegram:9091` inside the shared netns. The connector needs NO public
|
|
# ingress — it long-polls Telegram and only answers internal gRPC.
|
|
#
|
|
# The connector joins the same `edge` network as `backend` and `gateway` (the full
|
|
# service set rolled out together on a dev-environment deploy). The gateway calls it
|
|
# with GATEWAY_CONNECTOR_ADDR=telegram:9091; the backend admin surface (Stage 10)
|
|
# will use the same address. The single public ingress for the host reverse proxy
|
|
# (caddy) is the gateway's HTTP port, which also serves the Mini App under /telegram/
|
|
# (ARCHITECTURE.md §13). The full multi-service compose lands with Stage 12; this is
|
|
# the connector-scoped descriptor.
|
|
name: scrabble-telegram
|
|
|
|
services:
|
|
vpn:
|
|
container_name: scrabble-telegram-vpn
|
|
image: docker.iliadenisov.ru/developer/amneziawg-sidecar:latest
|
|
restart: unless-stopped
|
|
privileged: true
|
|
environment:
|
|
AWG_CONF: ${AWG_CONF:?set AWG_CONF}
|
|
networks:
|
|
edge:
|
|
aliases:
|
|
- telegram
|
|
|
|
app:
|
|
container_name: scrabble-telegram
|
|
image: scrabble-telegram:latest
|
|
build:
|
|
# Build from the repository root so go.work, pkg/ and platform/telegram/ are
|
|
# all in the Docker context (see platform/telegram/Dockerfile).
|
|
context: ../../..
|
|
dockerfile: platform/telegram/Dockerfile
|
|
restart: unless-stopped
|
|
depends_on:
|
|
- vpn
|
|
network_mode: "service:vpn"
|
|
environment:
|
|
# The bot tokens live ONLY in this container (ARCHITECTURE.md §12). One bot per
|
|
# service language (en/ru); at least one token is required (the connector
|
|
# validates this at boot — compose cannot express "one of").
|
|
TELEGRAM_BOT_TOKEN_EN: ${TELEGRAM_BOT_TOKEN_EN:-}
|
|
TELEGRAM_BOT_TOKEN_RU: ${TELEGRAM_BOT_TOKEN_RU:-}
|
|
TELEGRAM_GAME_CHANNEL_ID_EN: ${TELEGRAM_GAME_CHANNEL_ID_EN:-}
|
|
TELEGRAM_GAME_CHANNEL_ID_RU: ${TELEGRAM_GAME_CHANNEL_ID_RU:-}
|
|
TELEGRAM_MINIAPP_URL: ${TELEGRAM_MINIAPP_URL:?set TELEGRAM_MINIAPP_URL}
|
|
TELEGRAM_GRPC_ADDR: ${TELEGRAM_GRPC_ADDR:-:9091}
|
|
# Set to true when deploying into Telegram's test environment.
|
|
TELEGRAM_TEST_ENV: ${TELEGRAM_TEST_ENV:-false}
|
|
TELEGRAM_API_BASE_URL: ${TELEGRAM_API_BASE_URL:-}
|
|
|
|
networks:
|
|
edge:
|
|
external: true
|