Files
Bridge-and-Join-s/internal/lkgateway
fontvielle 958d777751 feat(lk-gateway): admin setup wizard — конфигурация подсистем через UI + тестовый прогон
Добавлена вкладка «Настройка» в admin-панели lk-gateway. Позволяет
ввести параметры каждой подсистемы прямо через веб-интерфейс,
проверить подключение и запустить тестовую заявку в один клик.

internal/lkgateway/runtimeconfig.go:
- Runtime-конфиг с персистом в JSON (BJ_SETUP_PATH или ~/.bj/setup.json)
- Поля: PostgresDSN, Crypto (provider/socket/jcp_path/license_key),
  NSD (profile/igw_base_url/key_container), LK (callback_url),
  LastTestRun (результат последнего тестового прогона)
- ReadinessSummary() для блока «Готовность системы: X из Y»

internal/lkgateway/setup.go:
- GET /admin/setup — страница настройки
- POST /admin/setup/postgres — DSN + sql.Ping (без pgx-драйвера упадёт
  на «unknown driver postgres», что покажет пользователю)
- POST /admin/setup/crypto — provider/socket/jcp.jar/лицензия, проверка
  существования файла jcp.jar
- POST /admin/setup/nsd — профиль/URL ИШ/контейнер, GET /healthz ИШ
- POST /admin/setup/lk — callback URL + GET /healthz эмулятора/ЛК
- POST /admin/setup/test-run — пробная сквозная заявка с предзаполнением
  (Иванов, 1500 акций Газпрома, ИИС T03), опрос статуса до финального

internal/lkgateway/web/templates/admin_setup.html:
- 4 карточки подсистем со статус-индикаторами (зелёная/красная точка)
- Inline-формы через <details>/<summary>: открыты для не настроенных,
  свёрнуты для уже настроенных
- Карточка «Тестовый прогон» с историей последнего результата
- Прогресс «Готовность системы: X из Y» в верхней части

internal/lkgateway/server.go:
- Server.rc *RuntimeConfig — поднимается при NewServer
- CheckOptions для admin-дашборда теперь берутся из runtime-конфига,
  а не только из ENV — изменения в /admin/setup сразу видны в /admin/
  и /admin/status без перезапуска

В layout.html добавлена nav-ссылка «Настройка», между «Дашборд» и
«Заявки».

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-14 11:30:48 +03:00
..

internal/lkgateway — BFF слой ЛК + admin web UI

Реализует REST-контракт ESIA Finance V1 (docs/lk-contract/v1/openapi.yaml) на стороне Bridge-and-Join-s и admin-веб для оператора.

REST API

  • POST /api/v1/back_office/claims/ — приём заявки от ЛК. Валидирует, собирает M2MTransferRequest через m2mcore.EnrichRequest, создаёт m2mcore.Deal, отправляет в НРД через m2mcore.NSDSender (на M2 — mock).
  • GET /api/v1/back_office/claims/{id} — карточка заявки.
  • GET /api/v1/back_office/claims — список с фильтрами (status/investor_id/created_from/created_to/limit/offset).
  • PATCH /api/v1/back_office/claims/{id} — placeholder для callback от внешней системы.
  • /healthz — health.

Admin web UI

  • /admin/ — дашборд: статус системы, счётчики (Total/Confirmed/ InProgress/Failed), последние 10 заявок.
  • /admin/claims — журнал всех заявок.
  • /admin/claims/{id} — детальная карточка: история FSM, ответ НРД (M2MTransferResponse), решение принимающей стороны (M2MTransferDecision), последний callback.
  • /admin/status — детальные проверки: postgres, crypto-service (UDS), nsd-adapter (REST), lk-emulator callback URL.

Состав пакета

  • server.goServer обвязка: HTTP mux + сервис + фоновый consumeDecisions (читает из mock.Sender.Decisions() и обновляет сделки + шлёт callback в ЛК).
  • service.go — бизнес-логика: DTO ↔ доменные сущности m2mcore, оркестрация FSM, отправка callback'ов.
  • api.go — REST endpoints.
  • admin.go — HTML endpoints с шаблонами в web/templates/.
  • checks.go — проверки готовности подсистем (postgres, crypto-service, nsd-adapter, callback URL).
  • seedstore.go — in-memory m2mcore.FansyStore с 5 тестовыми клиентами и счетами депо (соответствует docs/fansy-contract/v1/examples/seed-data.sql).
  • types.go — DTO под OpenAPI.
  • http_util.go — JSON-хелперы.

Конфигурация (cmd/lk-gateway/main.go, ENV)

Переменная По умолчанию Назначение
BJ_HTTP_ADDR :8080 Адрес HTTP
BJ_M2M_SENDER MC0079200000 DeponentCode отправителя в M2M Header
BJ_M2M_RECEIVER MC0010300000 DeponentCode получателя
BJ_DSN PostgreSQL DSN (M2-шаг-3, пока пусто = in-memory)
BJ_CRYPTO_SOCKET /run/bj/crypto.sock UDS для crypto-service
BJ_NSD_ADAPTER_URL URL nsd-adapter HTTP (пусто = mock)
BJ_LK_CALLBACK_URL URL ЛК для PATCH callback'ов (пусто = эмулятор регистрирует свой)
BJ_NSD_PROFILE demo (mock NSD) Имя профиля (отображается в admin)
BJ_CRYPTO_PROVIDER stub Провайдер криптографии в admin-статусе

Что подключается в следующих шагах

  • M2-шаг-3: pgx-репозиторий → миграция migrations/m2m-core/001__deals.sql уже готова.
  • M3: реальный nsd-adapter вместо mock — выставить BJ_NSD_ADAPTER_URL и реализовать в nsd-adapter поллер, отправляющий Decision не через канал mock, а через шину.
  • M4: admin-ui v2 на React + раздел «Сертификаты КриптоПро» для обновления публичных сертификатов через UI.