feat: живой цикл M2M с НРД + мастер установки ключа на флешку
Инфраструктура M2M (живой обмен с НРД через ИШ): - обработка M2MTransferResponse: ERROR(M2Mxx) → заявка Отклонена, сохранение ответа; INFO → ждём Decision; идемпотентность поллера - fallback-корреляция ответов с нулевым GUID (M2M14/M2M17) по FIFO - сырой XML ответа НРД в карточке заявки (для пересылки в ТП) - тестовый пакет роботу приведён к эталону m2m_robot_samples (CostInfo=Yes, 4 бумаги, IsolationStatus, DocumentSeries=сценарий); override паспорта - редирект из теста сразу в карточку заявки Мастер установки ключа Валидаты на флешку (admin/setup/keywizard): - пошаговый: загрузка .7z+пароль → выбор флешки → запись → справочник сертификатов (CRL) → перезапуск+проверка ИШ → готово - привилегированный воркер (bj-keymedia) в host-namespace через файл-обмен, bj-server остаётся в песочнице - сохранение структуры профиля архива (spr<N>), перечисление съёмных USB Прочее: - пакет-доказательство для ТП НРД + форма регистрации участника M2M - эталонные образцы робота (DOC/m2m_robot_samples) Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
This commit is contained in:
+4
-11
@@ -40,17 +40,10 @@ func main() {
|
||||
DefaultSender: defaultSender,
|
||||
DefaultReceiver: defaultReceiver,
|
||||
SetupPath: setupPath,
|
||||
CheckOptions: func() lkgateway.CheckOptions {
|
||||
return lkgateway.CheckOptions{
|
||||
PostgresDSN: os.Getenv("BJ_DSN"),
|
||||
CryptoSocket: getenv("BJ_CRYPTO_SOCKET", "/run/bj/crypto.sock"),
|
||||
NSDAdapterURL: os.Getenv("BJ_NSD_ADAPTER_URL"),
|
||||
LKCallbackURL: os.Getenv("BJ_LK_CALLBACK_URL"),
|
||||
Profile: getenv("BJ_NSD_PROFILE", "demo (mock NSD)"),
|
||||
CryptoProvider: getenv("BJ_CRYPTO_PROVIDER", "stub"),
|
||||
Timeout: 2 * time.Second,
|
||||
}
|
||||
},
|
||||
// CheckOptions не задаём — server.go использует свой снапшот-based
|
||||
// вариант, который читает актуальные значения из setup.json
|
||||
// (DSN, crypto-сокет, URL ИШ, профиль), а не из ENV. Так проверки
|
||||
// статуса совпадают с тем, что реально настроено в UI.
|
||||
}
|
||||
|
||||
srv, err := lkgateway.NewServer(cfg)
|
||||
|
||||
Reference in New Issue
Block a user