From d41819eabd6d882cd7367f5ed056673c4d94c994 Mon Sep 17 00:00:00 2001 From: dctouch Date: Tue, 14 Apr 2026 14:18:38 +0300 Subject: [PATCH] =?UTF-8?q?=D0=94=D0=9E=D0=9C=D0=95=D0=9D=D0=AB=20-=20?= =?UTF-8?q?=D0=92=D0=9E=D0=9F=D0=A0=D0=9E=D0=A1=D0=AB=20-=20=D0=A1=D0=9A?= =?UTF-8?q?=D0=9B=D0=90=D0=94=20-=20=D0=9F=D0=BE=D1=87=D0=B8=D0=BD=D0=B8?= =?UTF-8?q?=D1=82=D1=8C=20selected-object=20follow-up=20=D0=BF=D0=BE=20?= =?UTF-8?q?=D1=81=D0=BA=D0=BB=D0=B0=D0=B4=D1=83=20=D0=B8=20=D0=B2=D0=BA?= =?UTF-8?q?=D0=BB=D1=8E=D1=87=D0=B8=D1=82=D1=8C=20=D1=80=D0=B0=D0=B7=D0=B3?= =?UTF-8?q?=D0=BE=D0=B2=D0=BE=D1=80=D0=BD=D1=8B=D0=B5/UI-=D0=B2=D0=B0?= =?UTF-8?q?=D1=80=D0=B8=D0=B0=D0=BD=D1=82=D1=8B=20=D0=B2=20=D0=BE=D0=B1?= =?UTF-8?q?=D1=8F=D0=B7=D0=B0=D1=82=D0=B5=D0=BB=D1=8C=D0=BD=D1=8B=D0=B9=20?= =?UTF-8?q?domain-loop?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .codex/agents/domain_analyst.toml | 2 + .codex/agents/domain_coder.toml | 1 + .codex/agents/orchestrator.toml | 1 + .codex/skills/domain-case-loop/SKILL.md | 3 + .../references/verdict_template.md | 1 + .../runtime_logs/backend_8788_stderr.log | 1 + .../runtime_logs/backend_8788_stdout.log | 22 + .../runtime_logs/backend_8789_stderr.log | 1 + .../runtime_logs/backend_8789_stdout.log | 22 + .../runtime_logs/backend_8790_stderr.log | 8 + .../runtime_logs/backend_8790_stdout.log | 169 +++++++ .../runtime_logs/backend_8791_stderr.log | 1 + .../runtime_logs/backend_8791_stdout.log | 22 + .../runtime_logs/backend_8792_stderr.log | 0 .../runtime_logs/backend_8792_stdout.log | 21 + .../runtime_logs/backend_8793_stderr.log | 0 .../runtime_logs/backend_8793_stdout.log | 21 + .../runtime_logs/backend_8794_stderr.log | 0 .../runtime_logs/backend_8794_stdout.log | 2 + .../runtime_logs/backend_8795_stdout.log | Bin 0 -> 2960 bytes artifacts/runtime_logs/backend_stderr.log | 26 ++ artifacts/runtime_logs/backend_stdout.log | 1 - designconfig.ts | 4 + docs/TECH/address_route_expectations_v1.json | 32 +- .../dist/services/addressCapabilityPolicy.js | 30 +- .../dist/services/addressFilterExtractor.js | 244 +++++++++- .../dist/services/addressIntentResolver.js | 115 ++++- .../dist/services/addressQueryService.js | 59 ++- .../dist/services/addressRecipeCatalog.js | 252 ++++++++--- .../services/address_runtime/composeStage.js | 375 ++++++++++++++++ .../address_runtime/decomposeStage.js | 25 ++ .../backend/dist/services/assistantService.js | 22 +- .../src/services/addressCapabilityPolicy.ts | 30 +- .../src/services/addressFilterExtractor.ts | 297 ++++++++++++- .../src/services/addressIntentResolver.ts | 156 ++++++- .../src/services/addressQueryService.ts | 63 ++- .../src/services/addressRecipeCatalog.ts | 128 +++++- .../services/address_runtime/composeStage.ts | 418 ++++++++++++++++++ .../address_runtime/decomposeStage.ts | 27 ++ .../backend/src/services/assistantService.ts | 22 +- .../backend/src/types/addressQuery.ts | 6 +- .../tests/addressCapabilityPolicy.test.ts | 63 ++- .../tests/addressInventoryChainTail.test.ts | 14 + ...essInventorySelectedObjectFollowup.test.ts | 94 ++++ .../addressInventoryWarehouseAnchor.test.ts | 26 ++ .../tests/addressQueryRuntimeM23.test.ts | 340 +++++++++++++- .../assistantAddressLlmPredecompose.test.ts | 96 ++++ .../tests/assistantLivingRouter.test.ts | 71 +++ ...istant_autogen_runtime_job-X-D_QsIwS1.json | 22 + ...istant_autogen_runtime_job-Ypd6PvQH49.json | 22 + ...istant_autogen_runtime_job-iFZBx9sfg7.json | 22 + ...istant_autogen_runtime_job-ygtwpBa5EM.json | 22 + .../frontend/dist/assets/index-B9mz4jx4.js | 26 ++ .../frontend/dist/assets/index-CEJTyo9A.js | 20 - .../frontend/dist/assets/index-Cx2J_KsF.css | 1 - .../frontend/dist/assets/index-Dcuz1nX5.css | 1 + llm_normalizer/frontend/dist/index.html | 4 +- llm_normalizer/frontend/src/App.tsx | 31 +- .../src/components/AssistantPanel.tsx | 168 ++++++- .../src/components/AutoRunsHistoryPanel.tsx | 28 +- llm_normalizer/frontend/src/state/types.ts | 7 + llm_normalizer/frontend/src/styles.css | 93 ++++ router/query_classifier.py | 62 ++- scripts/domain_case_loop.py | 52 ++- tests/test_domain_case_loop.py | 44 ++ tests/test_route_guards.py | 6 + tests/test_router_decision_flags.py | 30 ++ 67 files changed, 3800 insertions(+), 195 deletions(-) create mode 100644 artifacts/runtime_logs/backend_8788_stderr.log create mode 100644 artifacts/runtime_logs/backend_8788_stdout.log create mode 100644 artifacts/runtime_logs/backend_8789_stderr.log create mode 100644 artifacts/runtime_logs/backend_8789_stdout.log create mode 100644 artifacts/runtime_logs/backend_8790_stderr.log create mode 100644 artifacts/runtime_logs/backend_8790_stdout.log create mode 100644 artifacts/runtime_logs/backend_8791_stderr.log create mode 100644 artifacts/runtime_logs/backend_8791_stdout.log create mode 100644 artifacts/runtime_logs/backend_8792_stderr.log create mode 100644 artifacts/runtime_logs/backend_8792_stdout.log create mode 100644 artifacts/runtime_logs/backend_8793_stderr.log create mode 100644 artifacts/runtime_logs/backend_8793_stdout.log create mode 100644 artifacts/runtime_logs/backend_8794_stderr.log create mode 100644 artifacts/runtime_logs/backend_8794_stdout.log create mode 100644 artifacts/runtime_logs/backend_8795_stdout.log create mode 100644 llm_normalizer/backend/tests/addressInventoryChainTail.test.ts create mode 100644 llm_normalizer/backend/tests/addressInventorySelectedObjectFollowup.test.ts create mode 100644 llm_normalizer/backend/tests/addressInventoryWarehouseAnchor.test.ts create mode 100644 llm_normalizer/data/eval_cases/assistant_autogen_runtime_job-X-D_QsIwS1.json create mode 100644 llm_normalizer/data/eval_cases/assistant_autogen_runtime_job-Ypd6PvQH49.json create mode 100644 llm_normalizer/data/eval_cases/assistant_autogen_runtime_job-iFZBx9sfg7.json create mode 100644 llm_normalizer/data/eval_cases/assistant_autogen_runtime_job-ygtwpBa5EM.json create mode 100644 llm_normalizer/frontend/dist/assets/index-B9mz4jx4.js delete mode 100644 llm_normalizer/frontend/dist/assets/index-CEJTyo9A.js delete mode 100644 llm_normalizer/frontend/dist/assets/index-Cx2J_KsF.css create mode 100644 llm_normalizer/frontend/dist/assets/index-Dcuz1nX5.css create mode 100644 tests/test_domain_case_loop.py diff --git a/.codex/agents/domain_analyst.toml b/.codex/agents/domain_analyst.toml index 3fbb1c5..f49f74d 100644 --- a/.codex/agents/domain_analyst.toml +++ b/.codex/agents/domain_analyst.toml @@ -37,6 +37,8 @@ Rules: - Do not praise superficial wording improvements if the compute layer is still wrong. - Highlight if an answer is unusable for a manager, accountant, or operator. - If the system answered a weaker question than the user asked, say so explicitly. +- Treat colloquial/slang wording, typo variants, and UI-generated selected-object follow-ups as first-class coverage, not optional polish. +- If the domain works only for one curated phrasing but breaks for realistic conversational or UI-originated follow-ups, call that out as a real defect and lower the score. Quality score: - Output one integer score from 0 to 100. diff --git a/.codex/agents/domain_coder.toml b/.codex/agents/domain_coder.toml index 658511e..9fad7e2 100644 --- a/.codex/agents/domain_coder.toml +++ b/.codex/agents/domain_coder.toml @@ -17,6 +17,7 @@ Your mission: - Find the smallest domain-only patch that moves the case toward a correct, useful, business-readable answer. - Use exact 1C/MCP-backed routes when they exist. - If exact data does not exist in the reachable contour, surface technical insufficiency instead of fabricating a result. +- Close the realistic surface of the bug, not only the clean canonical wording; include colloquial and UI-generated selected-object follow-up variants when they are part of the failing flow. Allowed change zones: - intents diff --git a/.codex/agents/orchestrator.toml b/.codex/agents/orchestrator.toml index a15f171..1c5f02c 100644 --- a/.codex/agents/orchestrator.toml +++ b/.codex/agents/orchestrator.toml @@ -38,6 +38,7 @@ Hard rules: - In autonomous loop mode, do not stop only because the analyst says `needs_exact_capability` or `partial` if there is still autonomous implementation work to do. - Stop early when the analyst sets `requires_user_decision = true` because the next step would otherwise require guessing a missing required observation, accepting a risky architecture fork, choosing a business-critical tradeoff, or pushing through a hacky / brittle / disproportionally complex fix. - Treat true runtime or 1C availability failures as `blocked`, not as a normal low-score iteration. +- For follow-up-heavy domains, capture and rerun at least one colloquial/slang variant and one UI-generated selected-object follow-up variant instead of validating only canonical wording. Acceptance gate: - accepted requires analyst quality_score >= 80 diff --git a/.codex/skills/domain-case-loop/SKILL.md b/.codex/skills/domain-case-loop/SKILL.md index da25a06..92c8f2b 100644 --- a/.codex/skills/domain-case-loop/SKILL.md +++ b/.codex/skills/domain-case-loop/SKILL.md @@ -15,6 +15,7 @@ This skill packages the standard workflow for iterating on one concrete domain c - there is a gap between exact compute intent and actual fallback output; - there are follow-up / continuation bugs that corrupt business context. - the user has a cascade of linked questions that should reuse one assistant session and semantic state. +- the bug appears only in colloquial/slang wording or in UI-generated follow-up phrasing such as `По выбранному объекту "...": ...`. ## Do not use this skill when @@ -77,6 +78,7 @@ In autonomous pack-loop mode: - stop only on `accepted`, `blocked`, explicit `requires_user_decision = true`, or `max_iterations`; - do not stop just because the analyst returns `needs_exact_capability` or `partial` if autonomous domain enablement work still remains. - treat `quality score >= 80` as the target gate, not as permission to keep pushing through hard blockers, missing essential observations, or unsafe fixes. +- for follow-up-heavy domains, include conversational variants, slang/typo variants, and UI-generated selected-object follow-ups in the acceptance slice instead of validating only one canonical wording. ### Step 1 - Normalize the case @@ -182,6 +184,7 @@ Accepted requires: - Keep domain fixes minimal and localized. - Preserve successful baseline scenarios. - Treat follow-up continuity as a state-machine problem, not a wording problem. +- Do not accept a domain as hardened if only canonical phrasing works while colloquial or UI-generated follow-up phrasing still breaks the exact contour. ## Domain-specific framing diff --git a/.codex/skills/domain-case-loop/references/verdict_template.md b/.codex/skills/domain-case-loop/references/verdict_template.md index 7fdb726..6aeaa5a 100644 --- a/.codex/skills/domain-case-loop/references/verdict_template.md +++ b/.codex/skills/domain-case-loop/references/verdict_template.md @@ -30,6 +30,7 @@ ## 10. Acceptance criteria for rerun - ... +- Include colloquial/slang variants and UI-generated selected-object follow-up variants when they are part of the business flow. ## 11. Quality score - integer from 0 to 100 diff --git a/artifacts/runtime_logs/backend_8788_stderr.log b/artifacts/runtime_logs/backend_8788_stderr.log new file mode 100644 index 0000000..7c6b07c --- /dev/null +++ b/artifacts/runtime_logs/backend_8788_stderr.log @@ -0,0 +1 @@ +[trace-completeness] trace_id=FxptYyx1YHermm schema=v1 issues=missing_parsed_normalized_json diff --git a/artifacts/runtime_logs/backend_8788_stdout.log b/artifacts/runtime_logs/backend_8788_stdout.log new file mode 100644 index 0000000..f24a2bd --- /dev/null +++ b/artifacts/runtime_logs/backend_8788_stdout.log @@ -0,0 +1,22 @@ +{"timestamp":"2026-04-14T07:32:51.289Z","level":"info","service":"llm_normalizer_backend","message":"Backend started on http://localhost:8788"} +{"timestamp":"2026-04-14T07:33:15.591Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-c7BDhkZ5ku","eventType":"assistant_message_address","details":{"session_id":"asst-c7BDhkZ5ku","message_id":"msg-eS5jZSFREs","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"dfLcGNfsRuL4am","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","limit":20,"as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-F1jADF44h0"}} +{"timestamp":"2026-04-14T07:33:21.660Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-c7BDhkZ5ku","eventType":"assistant_message_address","details":{"session_id":"asst-c7BDhkZ5ku","message_id":"msg-SVBWcn6hv8","user_message":"Из каких товаров состоит остаток по 41 счету","effective_address_user_message":"Какие товары составляют остаток на счете 41","address_followup_context_applied":true,"address_followup_context_previous_intent":"inventory_on_hand_as_of_date","address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"n0COyUFYeuTpUn","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"из каких товаров состоит остаток по 41 счету","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"continue_previous","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","limit":20,"account":"41","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-3h0hT6_2nm"}} +{"timestamp":"2026-04-14T07:33:27.767Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-c7BDhkZ5ku","eventType":"assistant_message_address","details":{"session_id":"asst-c7BDhkZ5ku","message_id":"msg-Y-rOO9-LNO","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31","effective_address_user_message":"Получить список товаров, находящихся на счете 41 на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"aaUTYS37Fq1hpS","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","limit":20,"account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address--ZsyViEb_w"}} +{"timestamp":"2026-04-14T07:33:33.837Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-c7BDhkZ5ku","eventType":"assistant_message_address","details":{"session_id":"asst-c7BDhkZ5ku","message_id":"msg-eYNkWE5Vum","user_message":"Какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","effective_address_user_message":"Получить список номенклатур, формирующих остаток на складе на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"ub73d6vtEtbmPo","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","limit":20,"as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-gDm253pwjo"}} +{"timestamp":"2026-04-14T07:33:39.917Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-uR03-9Nv8G","eventType":"assistant_message_address","details":{"session_id":"asst-uR03-9Nv8G","message_id":"msg-bVYU3xtCNk","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"rq5yAkEhqXWRws","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","limit":20,"as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-MpT-_mCDoD"}} +{"timestamp":"2026-04-14T07:33:47.026Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-uR03-9Nv8G","eventType":"assistant_message_address","details":{"session_id":"asst-uR03-9Nv8G","message_id":"msg-1r1rYeiY6S","user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"zpfNg2vHM2WFdL","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"от какого поставщика куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","limit":20,"item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"error","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"error","rows_fetched":0,"raw_rows_received":0,"rows_after_account_scope":0,"rows_after_recipe_filter":0,"rows_materialized":0,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"UNKNOWN","limited_reason_category":"execution_error","response_type":"LIMITED_WITH_REASON","limitations":["mcp_call_failed"],"assistant_reply":"Не удалось завершить проверку в адресном режиме.\n\nlive MCP вызов завершился ошибкой.\n\nКонтекст запроса: срез на 2026-04-14.\n\nЧто могу сделать сейчас: показать подтвержденные закупочные движения по товару на 41.01 с датами и документами; показать документы/платежи по контрагенту или договору; показать незакрытые договоры или хвосты на дату.","reply_type":"partial_coverage","trace_id":"address-_Kcqa_88uz"}} +{"timestamp":"2026-04-14T07:33:53.891Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-uR03-9Nv8G","eventType":"assistant_message_address","details":{"session_id":"asst-uR03-9Nv8G","message_id":"msg--hM4_Pbrry","user_message":"У какого поставщика были куплены товары, которые сейчас лежат на складе Основной склад организации ООО \\Альтернатива Плюс\\","effective_address_user_message":"У какого поставщика были куплены товары, которые сейчас лежат на складе Основной склад организации ООО \\Альтернатива Плюс\\","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"hoXjQBxMCs0bMX","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"у какого поставщика были куплены товары, которые сейчас лежат на складе основной склад организации ооо \\альтернатива плюс\\","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","limit":20,"warehouse":"Основной склад организации ООО \\Альтернатива Плюс\\","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"skipped","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"skipped","rows_fetched":0,"raw_rows_received":0,"rows_after_account_scope":0,"rows_after_recipe_filter":0,"rows_materialized":0,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":"missing_anchor","response_type":"LIMITED_WITH_REASON","limitations":["missing_required_filters"],"assistant_reply":"Запрос понятен, но для надежного ответа не хватает опорного ориентира.\n\nСмысл запроса понятен, но без уточнения (товар) риск ошибки слишком высокий.\n\nКонтекст запроса: срез на 2026-04-14.\n\nЧто могу сделать сейчас: уточнить ориентир: товар; показать подтвержденные закупочные движения по товару на 41.01 с датами и документами; показать документы/платежи по контрагенту или договору.","reply_type":"partial_coverage","trace_id":"address-36sMOcPGzT"}} +{"timestamp":"2026-04-14T07:33:59.664Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-uR03-9Nv8G","eventType":"assistant_message_address","details":{"session_id":"asst-uR03-9Nv8G","message_id":"msg-EJtE-LcSpX","user_message":"По какому поставщику проходит текущий товарный остаток на складе Основной склад","effective_address_user_message":"Получить информацию о поставщике, связанным с текущим товарным остатком на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"nRc7A5VWPYKWgm","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"по какому поставщику проходит текущий товарный остаток на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","limit":20,"warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":null,"mcp_call_status_legacy":"skipped","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"skipped","rows_fetched":0,"raw_rows_received":0,"rows_after_account_scope":0,"rows_after_recipe_filter":0,"rows_materialized":0,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"REQUIRES_SPECIALIZED_RECIPE","limited_reason_category":"recipe_visibility_gap","response_type":"LIMITED_WITH_REASON","limitations":["recipe_not_available"],"assistant_reply":"Запрос понятен, но текущий сценарий выборки не дает нужной детализации.\n\nДля уверенного ответа нужен более специализированный сценарий выборки.\n\nКонтекст запроса: срез на 2026-04-14.\n\nЧто могу сделать сейчас: показать документы/платежи по контрагенту или договору; показать незакрытые договоры или хвосты на дату; можно выбрать близкий поддерживаемый сценарий или переключить запрос в режим расширенной проверки.","reply_type":"partial_coverage","trace_id":"address-9bfIz1K3pQ"}} +{"timestamp":"2026-04-14T07:34:06.337Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-uR03-9Nv8G","eventType":"assistant_message_address","details":{"session_id":"asst-uR03-9Nv8G","message_id":"msg-VhIJvi4EvH","user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"78aiYlaUyATAdv","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"когда был куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","limit":20,"item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"error","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"error","rows_fetched":0,"raw_rows_received":0,"rows_after_account_scope":0,"rows_after_recipe_filter":0,"rows_materialized":0,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"UNKNOWN","limited_reason_category":"execution_error","response_type":"LIMITED_WITH_REASON","limitations":["mcp_call_failed"],"assistant_reply":"Не удалось завершить проверку в адресном режиме.\n\nlive MCP вызов завершился ошибкой.\n\nКонтекст запроса: срез на 2026-04-14.\n\nЧто могу сделать сейчас: показать подтвержденные закупочные движения по товару на 41.01 с датами и документами; показать документы/платежи по контрагенту или договору; показать незакрытые договоры или хвосты на дату.","reply_type":"partial_coverage","trace_id":"address-GLXQOuQhk2"}} +{"timestamp":"2026-04-14T07:34:13.444Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-uR03-9Nv8G","eventType":"assistant_message_address","details":{"session_id":"asst-uR03-9Nv8G","message_id":"msg-CuSCuOGkHv","user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","effective_address_user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"gMseCPXe9e1tD8","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"по каким документам был куплен товар диван трехместный для остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_documents_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_documents_for_item","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_documents_for_item","extracted_filters":{"sort":"period_desc","limit":20,"item":"Диван трехместный для остатка на складе Основной склад","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_documents_for_item_v1","mcp_call_status_legacy":"error","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"error","rows_fetched":0,"raw_rows_received":0,"rows_after_account_scope":0,"rows_after_recipe_filter":0,"rows_materialized":0,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"UNKNOWN","limited_reason_category":"execution_error","response_type":"LIMITED_WITH_REASON","limitations":["mcp_call_failed"],"assistant_reply":"Не удалось завершить проверку в адресном режиме.\n\nlive MCP вызов завершился ошибкой.\n\nСигнал запроса: список документов/операций.\n\nКонтекст запроса: срез на 2026-04-14.\n\nЧто могу сделать сейчас: показать документы поступления по товару на 41.01; показать документы/платежи по контрагенту или договору; показать незакрытые договоры или хвосты на дату.","reply_type":"partial_coverage","trace_id":"address-lb86RBF0-J"}} +{"timestamp":"2026-04-14T07:34:19.793Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-uR03-9Nv8G","eventType":"assistant_message_address","details":{"session_id":"asst-uR03-9Nv8G","message_id":"msg-hTzPguE8K0","user_message":"Какие товары от поставщика Гамма-мебель, ООО сейчас еще лежат на складе Основной склад","effective_address_user_message":"Получить информацию о товарах от поставщика 'Гамма-мебель, ООО', которые находятся на складе 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"GpYvaBaIYxQmNC","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары от поставщика гамма-мебель, ооо сейчас еще лежат на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","limit":20,"warehouse":"Основной склад","counterparty":"Гамма-мебель","as_of_date":"2026-04-14"},"selected_recipe":null,"mcp_call_status_legacy":"skipped","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"skipped","rows_fetched":0,"raw_rows_received":0,"rows_after_account_scope":0,"rows_after_recipe_filter":0,"rows_materialized":0,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"REQUIRES_SPECIALIZED_RECIPE","limited_reason_category":"recipe_visibility_gap","response_type":"LIMITED_WITH_REASON","limitations":["recipe_not_available"],"assistant_reply":"Сценарий запроса корректный, но текущая витрина не дает нужной детализации.\n\nДля уверенного ответа нужен более специализированный сценарий выборки.\n\nКонтекст запроса: срез на 2026-04-14.\n\nЧто могу сделать сейчас: показать документы и платежи по контрагенту Гамма-мебель; показать незакрытые договоры или хвосты на дату; можно выбрать близкий поддерживаемый сценарий или переключить запрос в режим расширенной проверки.","reply_type":"partial_coverage","trace_id":"address-uzElApRZTn"}} +{"timestamp":"2026-04-14T07:34:26.493Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-uR03-9Nv8G","eventType":"assistant_message_address","details":{"session_id":"asst-uR03-9Nv8G","message_id":"msg-5HXpt3zbHn","user_message":"Какие товары по состоянию на дату 2020-03-31 на складе Основной склад были куплены у поставщика Гамма-мебель, ООО","effective_address_user_message":"Какие товары по состоянию на дату 2020-03-31 на складе Основной склад были куплены у поставщика Гамма-мебель, ООО","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"p4ZN3wY2LsrNTx","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары по состоянию на дату 2020-03-31 на складе основной склад были куплены у поставщика гамма-мебель, ооо","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","limit":20,"as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"skipped","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"skipped","rows_fetched":0,"raw_rows_received":0,"rows_after_account_scope":0,"rows_after_recipe_filter":0,"rows_materialized":0,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":"missing_anchor","response_type":"LIMITED_WITH_REASON","limitations":["missing_required_filters"],"assistant_reply":"Вопрос по смыслу ясен, но пока не хватает конкретной опоры для выборки.\n\nНужно чуть точнее заякорить запрос: не хватает конкретного ориентира (товар).\n\nКонтекст запроса: срез на 2020-03-31.\n\nЧто могу сделать сейчас: уточнить ориентир: товар; показать подтвержденные закупочные движения по товару на 41.01 с датами и документами; показать документы/платежи по контрагенту или договору.","reply_type":"partial_coverage","trace_id":"address-1XGxrMnSpu"}} +{"timestamp":"2026-04-14T07:34:32.745Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-EVxK9tqjYB","eventType":"assistant_message_address","details":{"session_id":"asst-EVxK9tqjYB","message_id":"msg-jrKPCNXi6B","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"2nxoY7iYdXJuzR","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","limit":20,"as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-vghvQvlXvU"}} +{"timestamp":"2026-04-14T07:34:39.734Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-EVxK9tqjYB","eventType":"assistant_message_address","details":{"session_id":"asst-EVxK9tqjYB","message_id":"msg-j1OODTKkyT","user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","effective_address_user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"bcSvqVg6nYo58B","address_llm_predecompose_reason":"normalized_fragment_rejected_semantic_guard","address_fallback_rule_hit":null,"address_sanitized_user_message":"относится ли товар шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_aging_by_purchase_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_aging_by_purchase_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_aging_by_purchase_date","extracted_filters":{"sort":"period_desc","limit":20,"as_of_date":"2020-03-31"},"selected_recipe":null,"mcp_call_status_legacy":"skipped","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":null,"resolver_confidence":null,"match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"skipped","rows_fetched":0,"raw_rows_received":0,"rows_after_account_scope":0,"rows_after_recipe_filter":0,"rows_materialized":0,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"DEEP_ONLY","limited_reason_category":"unsupported","response_type":"LIMITED_WITH_REASON","limitations":["capability_route_disabled_by_flag"],"assistant_reply":"Сейчас не дам прямой адресный ответ, чтобы не ошибиться в выводах.\n\nДля этого запроса пока нет надежного ответа в текущем адресном режиме.\n\nКонтекст запроса: срез на 2020-03-31.","reply_type":"partial_coverage","trace_id":"address-CEY2Od-a6H"}} +{"timestamp":"2026-04-14T07:34:45.943Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-EVxK9tqjYB","eventType":"assistant_message_address","details":{"session_id":"asst-EVxK9tqjYB","message_id":"msg-AiqaWjRy2A","user_message":"Есть ли на складе Основной склад товары с остатком без понятной привязки к поставщику","effective_address_user_message":"Есть ли на складе Основной склад товары с остатком без понятной привязки к поставщику","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"Tf2u6hYbkqtsK9","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли на складе основной склад товары с остатком без понятной привязки к поставщику","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","limit":20,"item":"с остатком без понятной привязки к поставщику","warehouse":"Основной склад товары","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"error","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"error","rows_fetched":0,"raw_rows_received":0,"rows_after_account_scope":0,"rows_after_recipe_filter":0,"rows_materialized":0,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"UNKNOWN","limited_reason_category":"execution_error","response_type":"LIMITED_WITH_REASON","limitations":["mcp_call_failed"],"assistant_reply":"Не удалось завершить проверку в адресном режиме.\n\nlive MCP вызов завершился ошибкой.\n\nСигнал запроса: проверка фактического состояния по данным.\n\nКонтекст запроса: срез на 2026-04-14.\n\nЧто могу сделать сейчас: показать подтвержденные закупочные движения по товару на 41.01 с датами и документами; показать документы/платежи по контрагенту или договору; показать незакрытые договоры или хвосты на дату.","reply_type":"partial_coverage","trace_id":"address-libJ1lTV1p"}} +{"timestamp":"2026-04-14T07:34:53.071Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-EVxK9tqjYB","eventType":"assistant_message_address","details":{"session_id":"asst-EVxK9tqjYB","message_id":"msg-_OaYwpEJQW","user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","effective_address_user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"TkzXaw4cHxWlPz","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли среди текущих остатков на складе основной склад позиции, закупленные задолго до 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","limit":20,"as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-k6WoIsQqUS"}} +{"timestamp":"2026-04-14T07:34:59.137Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-AoX9SCFG9s","eventType":"assistant_message_address","details":{"session_id":"asst-AoX9SCFG9s","message_id":"msg-BlQEhJlMlL","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31 на складе Основной склад","effective_address_user_message":"Получить список товаров, находящихся на счете 41 на дату 2020-03-31 для склада 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"p0LdxrR4EEtf5u","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31 на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","limit":20,"account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-zfsmbmWLOP"}} +{"timestamp":"2026-04-14T07:35:06.233Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-AoX9SCFG9s","eventType":"assistant_message_address","details":{"session_id":"asst-AoX9SCFG9s","message_id":"msg-qACjXWm7HH","user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","effective_address_user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"EJlVu69-i4GnFG","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"кому был продан товар шкаф картотечный 1000*400*2100","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_sale_trace_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_sale_trace_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_sale_trace_for_item","extracted_filters":{"sort":"period_desc","limit":20,"item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_sale_trace_for_item_v1","mcp_call_status_legacy":"error","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"error","rows_fetched":0,"raw_rows_received":0,"rows_after_account_scope":0,"rows_after_recipe_filter":0,"rows_materialized":0,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"UNKNOWN","limited_reason_category":"execution_error","response_type":"LIMITED_WITH_REASON","limitations":["mcp_call_failed"],"assistant_reply":"Не удалось завершить проверку в адресном режиме.\n\nlive MCP вызов завершился ошибкой.\n\nКонтекст запроса: срез на 2026-04-14.\n\nЧто могу сделать сейчас: показать подтвержденные движения выбытия товара со счета 41.01; показать документы/платежи по контрагенту или договору; показать незакрытые договоры или хвосты на дату.","reply_type":"partial_coverage","trace_id":"address-iXpdlLktz3"}} +{"timestamp":"2026-04-14T07:35:14.378Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-AoX9SCFG9s","eventType":"assistant_message_address","details":{"session_id":"asst-AoX9SCFG9s","message_id":"msg-CBD8MKx9J7","user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","effective_address_user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"HZBwzD01Aq5Iwj","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"через какие документы прошел путь товара шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_to_sale_chain","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_to_sale_chain","extracted_filters":{"sort":"period_desc","limit":20,"item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_to_sale_chain_v1","mcp_call_status_legacy":"error","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"error","rows_fetched":0,"raw_rows_received":0,"rows_after_account_scope":0,"rows_after_recipe_filter":0,"rows_materialized":0,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"UNKNOWN","limited_reason_category":"execution_error","response_type":"LIMITED_WITH_REASON","limitations":["mcp_call_failed"],"assistant_reply":"Не удалось завершить проверку в адресном режиме.\n\nlive MCP вызов завершился ошибкой.\n\nСигнал запроса: список документов/операций.\n\nКонтекст запроса: срез на 2026-04-14.\n\nЧто могу сделать сейчас: показать документальную цепочку по товару: поступление на 41.01 и последующее выбытие; показать документы/платежи по контрагенту или договору; показать незакрытые договоры или хвосты на дату.","reply_type":"partial_coverage","trace_id":"address-pqaMWLkc1h"}} +{"timestamp":"2026-04-14T07:35:24.477Z","level":"info","service":"assistant_loop","message":"assistant_address_tool_gate_skip","sessionId":"asst-AoX9SCFG9s","details":{"session_id":"asst-AoX9SCFG9s","user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","effective_address_user_message":"Проверить наличие документально подтвержденной цепочки: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотечный 1000*400*2100 -> покупатель департамент капитального ремонта города москвы","assistant_orchestration_contract_v1":{"schema_version":"assistant_orchestration_contract_v1","hard_meta_mode":null,"address_mode":"deep_analysis","address_mode_confidence":"high","address_intent":"inventory_supplier_stock_overlap_as_of_date","address_intent_confidence":"medium","strong_data_signal_detected":true,"data_retrieval_signal_detected":true,"semantic_contract_valid":true,"semantic_apply_canonical_recommended":true,"semantic_reason_codes":["deep_investigation_signal_detected"],"semantic_route_arbitration":{"supported_address_intent_detected":false,"semantic_deep_investigation_hint_detected":true,"semantic_aggregate_shape_detected":false,"followup_semantic_override_to_deep_allowed":false},"followup_context_detected":false,"unsupported_address_intent_fallback_to_deep":false,"deep_analysis_signal_fallback_to_deep":true,"aggregate_analytics_signal_fallback_to_deep":false,"deep_session_continuation_fallback_to_deep":false,"final_decision":{"run_address_lane":false,"tool_gate_decision":"skip_address_lane","tool_gate_reason":"deep_analysis_signal_fallback_to_deep","living_mode":"deep_analysis","living_reason":"deep_analysis_signal_fallback_to_deep"}},"address_tool_gate_decision":"skip_address_lane","address_tool_gate_reason":"deep_analysis_signal_fallback_to_deep","address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["deep_investigation_signal_detected"]}} +{"timestamp":"2026-04-14T07:35:44.731Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-AoX9SCFG9s","eventType":"assistant_message","details":{"session_id":"asst-AoX9SCFG9s","message_id":"msg-2bUou7ybQC","user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","normalizer_output":null,"execution_plan":[],"resolved_execution_state":[],"routes":[],"retrieval_calls":[],"retrieval_results_raw":[],"retrieval_results_normalized":[],"requirements_extracted":[{"requirement_id":"R1","source_fragment_id":null,"requirement_text":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","subject_tokens":["counterparty","document","chain"],"status":"clarification_needed","route":null}],"requirements_total":1,"requirements_covered":0,"requirements_uncovered":[],"coverage_status":"partial_or_limited","answer_grounding_status":"no_grounded_answer","reply_semantic_type":"clarification_required","why_included_summary":[],"selection_reason_summary":[],"route_subject_match":true,"clarification_target":["R1"],"dropped_intent_segments":[],"question_type_class":"unknown","company_anchors":{"contract_numbers":[],"document_numbers":[],"dates":[],"amounts":[],"accounts":[],"periods":[],"document_types":[],"all":[]},"analysis_context_applied":true,"analysis_context":{"as_of_date":"2026-04-13","period_from":null,"period_to":null,"source":"scenario_pack","snapshot_mode":"auto"},"business_scope_raw":[],"business_scope_resolved":["company_specific_accounting"],"company_grounding_applied":true,"scope_resolution_reason":["settlement_claim_company_scope_recovery"],"company_scope_resolution_reason":["settlement_claim_company_scope_recovery"],"raw_time_anchor":"2026-04-13","raw_time_scope":"2026-04-13..2026-04-13","resolved_time_anchor":"2026-04-13","resolved_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"effective_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"temporal_guard_input":"2026-04-13..2026-04-13","temporal_alignment_status":"aligned","temporal_resolution_source":"scenario_pack","temporal_guard_basis":"raw_time_scope_unlocked","temporal_guard_applied":false,"temporal_guard_outcome":"passed","temporal_guard":{"raw_time_anchor":"2026-04-13","raw_time_scope":"2026-04-13..2026-04-13","resolved_time_anchor":"2026-04-13","resolved_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"effective_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"temporal_guard_input":"2026-04-13..2026-04-13","temporal_alignment_status":"aligned","temporal_resolution_source":"scenario_pack","temporal_guard_basis":"raw_time_scope_unlocked","temporal_guard_applied":false,"temporal_guard_outcome":"passed","primary_period_window":null,"allowed_context_window":null,"controlled_temporal_expansion_enabled":false,"context_expansion_reasons_allowed":["prehistory","carryover","post_period_closure","long_running_contract_context"],"normalized_anchor_drift_detected":false,"reason_codes":["analysis_context_applied"]},"raw_numeric_tokens":["1000","400","2100"],"classified_numeric_tokens":[],"rejected_as_non_accounts":[],"resolved_account_anchors":[],"domain_polarity_guard":{"applied":true,"polarity":"mixed_or_unresolved","outcome":"limited_unresolved_polarity","supplier_score":2,"customer_score":2,"account_scope":[],"raw_numeric_tokens":["1000","400","2100"],"classified_numeric_tokens":[],"rejected_as_non_accounts":[],"resolved_account_anchors":[],"rejected_problem_units":0,"rejected_evidence":0,"critical_contradiction":true,"reason_codes":["unresolved_supplier_customer_polarity","supplier_customer_signals_conflict"]},"claim_anchor_audit":{"claim_type":"prove_settlement_closure_state","settlement_role":"mixed","settlement_role_resolution_reason":["settlement_role_resolved_mixed"],"polarity_resolution_status":"mixed","required_anchors":["period","account_scope","counterparty_scope_or_contract","closure_signal"],"resolved_anchors":{"period":["2026-04-13"],"account_scope":[],"amounts":[],"contract":[],"document_numbers":[],"document_types":[],"counterparty_scope":["supplier","customer"],"advance_signal":[],"closure_signal":[],"vat_signal":[],"chain_signal":[],"close_signal":[],"cost_scope":[],"rbp_signal":[],"writeoff_signal":[],"fixed_asset_signal":[],"amortization_signal":[],"expected_fa_set":[],"actual_fa_set":[]},"missing_anchors":["account_scope","closure_signal"],"claim_anchor_resolution_rate":0.5,"primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"allowed_context_window":{"from":"2025-04-13","to":"2027-04-13","granularity":"month"},"context_expansion_reasons_allowed":["prehistory","carryover","post_period_closure","long_running_contract_context"],"reason_codes":["claim_missing_required_anchors","claim_anchor_resolution_low","unresolved_supplier_customer_polarity"]},"settlement_role":"mixed","settlement_role_resolution_reason":["settlement_role_resolved_mixed"],"polarity_resolution_status":"mixed","targeted_evidence_acquisition":{"claim_type":"prove_settlement_closure_state","required_checks":["payment_document_found","contract_matched","settlement_object_matched","closing_document_found","register_closure_entry_found","posting_link_found"],"check_status":{"payment_document_found":"not_found","contract_matched":"not_found","settlement_object_matched":"not_found","closing_document_found":"not_found","register_closure_entry_found":"not_found","posting_link_found":"not_found"},"targeted_item_hits":0,"targeted_evidence_hits":0,"targeted_evidence_hit_rate":0,"targeted_evidence_source_refs":[],"reason_codes":["targeted_evidence_not_found","targeted_evidence_hit_rate_low"]},"evidence_admissibility_gate":{"candidate_evidence_total":0,"admissible_evidence_count":0,"rejected_evidence_count":0,"rejected_item_count":0,"reject_breakdown":{"wrong_period":0,"wrong_domain":0,"wrong_account_scope":0,"weak_source_mapping":0,"zero_live_match":0,"future_dated_or_out_of_window":0},"category_breakdown":{"hard_evidence":0,"supporting_signal":0,"inadmissible_noise":0},"reason_codes":["no_admissible_evidence_for_grounded_answer"]},"eligibility_time_basis":"raw_time_scope_unlocked","grounded_answer_eligibility_guard":{"eligible":false,"temporal_passed":true,"eligibility_time_basis":"raw_time_scope_unlocked","business_scope_passed":true,"polarity_passed":false,"claim_anchors_passed":true,"claim_anchor_resolution_rate":0.5,"missing_required_anchors":2,"admissible_evidence_count":0,"critical_contradiction":true,"outcome":"limited_or_insufficient_evidence","grounding_mode":"limited_or_insufficient_evidence","reason_codes":["polarity_guard_limited_unresolved_polarity","admissible_evidence_count_zero","targeted_evidence_hit_rate_zero","critical_domain_or_account_contradiction"]},"problem_centric_answer_applied":false,"problem_units_used_count":0,"problem_answer_mode":"stage1_policy_v11","assistant_outcome_class_v1":"BLOCKED_BY_AMBIGUITY","assistant_orchestration_contracts_v1":{"query_frame":{"schema_version":"assistant_query_frame_v1","original_user_question":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","normalized_question":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","route_summary_mode":"none","fragments_total":0,"dropped_intent_segments":[],"analysis_context":{"as_of_date":"2026-04-13","period_from":null,"period_to":null,"source":"scenario_pack","snapshot_mode":"auto"}},"execution_plan":{"schema_version":"assistant_execution_plan_v1","steps":[],"requirements_total":1},"evidence_bundle":{"schema_version":"assistant_evidence_bundle_v1","retrieval_calls_total":0,"retrieval_results_total":0,"retrieval_status_breakdown":{"ok":0,"partial":0,"empty":0,"error":0},"evidence_total":0,"source_refs_total":0,"limitation_total":0,"error_total":0},"coverage":{"schema_version":"assistant_coverage_contract_v1","coverage_report":{"requirements_total":1,"requirements_covered":0,"requirements_uncovered":[],"requirements_partially_covered":[],"clarification_needed_for":["R1"],"out_of_scope_requirements":[]},"grounding":{"status":"no_grounded_answer","route_subject_match":true,"missing_requirements":["R1"],"reasons":["Ни одно требование не получило подтвержденного покрытия.","В текущей выборке не хватает явных подтверждений, почему записи попали в ответ.","Часть контекста вопроса не подтверждена напрямую в найденных данных: counterparty, document, chain","Не удалось однозначно определить сторону расчета (нам должны или мы должны).","Недостаточно подтвержденных данных для уверенного ответа.","Не хватило целевых подтверждений по выбранному сценарию.","Есть противоречие по выбранному домену или контуру счета."],"why_included_summary":[],"selection_reason_summary":[]},"outcome_class":"BLOCKED_BY_AMBIGUITY"}},"answer_contract_stage4_v1":{"schema_version":"stage4_answer_contract_audit_v1","stage4_blocks_expected":["Коротко","Что именно проверено","Что найдено","Что пока не доказано","Что проверить первым/Что могу сделать сейчас"],"stage4_blocks_present":["Коротко","Что именно проверено","Что найдено","Что пока не доказано","Что проверить первым/Что могу сделать сейчас"],"stage4_blocks_missing":[],"legacy_blocks_present":[],"is_stage4_shape":true},"answer_structure_v11":{"schema_version":"answer_structure_v1_1","answer_summary":"Нужны уточнения: без сужения фокуса надежный вывод невозможен.","direct_answer":"Есть признаки проблемы, но без уточнений по периоду и объекту вывод ненадежен.","mechanism_block":{"status":"unresolved","mechanism_notes":[],"limitation_reason_codes":[]},"evidence_block":{"evidence_ids":[],"source_refs":[],"mechanism_notes":[],"coverage_note":"coverage_partial_or_limited"},"uncertainty_block":{"open_uncertainties":["R1","missing_anchor:period","missing_anchor:account","missing_anchor:counterparty"],"limitations":["Ни одно требование не получило подтвержденного покрытия.","В текущей выборке не хватает явных подтверждений, почему записи попали в ответ.","Часть контекста вопроса не подтверждена напрямую в найденных данных: counterparty, document, chain","Не удалось однозначно определить сторону расчета (нам должны или мы должны).","Недостаточно подтвержденных данных для уверенного ответа.","Не хватило целевых подтверждений по выбранному сценарию.","Есть противоречие по выбранному домену или контуру счета."]},"next_step_block":{"recommended_actions":["Дайте недостающие якоря (период/счет/объект), иначе сильный factual вывод невозможен."],"clarification_questions":["Уточните период проверки (например, июль 2020).","Уточните счет или группу счетов (например, 19, 60, 62).","Укажите контрагента или группу контрагентов.","Закройте уточнения для требований: R1."]}},"investigation_state_snapshot":{"schema_version":"investigation_state_v1","session_id":"asst-AoX9SCFG9s","status":"active","turn_index":1,"updated_at":"2026-04-14T07:35:44.718Z","question_id":"msg-_mFVyt5Zvk","question_scope_id":"d:settlements_60_62|s:есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотеч","scope_origin":"explicit_from_message","focus":{"domain":"settlements_60_62","period":null,"primary_accounts":[],"active_query_subject":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы"},"narrowing_status":"unknown","evidence_refs":[],"open_uncertainties":["clarify:R1"],"last_answer_mode":"clarification_required","followup_context":{"previous_question_id":null,"last_user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","referenced_requirement_ids":["R1"],"active_domain":"settlements_60_62","active_requirement_ids":["R1"],"uncovered_requirement_ids":["R1"],"last_problem_unit_id":null,"settlement_next_actions":["Проверьте договор и объект расчетов по платежу.","Сверьте регистр расчетов и привязку платежа к закрывающему документу.","Проверьте зачет аванса или взаимозачет по связке 60/62."],"evidence_summary":[],"question_scope_id":"d:settlements_60_62|s:есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотеч","scope_origin":"explicit_from_message"},"query_mode_hint":"investigation_candidate"},"fallback_type":"clarification","assistant_reply":"Коротко: По этому запросу у меня нет надежного доменного покрытия, поэтому даю мягкий отказ вместо технического шаблона.\n\nЧто именно проверено:\n- Проверен доступный контур 1С и возможность маршрутизации запроса.\n- Надежный доменный путь для текущей формулировки не подтвержден.\n\nЧто найдено:\n- Взаиморасчеты 60/62: найти хвосты, незакрытые оплаты и рисковые связки по контрагентам.\n- НДС 19/68: проверить цепочку документ -> счет-фактура -> регистр -> книга.\n- Закрытие месяца 20/44: проверить распределение затрат и остатки после регламентных операций.\n\nЧто пока не доказано:\n- Запрос не подтвержден в поддерживаемом контуре как надежный бухгалтерский сценарий.\n\nЧто могу сделать сейчас:\n- Взаиморасчеты 60/62 — найти хвосты, незакрытые оплаты и рисковые связки по контрагентам.\n- НДС 19/68 — проверить цепочку документ -> счет-фактура -> регистр -> книга.\n- Закрытие месяца 20/44 — проверить распределение затрат и остатки после регламентных операций.","reply_type":"clarification_required","trace_id":"FxptYyx1YHermm"}} diff --git a/artifacts/runtime_logs/backend_8789_stderr.log b/artifacts/runtime_logs/backend_8789_stderr.log new file mode 100644 index 0000000..3e14693 --- /dev/null +++ b/artifacts/runtime_logs/backend_8789_stderr.log @@ -0,0 +1 @@ +[trace-completeness] trace_id=D5LlglEclPK3wI schema=v1 issues=missing_parsed_normalized_json diff --git a/artifacts/runtime_logs/backend_8789_stdout.log b/artifacts/runtime_logs/backend_8789_stdout.log new file mode 100644 index 0000000..bf74bc4 --- /dev/null +++ b/artifacts/runtime_logs/backend_8789_stdout.log @@ -0,0 +1,22 @@ +{"timestamp":"2026-04-14T07:48:12.071Z","level":"info","service":"llm_normalizer_backend","message":"Backend started on http://localhost:8789"} +{"timestamp":"2026-04-14T07:48:44.439Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-XWUh8NI_mb","eventType":"assistant_message_address","details":{"session_id":"asst-XWUh8NI_mb","message_id":"msg-tUOjRS2WlQ","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"3IMXJKGMTSBEeG","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","limit":20,"as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-mZOrKCvsXn"}} +{"timestamp":"2026-04-14T07:48:50.524Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-XWUh8NI_mb","eventType":"assistant_message_address","details":{"session_id":"asst-XWUh8NI_mb","message_id":"msg-oDWKR4Rq7l","user_message":"Из каких товаров состоит остаток по 41 счету","effective_address_user_message":"Из каких товаров состоит остаток по 41 счету","address_followup_context_applied":true,"address_followup_context_previous_intent":"inventory_on_hand_as_of_date","address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"-UkihzUB6-vGWV","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"из каких товаров состоит остаток по 41 счету","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"continue_previous","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","limit":20,"account":"41","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-pfRkdrbjh6"}} +{"timestamp":"2026-04-14T07:48:56.578Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-XWUh8NI_mb","eventType":"assistant_message_address","details":{"session_id":"asst-XWUh8NI_mb","message_id":"msg-4taLOhOzsG","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31","effective_address_user_message":"Получить список товаров, находящихся на счете 41 на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"Tk9UVAQr4XvPV_","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","limit":20,"account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-X0EkfZU3PL"}} +{"timestamp":"2026-04-14T07:49:02.702Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-XWUh8NI_mb","eventType":"assistant_message_address","details":{"session_id":"asst-XWUh8NI_mb","message_id":"msg-ZpjDqkrGvN","user_message":"Какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","effective_address_user_message":"Получить список номенклатур, формирующих остаток на складе на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"cREF0wVgtRNnxb","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","limit":20,"as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-C9OCMAVeKg"}} +{"timestamp":"2026-04-14T07:49:08.872Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-c7UafaR-7i","eventType":"assistant_message_address","details":{"session_id":"asst-c7UafaR-7i","message_id":"msg-NKjNnXllf-","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"zE8T_31Zyk304K","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","limit":20,"as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-xlBdG9fw_N"}} +{"timestamp":"2026-04-14T07:49:17.026Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-c7UafaR-7i","eventType":"assistant_message_address","details":{"session_id":"asst-c7UafaR-7i","message_id":"msg-V_Nb0kc7B3","user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"Получить информацию о поставщике, от которого был приобретен товар 'Диван трехместный' с текущим остатком на складе 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"TfpBfhwKTExDgn","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"от какого поставщика куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","limit":20,"warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":20,"raw_rows_received":20,"rows_after_account_scope":20,"rows_after_recipe_filter":20,"rows_materialized":20,"rows_matched":20,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 22.06.2020.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 5.\n- Закупочных операций в выборке: 20.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 20.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-05cSkkWKeE"}} +{"timestamp":"2026-04-14T07:49:26.126Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-c7UafaR-7i","eventType":"assistant_message_address","details":{"session_id":"asst-c7UafaR-7i","message_id":"msg-nCwD6xO0Kg","user_message":"У какого поставщика были куплены товары, которые сейчас лежат на складе Основной склад организации ООО \\Альтернатива Плюс\\","effective_address_user_message":"Определить поставщиков, у которых были приобретены товары, находящиеся на складе 'Основной склад' в компании 'ООО Альтернатива Плюс'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"QqERclVcFMqqvu","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"у какого поставщика были куплены товары, которые сейчас лежат на складе основной склад организации ооо \\альтернатива плюс\\","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"missing_anchor","address_retry_result_category":"missing_anchor","address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","limit":20,"warehouse":"Основной склад","counterparty":"ООО Альтернатива Плюс","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"materialized_but_not_matched","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"materialized_but_not_anchor_matched","match_failure_reason":"counterparty_anchor_not_matched_in_materialized_rows","mcp_call_status":"materialized_but_not_anchor_matched","rows_fetched":20,"raw_rows_received":20,"rows_after_account_scope":20,"rows_after_recipe_filter":0,"rows_materialized":20,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":"missing_anchor","response_type":"LIMITED_WITH_REASON","limitations":["counterparty_anchor_not_matched_after_materialization"],"assistant_reply":"Запрос понятен, но для надежного ответа не хватает опорного ориентира.\n\nСмысл запроса понятен, но без уточнения (контрагент, договор, счет или период) риск ошибки слишком высокий.\n\nКонтекст запроса: срез на 2026-04-14.\n\nЧто могу сделать сейчас: показать документы и платежи по контрагенту ООО Альтернатива Плюс; показать незакрытые договоры или хвосты на дату; уточните точное имя контрагента или добавьте ИНН.","reply_type":"partial_coverage","trace_id":"address-J3T4dTgOIX"}} +{"timestamp":"2026-04-14T07:49:33.177Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-c7UafaR-7i","eventType":"assistant_message_address","details":{"session_id":"asst-c7UafaR-7i","message_id":"msg-B6_NkGPSzF","user_message":"По какому поставщику проходит текущий товарный остаток на складе Основной склад","effective_address_user_message":"Получить информацию о поставщике, связанным с текущим товарным остатком на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"WgaAkE7qa0-xIc","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"по какому поставщику проходит текущий товарный остаток на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","limit":20,"warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":20,"raw_rows_received":20,"rows_after_account_scope":20,"rows_after_recipe_filter":20,"rows_materialized":20,"rows_matched":20,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 22.06.2020.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 5.\n- Закупочных операций в выборке: 20.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 20.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-VfwRWm7t2g"}} +{"timestamp":"2026-04-14T07:49:40.295Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-c7UafaR-7i","eventType":"assistant_message_address","details":{"session_id":"asst-c7UafaR-7i","message_id":"msg-0jYsgwcONA","user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"RQfsdy3z3_EFnq","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"когда был куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","limit":20,"item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"materialized_but_not_matched","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"materialized_but_not_anchor_matched","match_failure_reason":"item_anchor_not_matched_in_materialized_rows","mcp_call_status":"materialized_but_not_anchor_matched","rows_fetched":20,"raw_rows_received":20,"rows_after_account_scope":20,"rows_after_recipe_filter":0,"rows_materialized":20,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":"empty_match","response_type":"LIMITED_WITH_REASON","limitations":["no_rows_for_anchor_after_materialization"],"assistant_reply":"По заданным фильтрам в текущем срезе совпадений пока нет.\n\nпо указанному якорю и фильтрам в выборке данных нет строк.\n\nКонтекст запроса: срез на 2026-04-14.\n\nЧто могу сделать сейчас: показать подтвержденные закупочные движения по товару на 41.01 с датами и документами; показать документы/платежи по контрагенту или договору; показать незакрытые договоры или хвосты на дату.","reply_type":"partial_coverage","trace_id":"address-jvQiT_5Nvz"}} +{"timestamp":"2026-04-14T07:49:48.518Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-c7UafaR-7i","eventType":"assistant_message_address","details":{"session_id":"asst-c7UafaR-7i","message_id":"msg-DdyLssCzSZ","user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","effective_address_user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"q5RK5F1Uc1xkO9","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"по каким документам был куплен товар диван трехместный для остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_documents_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_documents_for_item","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_documents_for_item","extracted_filters":{"sort":"period_desc","limit":20,"item":"Диван трехместный для остатка на складе Основной склад","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_documents_for_item_v1","mcp_call_status_legacy":"materialized_but_not_matched","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"materialized_but_not_anchor_matched","match_failure_reason":"item_anchor_not_matched_in_materialized_rows","mcp_call_status":"materialized_but_not_anchor_matched","rows_fetched":20,"raw_rows_received":20,"rows_after_account_scope":20,"rows_after_recipe_filter":0,"rows_materialized":20,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":"empty_match","response_type":"LIMITED_WITH_REASON","limitations":["no_rows_for_anchor_after_materialization"],"assistant_reply":"По заданным фильтрам в текущем срезе совпадений пока нет.\n\nпо указанному якорю и фильтрам в выборке данных нет строк.\n\nСигнал запроса: список документов/операций.\n\nКонтекст запроса: срез на 2026-04-14.\n\nЧто могу сделать сейчас: показать документы поступления по товару на 41.01; показать документы/платежи по контрагенту или договору; показать незакрытые договоры или хвосты на дату.","reply_type":"partial_coverage","trace_id":"address-DBq-m1Bef_"}} +{"timestamp":"2026-04-14T07:49:57.527Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-c7UafaR-7i","eventType":"assistant_message_address","details":{"session_id":"asst-c7UafaR-7i","message_id":"msg-n4FZMwtWPY","user_message":"Какие товары от поставщика Гамма-мебель, ООО сейчас еще лежат на складе Основной склад","effective_address_user_message":"Получить информацию о товарах от поставщика 'Гамма-мебель, ООО', которые находятся на складе 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"dngX7mmdSsAZ5j","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары от поставщика гамма-мебель, ооо сейчас еще лежат на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"missing_anchor","address_retry_result_category":"missing_anchor","address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","limit":20,"warehouse":"Основной склад","counterparty":"Гамма-мебель","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"materialized_but_not_matched","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"materialized_but_not_anchor_matched","match_failure_reason":"counterparty_anchor_not_matched_in_materialized_rows","mcp_call_status":"materialized_but_not_anchor_matched","rows_fetched":20,"raw_rows_received":20,"rows_after_account_scope":20,"rows_after_recipe_filter":0,"rows_materialized":20,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":"missing_anchor","response_type":"LIMITED_WITH_REASON","limitations":["counterparty_anchor_not_matched_after_materialization"],"assistant_reply":"Чтобы ответ был точным, нужно чуть сильнее заякорить запрос.\n\nДля точного ответа нужен хотя бы один явный ориентир: контрагент, договор, счет или период.\n\nКонтекст запроса: срез на 2026-04-14.\n\nЧто могу сделать сейчас: показать документы и платежи по контрагенту Гамма-мебель; показать незакрытые договоры или хвосты на дату; уточните точное имя контрагента или добавьте ИНН.","reply_type":"partial_coverage","trace_id":"address-sef9OdPHd-"}} +{"timestamp":"2026-04-14T07:50:05.736Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-c7UafaR-7i","eventType":"assistant_message_address","details":{"session_id":"asst-c7UafaR-7i","message_id":"msg-ZrDjYKZWgH","user_message":"Какие товары по состоянию на дату 2020-03-31 на складе Основной склад были куплены у поставщика Гамма-мебель, ООО","effective_address_user_message":"Список товаров на складе 'Основной склад' по состоянию на 2020-03-31, приобретенных у поставщика 'Гамма-мебель, ООО'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"SvgXflFPcI7qbN","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары по состоянию на дату 2020-03-31 на складе основной склад были куплены у поставщика гамма-мебель, ооо","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","limit":20,"warehouse":"Основной склад","counterparty":"Гамма-мебель","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":20,"raw_rows_received":20,"rows_after_account_scope":20,"rows_after_recipe_filter":12,"rows_materialized":20,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 31.03.2020.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 01.10.2019.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 3.\n- Закупочных операций в выборке: 12.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 12.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n3. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n4. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 28.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n5. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 199.671,66 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n6. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 159.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n7. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 23.660,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 62.150,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n9. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 16.880,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n10. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 75.075,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-nxhEfgejlo"}} +{"timestamp":"2026-04-14T07:50:12.113Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-_1pY2Yvkbe","eventType":"assistant_message_address","details":{"session_id":"asst-_1pY2Yvkbe","message_id":"msg-GFglRaI-Bg","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"EZ7HSSyUuOCArw","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","limit":20,"as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-08_24QdCEE"}} +{"timestamp":"2026-04-14T07:50:19.129Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-_1pY2Yvkbe","eventType":"assistant_message_address","details":{"session_id":"asst-_1pY2Yvkbe","message_id":"msg-SoBTUZdUEm","user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","effective_address_user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"R2IqfSj_vb04W6","address_llm_predecompose_reason":"normalized_fragment_rejected_semantic_guard","address_fallback_rule_hit":null,"address_sanitized_user_message":"относится ли товар шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_aging_by_purchase_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_aging_by_purchase_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_aging_by_purchase_date","extracted_filters":{"sort":"period_desc","limit":20,"item":"Шкаф картотечный 1000*400*2100","as_of_date":"2020-03-31"},"selected_recipe":null,"mcp_call_status_legacy":"skipped","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":null,"resolver_confidence":null,"match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"skipped","rows_fetched":0,"raw_rows_received":0,"rows_after_account_scope":0,"rows_after_recipe_filter":0,"rows_materialized":0,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"DEEP_ONLY","limited_reason_category":"unsupported","response_type":"LIMITED_WITH_REASON","limitations":["capability_route_disabled_by_flag"],"assistant_reply":"Сейчас не дам прямой адресный ответ, чтобы не ошибиться в выводах.\n\nДля этого запроса пока нет надежного ответа в текущем адресном режиме.\n\nКонтекст запроса: срез на 2020-03-31.","reply_type":"partial_coverage","trace_id":"address-r4AtVQiE8q"}} +{"timestamp":"2026-04-14T07:50:27.102Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-_1pY2Yvkbe","eventType":"assistant_message_address","details":{"session_id":"asst-_1pY2Yvkbe","message_id":"msg-_dKQk8pG42","user_message":"Есть ли на складе Основной склад товары с остатком без понятной привязки к поставщику","effective_address_user_message":"Проверить наличие товаров на Основном складе с остатками, у которых нет ясной привязки к поставщику.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"hA7z2le2EZGX7u","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли на складе основной склад товары с остатком без понятной привязки к поставщику","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract","deep_investigation_signal_detected"],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","limit":20,"as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":20,"raw_rows_received":20,"rows_after_account_scope":20,"rows_after_recipe_filter":20,"rows_materialized":20,"rows_matched":20,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 22.06.2020.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 5.\n- Закупочных операций в выборке: 20.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 20.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-kSPeUVweTe"}} +{"timestamp":"2026-04-14T07:50:34.462Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-_1pY2Yvkbe","eventType":"assistant_message_address","details":{"session_id":"asst-_1pY2Yvkbe","message_id":"msg--i8QmiwxrT","user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","effective_address_user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"4GrQJ_hSnpDgsr","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли среди текущих остатков на складе основной склад позиции, закупленные задолго до 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","limit":20,"as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-hfBi_32Zms"}} +{"timestamp":"2026-04-14T07:50:41.568Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-na4raXo9eh","eventType":"assistant_message_address","details":{"session_id":"asst-na4raXo9eh","message_id":"msg-1IwfHJCtT9","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31 на складе Основной склад","effective_address_user_message":"Получить список товаров, находящихся на 41 счете по состоянию на 2020-03-31 для склада 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"DowGQdOGI2XYAj","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31 на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","limit":20,"account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-5v75QJS1gX"}} +{"timestamp":"2026-04-14T07:50:49.495Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-na4raXo9eh","eventType":"assistant_message_address","details":{"session_id":"asst-na4raXo9eh","message_id":"msg-MYP36M1dSt","user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","effective_address_user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"62ukBwpKH1vsLG","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"кому был продан товар шкаф картотечный 1000*400*2100","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_sale_trace_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_sale_trace_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_sale_trace_for_item","extracted_filters":{"sort":"period_desc","limit":20,"item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_sale_trace_for_item_v1","mcp_call_status_legacy":"materialized_but_not_matched","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"materialized_but_not_anchor_matched","match_failure_reason":"item_anchor_not_matched_in_materialized_rows","mcp_call_status":"materialized_but_not_anchor_matched","rows_fetched":20,"raw_rows_received":20,"rows_after_account_scope":20,"rows_after_recipe_filter":0,"rows_materialized":20,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":"empty_match","response_type":"LIMITED_WITH_REASON","limitations":["no_rows_for_anchor_after_materialization"],"assistant_reply":"По заданным фильтрам в текущем срезе совпадений пока нет.\n\nпо указанному якорю и фильтрам в выборке данных нет строк.\n\nКонтекст запроса: срез на 2026-04-14.\n\nЧто могу сделать сейчас: показать подтвержденные движения выбытия товара со счета 41.01; показать документы/платежи по контрагенту или договору; показать незакрытые договоры или хвосты на дату.","reply_type":"partial_coverage","trace_id":"address-JroBSBRf_Q"}} +{"timestamp":"2026-04-14T07:50:58.642Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-na4raXo9eh","eventType":"assistant_message_address","details":{"session_id":"asst-na4raXo9eh","message_id":"msg-PIj62tF5aY","user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","effective_address_user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"-tVddfedFXkKel","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"через какие документы прошел путь товара шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_to_sale_chain","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_to_sale_chain","extracted_filters":{"sort":"period_desc","limit":20,"item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_to_sale_chain_v1","mcp_call_status_legacy":"materialized_but_not_matched","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"materialized_but_not_anchor_matched","match_failure_reason":"item_anchor_not_matched_in_materialized_rows","mcp_call_status":"materialized_but_not_anchor_matched","rows_fetched":20,"raw_rows_received":20,"rows_after_account_scope":20,"rows_after_recipe_filter":0,"rows_materialized":20,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":"empty_match","response_type":"LIMITED_WITH_REASON","limitations":["no_rows_for_anchor_after_materialization"],"assistant_reply":"По заданным фильтрам в текущем срезе совпадений пока нет.\n\nпо указанному якорю и фильтрам в выборке данных нет строк.\n\nСигнал запроса: список документов/операций.\n\nКонтекст запроса: срез на 2026-04-14.\n\nЧто могу сделать сейчас: показать документальную цепочку по товару: поступление на 41.01 и последующее выбытие; показать документы/платежи по контрагенту или договору; показать незакрытые договоры или хвосты на дату.","reply_type":"partial_coverage","trace_id":"address-mz69a_xShG"}} +{"timestamp":"2026-04-14T07:51:08.572Z","level":"info","service":"assistant_loop","message":"assistant_address_tool_gate_skip","sessionId":"asst-na4raXo9eh","details":{"session_id":"asst-na4raXo9eh","user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","effective_address_user_message":"Проверить наличие документально подтвержденной цепочки: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотечный 1000*400*2100 -> покупатель департамент капитального ремонта города москвы","assistant_orchestration_contract_v1":{"schema_version":"assistant_orchestration_contract_v1","hard_meta_mode":null,"address_mode":"deep_analysis","address_mode_confidence":"high","address_intent":"inventory_purchase_to_sale_chain","address_intent_confidence":"medium","strong_data_signal_detected":true,"data_retrieval_signal_detected":true,"semantic_contract_valid":true,"semantic_apply_canonical_recommended":true,"semantic_reason_codes":["deep_investigation_signal_detected"],"semantic_route_arbitration":{"supported_address_intent_detected":false,"semantic_deep_investigation_hint_detected":true,"semantic_aggregate_shape_detected":false,"followup_semantic_override_to_deep_allowed":false},"followup_context_detected":false,"unsupported_address_intent_fallback_to_deep":false,"deep_analysis_signal_fallback_to_deep":true,"aggregate_analytics_signal_fallback_to_deep":false,"deep_session_continuation_fallback_to_deep":false,"final_decision":{"run_address_lane":false,"tool_gate_decision":"skip_address_lane","tool_gate_reason":"deep_analysis_signal_fallback_to_deep","living_mode":"deep_analysis","living_reason":"deep_analysis_signal_fallback_to_deep"}},"address_tool_gate_decision":"skip_address_lane","address_tool_gate_reason":"deep_analysis_signal_fallback_to_deep","address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["deep_investigation_signal_detected"]}} +{"timestamp":"2026-04-14T07:51:28.670Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-na4raXo9eh","eventType":"assistant_message","details":{"session_id":"asst-na4raXo9eh","message_id":"msg-w5e8xcHO90","user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","normalizer_output":null,"execution_plan":[],"resolved_execution_state":[],"routes":[],"retrieval_calls":[],"retrieval_results_raw":[],"retrieval_results_normalized":[],"requirements_extracted":[{"requirement_id":"R1","source_fragment_id":null,"requirement_text":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","subject_tokens":["counterparty","document","chain"],"status":"clarification_needed","route":null}],"requirements_total":1,"requirements_covered":0,"requirements_uncovered":[],"coverage_status":"partial_or_limited","answer_grounding_status":"no_grounded_answer","reply_semantic_type":"clarification_required","why_included_summary":[],"selection_reason_summary":[],"route_subject_match":true,"clarification_target":["R1"],"dropped_intent_segments":[],"question_type_class":"unknown","company_anchors":{"contract_numbers":[],"document_numbers":[],"dates":[],"amounts":[],"accounts":[],"periods":[],"document_types":[],"all":[]},"analysis_context_applied":true,"analysis_context":{"as_of_date":"2026-04-13","period_from":null,"period_to":null,"source":"scenario_pack","snapshot_mode":"auto"},"business_scope_raw":[],"business_scope_resolved":["company_specific_accounting"],"company_grounding_applied":true,"scope_resolution_reason":["settlement_claim_company_scope_recovery"],"company_scope_resolution_reason":["settlement_claim_company_scope_recovery"],"raw_time_anchor":"2026-04-13","raw_time_scope":"2026-04-13..2026-04-13","resolved_time_anchor":"2026-04-13","resolved_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"effective_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"temporal_guard_input":"2026-04-13..2026-04-13","temporal_alignment_status":"aligned","temporal_resolution_source":"scenario_pack","temporal_guard_basis":"raw_time_scope_unlocked","temporal_guard_applied":false,"temporal_guard_outcome":"passed","temporal_guard":{"raw_time_anchor":"2026-04-13","raw_time_scope":"2026-04-13..2026-04-13","resolved_time_anchor":"2026-04-13","resolved_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"effective_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"temporal_guard_input":"2026-04-13..2026-04-13","temporal_alignment_status":"aligned","temporal_resolution_source":"scenario_pack","temporal_guard_basis":"raw_time_scope_unlocked","temporal_guard_applied":false,"temporal_guard_outcome":"passed","primary_period_window":null,"allowed_context_window":null,"controlled_temporal_expansion_enabled":false,"context_expansion_reasons_allowed":["prehistory","carryover","post_period_closure","long_running_contract_context"],"normalized_anchor_drift_detected":false,"reason_codes":["analysis_context_applied"]},"raw_numeric_tokens":["1000","400","2100"],"classified_numeric_tokens":[],"rejected_as_non_accounts":[],"resolved_account_anchors":[],"domain_polarity_guard":{"applied":true,"polarity":"mixed_or_unresolved","outcome":"limited_unresolved_polarity","supplier_score":2,"customer_score":2,"account_scope":[],"raw_numeric_tokens":["1000","400","2100"],"classified_numeric_tokens":[],"rejected_as_non_accounts":[],"resolved_account_anchors":[],"rejected_problem_units":0,"rejected_evidence":0,"critical_contradiction":true,"reason_codes":["unresolved_supplier_customer_polarity","supplier_customer_signals_conflict"]},"claim_anchor_audit":{"claim_type":"prove_settlement_closure_state","settlement_role":"mixed","settlement_role_resolution_reason":["settlement_role_resolved_mixed"],"polarity_resolution_status":"mixed","required_anchors":["period","account_scope","counterparty_scope_or_contract","closure_signal"],"resolved_anchors":{"period":["2026-04-13"],"account_scope":[],"amounts":[],"contract":[],"document_numbers":[],"document_types":[],"counterparty_scope":["supplier","customer"],"advance_signal":[],"closure_signal":[],"vat_signal":[],"chain_signal":[],"close_signal":[],"cost_scope":[],"rbp_signal":[],"writeoff_signal":[],"fixed_asset_signal":[],"amortization_signal":[],"expected_fa_set":[],"actual_fa_set":[]},"missing_anchors":["account_scope","closure_signal"],"claim_anchor_resolution_rate":0.5,"primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"allowed_context_window":{"from":"2025-04-13","to":"2027-04-13","granularity":"month"},"context_expansion_reasons_allowed":["prehistory","carryover","post_period_closure","long_running_contract_context"],"reason_codes":["claim_missing_required_anchors","claim_anchor_resolution_low","unresolved_supplier_customer_polarity"]},"settlement_role":"mixed","settlement_role_resolution_reason":["settlement_role_resolved_mixed"],"polarity_resolution_status":"mixed","targeted_evidence_acquisition":{"claim_type":"prove_settlement_closure_state","required_checks":["payment_document_found","contract_matched","settlement_object_matched","closing_document_found","register_closure_entry_found","posting_link_found"],"check_status":{"payment_document_found":"not_found","contract_matched":"not_found","settlement_object_matched":"not_found","closing_document_found":"not_found","register_closure_entry_found":"not_found","posting_link_found":"not_found"},"targeted_item_hits":0,"targeted_evidence_hits":0,"targeted_evidence_hit_rate":0,"targeted_evidence_source_refs":[],"reason_codes":["targeted_evidence_not_found","targeted_evidence_hit_rate_low"]},"evidence_admissibility_gate":{"candidate_evidence_total":0,"admissible_evidence_count":0,"rejected_evidence_count":0,"rejected_item_count":0,"reject_breakdown":{"wrong_period":0,"wrong_domain":0,"wrong_account_scope":0,"weak_source_mapping":0,"zero_live_match":0,"future_dated_or_out_of_window":0},"category_breakdown":{"hard_evidence":0,"supporting_signal":0,"inadmissible_noise":0},"reason_codes":["no_admissible_evidence_for_grounded_answer"]},"eligibility_time_basis":"raw_time_scope_unlocked","grounded_answer_eligibility_guard":{"eligible":false,"temporal_passed":true,"eligibility_time_basis":"raw_time_scope_unlocked","business_scope_passed":true,"polarity_passed":false,"claim_anchors_passed":true,"claim_anchor_resolution_rate":0.5,"missing_required_anchors":2,"admissible_evidence_count":0,"critical_contradiction":true,"outcome":"limited_or_insufficient_evidence","grounding_mode":"limited_or_insufficient_evidence","reason_codes":["polarity_guard_limited_unresolved_polarity","admissible_evidence_count_zero","targeted_evidence_hit_rate_zero","critical_domain_or_account_contradiction"]},"problem_centric_answer_applied":false,"problem_units_used_count":0,"problem_answer_mode":"stage1_policy_v11","assistant_outcome_class_v1":"BLOCKED_BY_AMBIGUITY","assistant_orchestration_contracts_v1":{"query_frame":{"schema_version":"assistant_query_frame_v1","original_user_question":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","normalized_question":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","route_summary_mode":"none","fragments_total":0,"dropped_intent_segments":[],"analysis_context":{"as_of_date":"2026-04-13","period_from":null,"period_to":null,"source":"scenario_pack","snapshot_mode":"auto"}},"execution_plan":{"schema_version":"assistant_execution_plan_v1","steps":[],"requirements_total":1},"evidence_bundle":{"schema_version":"assistant_evidence_bundle_v1","retrieval_calls_total":0,"retrieval_results_total":0,"retrieval_status_breakdown":{"ok":0,"partial":0,"empty":0,"error":0},"evidence_total":0,"source_refs_total":0,"limitation_total":0,"error_total":0},"coverage":{"schema_version":"assistant_coverage_contract_v1","coverage_report":{"requirements_total":1,"requirements_covered":0,"requirements_uncovered":[],"requirements_partially_covered":[],"clarification_needed_for":["R1"],"out_of_scope_requirements":[]},"grounding":{"status":"no_grounded_answer","route_subject_match":true,"missing_requirements":["R1"],"reasons":["Ни одно требование не получило подтвержденного покрытия.","В текущей выборке не хватает явных подтверждений, почему записи попали в ответ.","Часть контекста вопроса не подтверждена напрямую в найденных данных: counterparty, document, chain","Не удалось однозначно определить сторону расчета (нам должны или мы должны).","Недостаточно подтвержденных данных для уверенного ответа.","Не хватило целевых подтверждений по выбранному сценарию.","Есть противоречие по выбранному домену или контуру счета."],"why_included_summary":[],"selection_reason_summary":[]},"outcome_class":"BLOCKED_BY_AMBIGUITY"}},"answer_contract_stage4_v1":{"schema_version":"stage4_answer_contract_audit_v1","stage4_blocks_expected":["Коротко","Что именно проверено","Что найдено","Что пока не доказано","Что проверить первым/Что могу сделать сейчас"],"stage4_blocks_present":["Коротко","Что именно проверено","Что найдено","Что пока не доказано","Что проверить первым/Что могу сделать сейчас"],"stage4_blocks_missing":[],"legacy_blocks_present":[],"is_stage4_shape":true},"answer_structure_v11":{"schema_version":"answer_structure_v1_1","answer_summary":"Нужны уточнения: без сужения фокуса надежный вывод невозможен.","direct_answer":"Есть признаки проблемы, но без уточнений по периоду и объекту вывод ненадежен.","mechanism_block":{"status":"unresolved","mechanism_notes":[],"limitation_reason_codes":[]},"evidence_block":{"evidence_ids":[],"source_refs":[],"mechanism_notes":[],"coverage_note":"coverage_partial_or_limited"},"uncertainty_block":{"open_uncertainties":["R1","missing_anchor:period","missing_anchor:account","missing_anchor:counterparty"],"limitations":["Ни одно требование не получило подтвержденного покрытия.","В текущей выборке не хватает явных подтверждений, почему записи попали в ответ.","Часть контекста вопроса не подтверждена напрямую в найденных данных: counterparty, document, chain","Не удалось однозначно определить сторону расчета (нам должны или мы должны).","Недостаточно подтвержденных данных для уверенного ответа.","Не хватило целевых подтверждений по выбранному сценарию.","Есть противоречие по выбранному домену или контуру счета."]},"next_step_block":{"recommended_actions":["Дайте недостающие якоря (период/счет/объект), иначе сильный factual вывод невозможен."],"clarification_questions":["Уточните период проверки (например, июль 2020).","Уточните счет или группу счетов (например, 19, 60, 62).","Укажите контрагента или группу контрагентов.","Закройте уточнения для требований: R1."]}},"investigation_state_snapshot":{"schema_version":"investigation_state_v1","session_id":"asst-na4raXo9eh","status":"active","turn_index":1,"updated_at":"2026-04-14T07:51:28.666Z","question_id":"msg-CGKLlH8ZYm","question_scope_id":"d:settlements_60_62|s:есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотеч","scope_origin":"explicit_from_message","focus":{"domain":"settlements_60_62","period":null,"primary_accounts":[],"active_query_subject":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы"},"narrowing_status":"unknown","evidence_refs":[],"open_uncertainties":["clarify:R1"],"last_answer_mode":"clarification_required","followup_context":{"previous_question_id":null,"last_user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","referenced_requirement_ids":["R1"],"active_domain":"settlements_60_62","active_requirement_ids":["R1"],"uncovered_requirement_ids":["R1"],"last_problem_unit_id":null,"settlement_next_actions":["Проверьте договор и объект расчетов по платежу.","Сверьте регистр расчетов и привязку платежа к закрывающему документу.","Проверьте зачет аванса или взаимозачет по связке 60/62."],"evidence_summary":[],"question_scope_id":"d:settlements_60_62|s:есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотеч","scope_origin":"explicit_from_message"},"query_mode_hint":"investigation_candidate"},"fallback_type":"clarification","assistant_reply":"Коротко: По этому запросу у меня нет надежного доменного покрытия, поэтому даю мягкий отказ вместо технического шаблона.\n\nЧто именно проверено:\n- Проверен доступный контур 1С и возможность маршрутизации запроса.\n- Надежный доменный путь для текущей формулировки не подтвержден.\n\nЧто найдено:\n- Взаиморасчеты 60/62: найти хвосты, незакрытые оплаты и рисковые связки по контрагентам.\n- НДС 19/68: проверить цепочку документ -> счет-фактура -> регистр -> книга.\n- Закрытие месяца 20/44: проверить распределение затрат и остатки после регламентных операций.\n\nЧто пока не доказано:\n- Запрос не подтвержден в поддерживаемом контуре как надежный бухгалтерский сценарий.\n\nЧто могу сделать сейчас:\n- Взаиморасчеты 60/62 — найти хвосты, незакрытые оплаты и рисковые связки по контрагентам.\n- НДС 19/68 — проверить цепочку документ -> счет-фактура -> регистр -> книга.\n- Закрытие месяца 20/44 — проверить распределение затрат и остатки после регламентных операций.","reply_type":"clarification_required","trace_id":"D5LlglEclPK3wI"}} diff --git a/artifacts/runtime_logs/backend_8790_stderr.log b/artifacts/runtime_logs/backend_8790_stderr.log new file mode 100644 index 0000000..0dd98bf --- /dev/null +++ b/artifacts/runtime_logs/backend_8790_stderr.log @@ -0,0 +1,8 @@ +[trace-completeness] trace_id=VDxca2tLAKyVJo schema=v1 issues=missing_parsed_normalized_json +[trace-completeness] trace_id=-nB07p30ipnMC9 schema=v1 issues=missing_parsed_normalized_json +[trace-completeness] trace_id=xyJUh372ge9qh1 schema=v1 issues=missing_parsed_normalized_json +[trace-completeness] trace_id=diT7xjvfkD7An2 schema=v1 issues=missing_parsed_normalized_json +[trace-completeness] trace_id=fV-syC1Uct-PMK schema=v1 issues=missing_parsed_normalized_json +[trace-completeness] trace_id=gNDDzj4rdhRaKA schema=v1 issues=missing_parsed_normalized_json +[trace-completeness] trace_id=-Tg-6Lsx4z0nIT schema=v1 issues=missing_parsed_normalized_json +[trace-completeness] trace_id=MJPJ-rKxWt7poz schema=v1 issues=missing_parsed_normalized_json diff --git a/artifacts/runtime_logs/backend_8790_stdout.log b/artifacts/runtime_logs/backend_8790_stdout.log new file mode 100644 index 0000000..ee560cf --- /dev/null +++ b/artifacts/runtime_logs/backend_8790_stdout.log @@ -0,0 +1,169 @@ +{"timestamp":"2026-04-14T08:15:00.371Z","level":"info","service":"llm_normalizer_backend","message":"Backend started on http://localhost:8790"} +{"timestamp":"2026-04-14T08:16:05.788Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-KzqTEOs82a","eventType":"assistant_message_address","details":{"session_id":"asst-KzqTEOs82a","message_id":"msg-McTXc5MavB","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"trs6kh7NVd-gUL","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-5uFZLOz4Ck"}} +{"timestamp":"2026-04-14T08:16:11.899Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-KzqTEOs82a","eventType":"assistant_message_address","details":{"session_id":"asst-KzqTEOs82a","message_id":"msg-TNvHVpW2I5","user_message":"Из каких товаров состоит остаток по 41 счету","effective_address_user_message":"Какие товары составляют остаток на счете 41","address_followup_context_applied":true,"address_followup_context_previous_intent":"inventory_on_hand_as_of_date","address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"viPN4OgksofiPH","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"из каких товаров состоит остаток по 41 счету","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"continue_previous","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-T8W4uzvLZo"}} +{"timestamp":"2026-04-14T08:16:17.953Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-KzqTEOs82a","eventType":"assistant_message_address","details":{"session_id":"asst-KzqTEOs82a","message_id":"msg-bULLalA_mS","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31","effective_address_user_message":"Получить список товаров, находящихся на счете 41 на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"IcduRSoKlW5ALQ","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-90-Vi48V_a"}} +{"timestamp":"2026-04-14T08:16:24.051Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-KzqTEOs82a","eventType":"assistant_message_address","details":{"session_id":"asst-KzqTEOs82a","message_id":"msg-Rg-X4y66q2","user_message":"Какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","effective_address_user_message":"Получить список номенклатур, формирующих остаток на складе на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"VhuwxFLabYcL6t","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-eaLu2RQ_a2"}} +{"timestamp":"2026-04-14T08:16:30.148Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Ofr6JgVSSq","eventType":"assistant_message_address","details":{"session_id":"asst-Ofr6JgVSSq","message_id":"msg-63GiBDU9B-","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"-MmxjD3adWRBUX","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-ncYKyLIjbL"}} +{"timestamp":"2026-04-14T08:16:38.082Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Ofr6JgVSSq","eventType":"assistant_message_address","details":{"session_id":"asst-Ofr6JgVSSq","message_id":"msg-QmBI3UhXnX","user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"FzdiHPJn8XtLya","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"от какого поставщика куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный закупочный след по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные закупочные движения на 41.01 по выбранному товару.\n- Важно: без партионности этот контур не подменяет собой лот-level доказательство происхождения текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 24.08.2018.\n- Последняя найденная дата закупочного движения: 24.08.2018.\n- Документов поступления: 1.\n- Операций поступления: 1.\n- Закупочные документы найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Опорные документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-4wC13OvMb-"}} +{"timestamp":"2026-04-14T08:16:46.192Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Ofr6JgVSSq","eventType":"assistant_message_address","details":{"session_id":"asst-Ofr6JgVSSq","message_id":"msg-NxUFJniub1","user_message":"У какого поставщика были куплены товары, которые сейчас лежат на складе Основной склад организации ООО \\Альтернатива Плюс\\","effective_address_user_message":"Определить поставщиков, у которых были приобретены товары, находящиеся на складе 'Основной склад' в компании 'ООО Альтернатива Плюс'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"0b-N5_c0vISuhj","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"у какого поставщика были куплены товары, которые сейчас лежат на складе основной склад организации ооо \\альтернатива плюс\\","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-NwSniIUdi0"}} +{"timestamp":"2026-04-14T08:16:53.364Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Ofr6JgVSSq","eventType":"assistant_message_address","details":{"session_id":"asst-Ofr6JgVSSq","message_id":"msg-ytlkROb1R6","user_message":"По какому поставщику проходит текущий товарный остаток на складе Основной склад","effective_address_user_message":"Получить информацию о поставщике, связанным с текущим товарным остатком на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"QExgYhFZxIt0aw","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"по какому поставщику проходит текущий товарный остаток на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-6rHrookP_a"}} +{"timestamp":"2026-04-14T08:17:00.382Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Ofr6JgVSSq","eventType":"assistant_message_address","details":{"session_id":"asst-Ofr6JgVSSq","message_id":"msg-QZerlnItQX","user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"6M_Q-resw3b8mY","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"когда был куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный закупочный след по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные закупочные движения на 41.01 по выбранному товару.\n- Важно: без партионности этот контур не подменяет собой лот-level доказательство происхождения текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 24.08.2018.\n- Последняя найденная дата закупочного движения: 24.08.2018.\n- Документов поступления: 1.\n- Операций поступления: 1.\n- Закупочные документы найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Опорные документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-F7S2nshKva"}} +{"timestamp":"2026-04-14T08:17:07.606Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Ofr6JgVSSq","eventType":"assistant_message_address","details":{"session_id":"asst-Ofr6JgVSSq","message_id":"msg-VZi6-z2IbC","user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","effective_address_user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"8WsPWF-Ledt_FC","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"по каким документам был куплен товар диван трехместный для остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_documents_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_documents_for_item","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_documents_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный для остатка на складе Основной склад","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_documents_for_item_v1","mcp_call_status_legacy":"materialized_but_not_matched","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"materialized_but_not_anchor_matched","match_failure_reason":"item_anchor_not_matched_in_materialized_rows","mcp_call_status":"materialized_but_not_anchor_matched","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":0,"rows_materialized":400,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":"empty_match","response_type":"LIMITED_WITH_REASON","limitations":["no_rows_for_anchor_after_materialization"],"assistant_reply":"По заданным фильтрам в текущем срезе совпадений пока нет.\n\nпо указанному якорю и фильтрам в выборке данных нет строк.\n\nСигнал запроса: список документов/операций.\n\nКонтекст запроса: срез на 2026-04-14.\n\nЧто могу сделать сейчас: показать документы поступления по товару на 41.01; показать документы/платежи по контрагенту или договору; показать незакрытые договоры или хвосты на дату.","reply_type":"partial_coverage","trace_id":"address-TJBkBo-9dM"}} +{"timestamp":"2026-04-14T08:17:15.773Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Ofr6JgVSSq","eventType":"assistant_message_address","details":{"session_id":"asst-Ofr6JgVSSq","message_id":"msg-8hOIRVw5D-","user_message":"Какие товары от поставщика Гамма-мебель, ООО сейчас еще лежат на складе Основной склад","effective_address_user_message":"Получить информацию о товарах от поставщика 'Гамма-мебель, ООО', которые находятся на складе 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"g-_Q0Unv6v7rb1","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары от поставщика гамма-мебель, ооо сейчас еще лежат на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","counterparty":"Гамма-мебель, ООО',","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":41,"rows_materialized":500,"rows_matched":41,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 13.05.2019.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 11.\n- Закупочных операций в выборке: 41.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 41.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n3. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n4. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 28.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n5. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 199.671,66 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n6. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 62.150,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n7. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 16.880,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 159.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n9. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 23.660,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n10. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 75.075,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-iWPXCgMXaX"}} +{"timestamp":"2026-04-14T08:17:23.931Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Ofr6JgVSSq","eventType":"assistant_message_address","details":{"session_id":"asst-Ofr6JgVSSq","message_id":"msg-CDQjPxFm5z","user_message":"Какие товары по состоянию на дату 2020-03-31 на складе Основной склад были куплены у поставщика Гамма-мебель, ООО","effective_address_user_message":"Получить список товаров на складе 'Основной склад' по состоянию на 2020-03-31, приобретенных у поставщика 'Гамма-мебель, ООО'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"VhU2bIy7VkF1ZC","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары по состоянию на дату 2020-03-31 на складе основной склад были куплены у поставщика гамма-мебель, ооо","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","counterparty":"Гамма-мебель, ООО","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":41,"rows_materialized":500,"rows_matched":41,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 31.03.2020.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 13.05.2019.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 11.\n- Закупочных операций в выборке: 41.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 41.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n3. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n4. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 28.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n5. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 199.671,66 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n6. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 159.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n7. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 23.660,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 62.150,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n9. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 16.880,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n10. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 75.075,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-kojzGqtes3"}} +{"timestamp":"2026-04-14T08:17:30.090Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-YOWbk2kDXx","eventType":"assistant_message_address","details":{"session_id":"asst-YOWbk2kDXx","message_id":"msg-mpI35yEca_","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"4UHPRnxjOjmR7J","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-ofeC_L9AnV"}} +{"timestamp":"2026-04-14T08:17:36.864Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-YOWbk2kDXx","eventType":"assistant_message_address","details":{"session_id":"asst-YOWbk2kDXx","message_id":"msg-OkQ7ADECyL","user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","effective_address_user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"1RPzZ-S2sJkHp8","address_llm_predecompose_reason":"normalized_fragment_rejected_semantic_guard","address_fallback_rule_hit":null,"address_sanitized_user_message":"относится ли товар шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_aging_by_purchase_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_aging_by_purchase_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_aging_by_purchase_date","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2020-03-31"},"selected_recipe":null,"mcp_call_status_legacy":"skipped","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":null,"resolver_confidence":null,"match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"skipped","rows_fetched":0,"raw_rows_received":0,"rows_after_account_scope":0,"rows_after_recipe_filter":0,"rows_materialized":0,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"DEEP_ONLY","limited_reason_category":"unsupported","response_type":"LIMITED_WITH_REASON","limitations":["capability_route_disabled_by_flag"],"assistant_reply":"Сейчас не дам прямой адресный ответ, чтобы не ошибиться в выводах.\n\nДля этого запроса пока нет надежного ответа в текущем адресном режиме.\n\nКонтекст запроса: срез на 2020-03-31.","reply_type":"partial_coverage","trace_id":"address-R_2Od2nt7H"}} +{"timestamp":"2026-04-14T08:17:45.101Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-YOWbk2kDXx","eventType":"assistant_message_address","details":{"session_id":"asst-YOWbk2kDXx","message_id":"msg-_0KtO63gsi","user_message":"Есть ли на складе Основной склад товары с остатком без понятной привязки к поставщику","effective_address_user_message":"Есть ли на складе Основной склад товары с остатком без понятной привязки к поставщику","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"T4hhex5TpmQB5Q","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли на складе основной склад товары с остатком без понятной привязки к поставщику","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract","deep_investigation_signal_detected"],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад товары","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":487,"rows_materialized":500,"rows_matched":487,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 90.\n- Закупочных операций в выборке: 487.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 464.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-yMsU3gcxWT"}} +{"timestamp":"2026-04-14T08:17:52.469Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-YOWbk2kDXx","eventType":"assistant_message_address","details":{"session_id":"asst-YOWbk2kDXx","message_id":"msg-BPSoIkCcGa","user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","effective_address_user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"nVf9Tnaw3nkzbX","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли среди текущих остатков на складе основной склад позиции, закупленные задолго до 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-TL006zkBb9"}} +{"timestamp":"2026-04-14T08:17:58.575Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-BExvZaGtx4","eventType":"assistant_message_address","details":{"session_id":"asst-BExvZaGtx4","message_id":"msg-N-QCblvUEi","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31 на складе Основной склад","effective_address_user_message":"Получить список товаров, находящихся на счете 41 на дату 2020-03-31 для склада 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"J90xDZRD8Zo8tK","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31 на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-JH7ws5--FZ"}} +{"timestamp":"2026-04-14T08:18:05.511Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-BExvZaGtx4","eventType":"assistant_message_address","details":{"session_id":"asst-BExvZaGtx4","message_id":"msg-dsQnR5O_It","user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","effective_address_user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"Y9l0ZZ6oZ068gd","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"кому был продан товар шкаф картотечный 1000*400*2100","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_sale_trace_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_sale_trace_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_sale_trace_for_item","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_sale_trace_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный след выбытия по товару товар до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные движения выбытия товара со счета 41.01.\n\nБлок 2. Сводка\n- Первая найденная дата выбытия: 01.04.2020.\n- Последняя найденная дата выбытия: 01.04.2020.\n- Документов выбытия: 1.\n- Операций выбытия: 1.\n- Документы выбытия найдены, но покупатель не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Документы выбытия\n1. Реализация товаров и услуг 00000000001 от 01.04.2020 0:00:00 | дата: 01.04.2020 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-l9I6z7yTDu"}} +{"timestamp":"2026-04-14T08:18:14.730Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-BExvZaGtx4","eventType":"assistant_message_address","details":{"session_id":"asst-BExvZaGtx4","message_id":"msg-MyT9ecO8b8","user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","effective_address_user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"GHFrIFFXX72VZk","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"через какие документы прошел путь товара шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_to_sale_chain","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_to_sale_chain","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_to_sale_chain_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":600,"raw_rows_received":600,"rows_after_account_scope":600,"rows_after_recipe_filter":2,"rows_materialized":600,"rows_matched":2,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собрана документальная цепочка по товару Шкаф картотечный 1000*400*2100 до 14.04.2026.\n\nБлок 1. Статус результата\n- Закупочных движений на 41.01: 1.\n- Движений выбытия со счета 41.01: 1.\n- В текущем контуре найдены обе стороны цепочки: поступление и последующее выбытие.\n\nБлок 2. Закупка\n- Первая дата: 10.12.2019.\n- Последняя дата: 10.12.2019.\n1. Поступление товаров и услуг 00000000111 от 10.12.2019 12:00:01 | дата: 10.12.2019 | сумма: 712.500,00 ₽ | склад: Основной склад\n\nБлок 3. Выбытие\n- Первая дата: 01.04.2020.\n- Последняя дата: 01.04.2020.\n1. Реализация товаров и услуг 00000000001 от 01.04.2020 0:00:00 | дата: 01.04.2020 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-CDWA4KbSYO"}} +{"timestamp":"2026-04-14T08:18:24.607Z","level":"info","service":"assistant_loop","message":"assistant_address_tool_gate_skip","sessionId":"asst-BExvZaGtx4","details":{"session_id":"asst-BExvZaGtx4","user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","effective_address_user_message":"Проверить наличие документально подтвержденной цепочки: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотечный 1000*400*2100 -> покупатель департамент капитального ремонта города москвы","assistant_orchestration_contract_v1":{"schema_version":"assistant_orchestration_contract_v1","hard_meta_mode":null,"address_mode":"deep_analysis","address_mode_confidence":"high","address_intent":"inventory_purchase_to_sale_chain","address_intent_confidence":"medium","strong_data_signal_detected":true,"data_retrieval_signal_detected":true,"semantic_contract_valid":true,"semantic_apply_canonical_recommended":true,"semantic_reason_codes":["deep_investigation_signal_detected"],"semantic_route_arbitration":{"supported_address_intent_detected":false,"semantic_deep_investigation_hint_detected":true,"semantic_aggregate_shape_detected":false,"followup_semantic_override_to_deep_allowed":false},"followup_context_detected":false,"unsupported_address_intent_fallback_to_deep":false,"deep_analysis_signal_fallback_to_deep":true,"aggregate_analytics_signal_fallback_to_deep":false,"deep_session_continuation_fallback_to_deep":false,"final_decision":{"run_address_lane":false,"tool_gate_decision":"skip_address_lane","tool_gate_reason":"deep_analysis_signal_fallback_to_deep","living_mode":"deep_analysis","living_reason":"deep_analysis_signal_fallback_to_deep"}},"address_tool_gate_decision":"skip_address_lane","address_tool_gate_reason":"deep_analysis_signal_fallback_to_deep","address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["deep_investigation_signal_detected"]}} +{"timestamp":"2026-04-14T08:18:44.319Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-BExvZaGtx4","eventType":"assistant_message","details":{"session_id":"asst-BExvZaGtx4","message_id":"msg-K0YmprH2LI","user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","normalizer_output":null,"execution_plan":[],"resolved_execution_state":[],"routes":[],"retrieval_calls":[],"retrieval_results_raw":[],"retrieval_results_normalized":[],"requirements_extracted":[{"requirement_id":"R1","source_fragment_id":null,"requirement_text":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","subject_tokens":["counterparty","document","chain"],"status":"clarification_needed","route":null}],"requirements_total":1,"requirements_covered":0,"requirements_uncovered":[],"coverage_status":"partial_or_limited","answer_grounding_status":"no_grounded_answer","reply_semantic_type":"clarification_required","why_included_summary":[],"selection_reason_summary":[],"route_subject_match":true,"clarification_target":["R1"],"dropped_intent_segments":[],"question_type_class":"unknown","company_anchors":{"contract_numbers":[],"document_numbers":[],"dates":[],"amounts":[],"accounts":[],"periods":[],"document_types":[],"all":[]},"analysis_context_applied":true,"analysis_context":{"as_of_date":"2026-04-13","period_from":null,"period_to":null,"source":"scenario_pack","snapshot_mode":"auto"},"business_scope_raw":[],"business_scope_resolved":["company_specific_accounting"],"company_grounding_applied":true,"scope_resolution_reason":["settlement_claim_company_scope_recovery"],"company_scope_resolution_reason":["settlement_claim_company_scope_recovery"],"raw_time_anchor":"2026-04-13","raw_time_scope":"2026-04-13..2026-04-13","resolved_time_anchor":"2026-04-13","resolved_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"effective_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"temporal_guard_input":"2026-04-13..2026-04-13","temporal_alignment_status":"aligned","temporal_resolution_source":"scenario_pack","temporal_guard_basis":"raw_time_scope_unlocked","temporal_guard_applied":false,"temporal_guard_outcome":"passed","temporal_guard":{"raw_time_anchor":"2026-04-13","raw_time_scope":"2026-04-13..2026-04-13","resolved_time_anchor":"2026-04-13","resolved_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"effective_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"temporal_guard_input":"2026-04-13..2026-04-13","temporal_alignment_status":"aligned","temporal_resolution_source":"scenario_pack","temporal_guard_basis":"raw_time_scope_unlocked","temporal_guard_applied":false,"temporal_guard_outcome":"passed","primary_period_window":null,"allowed_context_window":null,"controlled_temporal_expansion_enabled":false,"context_expansion_reasons_allowed":["prehistory","carryover","post_period_closure","long_running_contract_context"],"normalized_anchor_drift_detected":false,"reason_codes":["analysis_context_applied"]},"raw_numeric_tokens":["1000","400","2100"],"classified_numeric_tokens":[],"rejected_as_non_accounts":[],"resolved_account_anchors":[],"domain_polarity_guard":{"applied":true,"polarity":"mixed_or_unresolved","outcome":"limited_unresolved_polarity","supplier_score":2,"customer_score":2,"account_scope":[],"raw_numeric_tokens":["1000","400","2100"],"classified_numeric_tokens":[],"rejected_as_non_accounts":[],"resolved_account_anchors":[],"rejected_problem_units":0,"rejected_evidence":0,"critical_contradiction":true,"reason_codes":["unresolved_supplier_customer_polarity","supplier_customer_signals_conflict"]},"claim_anchor_audit":{"claim_type":"prove_settlement_closure_state","settlement_role":"mixed","settlement_role_resolution_reason":["settlement_role_resolved_mixed"],"polarity_resolution_status":"mixed","required_anchors":["period","account_scope","counterparty_scope_or_contract","closure_signal"],"resolved_anchors":{"period":["2026-04-13"],"account_scope":[],"amounts":[],"contract":[],"document_numbers":[],"document_types":[],"counterparty_scope":["supplier","customer"],"advance_signal":[],"closure_signal":[],"vat_signal":[],"chain_signal":[],"close_signal":[],"cost_scope":[],"rbp_signal":[],"writeoff_signal":[],"fixed_asset_signal":[],"amortization_signal":[],"expected_fa_set":[],"actual_fa_set":[]},"missing_anchors":["account_scope","closure_signal"],"claim_anchor_resolution_rate":0.5,"primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"allowed_context_window":{"from":"2025-04-13","to":"2027-04-13","granularity":"month"},"context_expansion_reasons_allowed":["prehistory","carryover","post_period_closure","long_running_contract_context"],"reason_codes":["claim_missing_required_anchors","claim_anchor_resolution_low","unresolved_supplier_customer_polarity"]},"settlement_role":"mixed","settlement_role_resolution_reason":["settlement_role_resolved_mixed"],"polarity_resolution_status":"mixed","targeted_evidence_acquisition":{"claim_type":"prove_settlement_closure_state","required_checks":["payment_document_found","contract_matched","settlement_object_matched","closing_document_found","register_closure_entry_found","posting_link_found"],"check_status":{"payment_document_found":"not_found","contract_matched":"not_found","settlement_object_matched":"not_found","closing_document_found":"not_found","register_closure_entry_found":"not_found","posting_link_found":"not_found"},"targeted_item_hits":0,"targeted_evidence_hits":0,"targeted_evidence_hit_rate":0,"targeted_evidence_source_refs":[],"reason_codes":["targeted_evidence_not_found","targeted_evidence_hit_rate_low"]},"evidence_admissibility_gate":{"candidate_evidence_total":0,"admissible_evidence_count":0,"rejected_evidence_count":0,"rejected_item_count":0,"reject_breakdown":{"wrong_period":0,"wrong_domain":0,"wrong_account_scope":0,"weak_source_mapping":0,"zero_live_match":0,"future_dated_or_out_of_window":0},"category_breakdown":{"hard_evidence":0,"supporting_signal":0,"inadmissible_noise":0},"reason_codes":["no_admissible_evidence_for_grounded_answer"]},"eligibility_time_basis":"raw_time_scope_unlocked","grounded_answer_eligibility_guard":{"eligible":false,"temporal_passed":true,"eligibility_time_basis":"raw_time_scope_unlocked","business_scope_passed":true,"polarity_passed":false,"claim_anchors_passed":true,"claim_anchor_resolution_rate":0.5,"missing_required_anchors":2,"admissible_evidence_count":0,"critical_contradiction":true,"outcome":"limited_or_insufficient_evidence","grounding_mode":"limited_or_insufficient_evidence","reason_codes":["polarity_guard_limited_unresolved_polarity","admissible_evidence_count_zero","targeted_evidence_hit_rate_zero","critical_domain_or_account_contradiction"]},"problem_centric_answer_applied":false,"problem_units_used_count":0,"problem_answer_mode":"stage1_policy_v11","assistant_outcome_class_v1":"BLOCKED_BY_AMBIGUITY","assistant_orchestration_contracts_v1":{"query_frame":{"schema_version":"assistant_query_frame_v1","original_user_question":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","normalized_question":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","route_summary_mode":"none","fragments_total":0,"dropped_intent_segments":[],"analysis_context":{"as_of_date":"2026-04-13","period_from":null,"period_to":null,"source":"scenario_pack","snapshot_mode":"auto"}},"execution_plan":{"schema_version":"assistant_execution_plan_v1","steps":[],"requirements_total":1},"evidence_bundle":{"schema_version":"assistant_evidence_bundle_v1","retrieval_calls_total":0,"retrieval_results_total":0,"retrieval_status_breakdown":{"ok":0,"partial":0,"empty":0,"error":0},"evidence_total":0,"source_refs_total":0,"limitation_total":0,"error_total":0},"coverage":{"schema_version":"assistant_coverage_contract_v1","coverage_report":{"requirements_total":1,"requirements_covered":0,"requirements_uncovered":[],"requirements_partially_covered":[],"clarification_needed_for":["R1"],"out_of_scope_requirements":[]},"grounding":{"status":"no_grounded_answer","route_subject_match":true,"missing_requirements":["R1"],"reasons":["Ни одно требование не получило подтвержденного покрытия.","В текущей выборке не хватает явных подтверждений, почему записи попали в ответ.","Часть контекста вопроса не подтверждена напрямую в найденных данных: counterparty, document, chain","Не удалось однозначно определить сторону расчета (нам должны или мы должны).","Недостаточно подтвержденных данных для уверенного ответа.","Не хватило целевых подтверждений по выбранному сценарию.","Есть противоречие по выбранному домену или контуру счета."],"why_included_summary":[],"selection_reason_summary":[]},"outcome_class":"BLOCKED_BY_AMBIGUITY"}},"answer_contract_stage4_v1":{"schema_version":"stage4_answer_contract_audit_v1","stage4_blocks_expected":["Коротко","Что именно проверено","Что найдено","Что пока не доказано","Что проверить первым/Что могу сделать сейчас"],"stage4_blocks_present":["Коротко","Что именно проверено","Что найдено","Что пока не доказано","Что проверить первым/Что могу сделать сейчас"],"stage4_blocks_missing":[],"legacy_blocks_present":[],"is_stage4_shape":true},"answer_structure_v11":{"schema_version":"answer_structure_v1_1","answer_summary":"Нужны уточнения: без сужения фокуса надежный вывод невозможен.","direct_answer":"Есть признаки проблемы, но без уточнений по периоду и объекту вывод ненадежен.","mechanism_block":{"status":"unresolved","mechanism_notes":[],"limitation_reason_codes":[]},"evidence_block":{"evidence_ids":[],"source_refs":[],"mechanism_notes":[],"coverage_note":"coverage_partial_or_limited"},"uncertainty_block":{"open_uncertainties":["R1","missing_anchor:period","missing_anchor:account","missing_anchor:counterparty"],"limitations":["Ни одно требование не получило подтвержденного покрытия.","В текущей выборке не хватает явных подтверждений, почему записи попали в ответ.","Часть контекста вопроса не подтверждена напрямую в найденных данных: counterparty, document, chain","Не удалось однозначно определить сторону расчета (нам должны или мы должны).","Недостаточно подтвержденных данных для уверенного ответа.","Не хватило целевых подтверждений по выбранному сценарию.","Есть противоречие по выбранному домену или контуру счета."]},"next_step_block":{"recommended_actions":["Дайте недостающие якоря (период/счет/объект), иначе сильный factual вывод невозможен."],"clarification_questions":["Уточните период проверки (например, июль 2020).","Уточните счет или группу счетов (например, 19, 60, 62).","Укажите контрагента или группу контрагентов.","Закройте уточнения для требований: R1."]}},"investigation_state_snapshot":{"schema_version":"investigation_state_v1","session_id":"asst-BExvZaGtx4","status":"active","turn_index":1,"updated_at":"2026-04-14T08:18:44.315Z","question_id":"msg-xBZO9GztLP","question_scope_id":"d:settlements_60_62|s:есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотеч","scope_origin":"explicit_from_message","focus":{"domain":"settlements_60_62","period":null,"primary_accounts":[],"active_query_subject":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы"},"narrowing_status":"unknown","evidence_refs":[],"open_uncertainties":["clarify:R1"],"last_answer_mode":"clarification_required","followup_context":{"previous_question_id":null,"last_user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","referenced_requirement_ids":["R1"],"active_domain":"settlements_60_62","active_requirement_ids":["R1"],"uncovered_requirement_ids":["R1"],"last_problem_unit_id":null,"settlement_next_actions":["Проверьте договор и объект расчетов по платежу.","Сверьте регистр расчетов и привязку платежа к закрывающему документу.","Проверьте зачет аванса или взаимозачет по связке 60/62."],"evidence_summary":[],"question_scope_id":"d:settlements_60_62|s:есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотеч","scope_origin":"explicit_from_message"},"query_mode_hint":"investigation_candidate"},"fallback_type":"clarification","assistant_reply":"Коротко: По этому запросу у меня нет надежного доменного покрытия, поэтому даю мягкий отказ вместо технического шаблона.\n\nЧто именно проверено:\n- Проверен доступный контур 1С и возможность маршрутизации запроса.\n- Надежный доменный путь для текущей формулировки не подтвержден.\n\nЧто найдено:\n- Взаиморасчеты 60/62: найти хвосты, незакрытые оплаты и рисковые связки по контрагентам.\n- НДС 19/68: проверить цепочку документ -> счет-фактура -> регистр -> книга.\n- Закрытие месяца 20/44: проверить распределение затрат и остатки после регламентных операций.\n\nЧто пока не доказано:\n- Запрос не подтвержден в поддерживаемом контуре как надежный бухгалтерский сценарий.\n\nЧто могу сделать сейчас:\n- Взаиморасчеты 60/62 — найти хвосты, незакрытые оплаты и рисковые связки по контрагентам.\n- НДС 19/68 — проверить цепочку документ -> счет-фактура -> регистр -> книга.\n- Закрытие месяца 20/44 — проверить распределение затрат и остатки после регламентных операций.","reply_type":"clarification_required","trace_id":"VDxca2tLAKyVJo"}} +{"timestamp":"2026-04-14T08:21:42.311Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-i77GCV_L7a","eventType":"assistant_message_address","details":{"session_id":"asst-i77GCV_L7a","message_id":"msg-6zC59ueWj1","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"RIOA6pLl1SJDTU","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-Rc2rdhgK-q"}} +{"timestamp":"2026-04-14T08:21:48.369Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-i77GCV_L7a","eventType":"assistant_message_address","details":{"session_id":"asst-i77GCV_L7a","message_id":"msg-DH8IZqLFnp","user_message":"Из каких товаров состоит остаток по 41 счету","effective_address_user_message":"Из каких товаров состоит остаток по 41 счету","address_followup_context_applied":true,"address_followup_context_previous_intent":"inventory_on_hand_as_of_date","address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"fwNZSKtSzOkK3L","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"из каких товаров состоит остаток по 41 счету","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"continue_previous","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-VjeB7YheQn"}} +{"timestamp":"2026-04-14T08:21:54.536Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-i77GCV_L7a","eventType":"assistant_message_address","details":{"session_id":"asst-i77GCV_L7a","message_id":"msg-bjJsTTQ0vz","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31","effective_address_user_message":"Получить список товаров, находящихся на счете 41 на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"SZlfp1dSSHaiAt","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-GNU1TfKWnY"}} +{"timestamp":"2026-04-14T08:22:00.598Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-i77GCV_L7a","eventType":"assistant_message_address","details":{"session_id":"asst-i77GCV_L7a","message_id":"msg-IxmjswjKBk","user_message":"Какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","effective_address_user_message":"Получить список номенклатур, формирующих остаток на складе на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"jknf0VGLecadk-","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-gHD3cCxbU0"}} +{"timestamp":"2026-04-14T08:22:06.738Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-cz3p2dqF6n","eventType":"assistant_message_address","details":{"session_id":"asst-cz3p2dqF6n","message_id":"msg-nzThb6kIA3","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"JSnFVAnrdV9luZ","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-MytSMggnQ_"}} +{"timestamp":"2026-04-14T08:22:14.640Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-cz3p2dqF6n","eventType":"assistant_message_address","details":{"session_id":"asst-cz3p2dqF6n","message_id":"msg-hewPvLXX8d","user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"0YnAeG-bzTVgpI","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"от какого поставщика куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный закупочный след по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные закупочные движения на 41.01 по выбранному товару.\n- Важно: без партионности этот контур не подменяет собой лот-level доказательство происхождения текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 24.08.2018.\n- Последняя найденная дата закупочного движения: 24.08.2018.\n- Документов поступления: 1.\n- Операций поступления: 1.\n- Закупочные документы найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Опорные документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-Gvsybnuwak"}} +{"timestamp":"2026-04-14T08:22:22.754Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-cz3p2dqF6n","eventType":"assistant_message_address","details":{"session_id":"asst-cz3p2dqF6n","message_id":"msg-XhAAjLbI7t","user_message":"У какого поставщика были куплены товары, которые сейчас лежат на складе Основной склад организации ООО \\Альтернатива Плюс\\","effective_address_user_message":"Определить поставщиков, у которых были приобретены товары, находящиеся на складе 'Основной склад' в компании 'ООО Альтернатива Плюс'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"a0S5p5hP3ctU8b","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"у какого поставщика были куплены товары, которые сейчас лежат на складе основной склад организации ооо \\альтернатива плюс\\","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-XSVB5zX1xE"}} +{"timestamp":"2026-04-14T08:22:29.900Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-cz3p2dqF6n","eventType":"assistant_message_address","details":{"session_id":"asst-cz3p2dqF6n","message_id":"msg-y8nss27DLm","user_message":"По какому поставщику проходит текущий товарный остаток на складе Основной склад","effective_address_user_message":"Получить информацию о поставщике, связанным с текущим товарным остатком на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"ZE3OgeXf9zt9Sl","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"по какому поставщику проходит текущий товарный остаток на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-Uf5AqsYkvB"}} +{"timestamp":"2026-04-14T08:22:36.994Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-cz3p2dqF6n","eventType":"assistant_message_address","details":{"session_id":"asst-cz3p2dqF6n","message_id":"msg-8PAxgxoWPp","user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"uUUfs_zYBjj2Wg","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"когда был куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный закупочный след по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные закупочные движения на 41.01 по выбранному товару.\n- Важно: без партионности этот контур не подменяет собой лот-level доказательство происхождения текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 24.08.2018.\n- Последняя найденная дата закупочного движения: 24.08.2018.\n- Документов поступления: 1.\n- Операций поступления: 1.\n- Закупочные документы найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Опорные документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-F7tYRXK2ua"}} +{"timestamp":"2026-04-14T08:22:45.161Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-cz3p2dqF6n","eventType":"assistant_message_address","details":{"session_id":"asst-cz3p2dqF6n","message_id":"msg-kIuU_vmmYS","user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","effective_address_user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"N3UksPu3DAXCHl","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"по каким документам был куплен товар диван трехместный для остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_documents_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_documents_for_item","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_documents_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный для остатка на складе Основной склад","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_documents_for_item_v1","mcp_call_status_legacy":"materialized_but_not_matched","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"materialized_but_not_anchor_matched","match_failure_reason":"item_anchor_not_matched_in_materialized_rows","mcp_call_status":"materialized_but_not_anchor_matched","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":0,"rows_materialized":400,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":"empty_match","response_type":"LIMITED_WITH_REASON","limitations":["no_rows_for_anchor_after_materialization"],"assistant_reply":"По заданным фильтрам в текущем срезе совпадений пока нет.\n\nпо указанному якорю и фильтрам в выборке данных нет строк.\n\nСигнал запроса: список документов/операций.\n\nКонтекст запроса: срез на 2026-04-14.\n\nЧто могу сделать сейчас: показать документы поступления по товару на 41.01; показать документы/платежи по контрагенту или договору; показать незакрытые договоры или хвосты на дату.","reply_type":"partial_coverage","trace_id":"address-5s8My7DaxC"}} +{"timestamp":"2026-04-14T08:22:52.257Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-cz3p2dqF6n","eventType":"assistant_message_address","details":{"session_id":"asst-cz3p2dqF6n","message_id":"msg-ftmf2mgcoT","user_message":"Какие товары от поставщика Гамма-мебель, ООО сейчас еще лежат на складе Основной склад","effective_address_user_message":"Получить информацию о товарах от поставщика 'Гамма-мебель, ООО', которые находятся на складе 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"8foik14FIFXhcG","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары от поставщика гамма-мебель, ооо сейчас еще лежат на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","counterparty":"Гамма-мебель, ООО',","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":41,"rows_materialized":500,"rows_matched":41,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 13.05.2019.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 11.\n- Закупочных операций в выборке: 41.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 41.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n3. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n4. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 28.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n5. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 199.671,66 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n6. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 62.150,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n7. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 16.880,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 159.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n9. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 23.660,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n10. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 75.075,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-HgCZ3_3eH_"}} +{"timestamp":"2026-04-14T08:23:00.496Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-cz3p2dqF6n","eventType":"assistant_message_address","details":{"session_id":"asst-cz3p2dqF6n","message_id":"msg-vn0GVvktDA","user_message":"Какие товары по состоянию на дату 2020-03-31 на складе Основной склад были куплены у поставщика Гамма-мебель, ООО","effective_address_user_message":"Список товаров на складе 'Основной склад' по состоянию на 2020-03-31, приобретенных у поставщика 'Гамма-мебель, ООО'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"C9jG_YZks0dYeA","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары по состоянию на дату 2020-03-31 на складе основной склад были куплены у поставщика гамма-мебель, ооо","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","counterparty":"Гамма-мебель, ООО","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":41,"rows_materialized":500,"rows_matched":41,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 31.03.2020.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 13.05.2019.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 11.\n- Закупочных операций в выборке: 41.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 41.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n3. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n4. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 28.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n5. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 199.671,66 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n6. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 159.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n7. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 23.660,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 62.150,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n9. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 16.880,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n10. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 75.075,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-dNNCrYt0N9"}} +{"timestamp":"2026-04-14T08:23:06.751Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Dcjf7X7Scu","eventType":"assistant_message_address","details":{"session_id":"asst-Dcjf7X7Scu","message_id":"msg-Uween16ley","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"lM0bf0rf9UMpWg","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-Q73W4M4FGx"}} +{"timestamp":"2026-04-14T08:23:13.645Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Dcjf7X7Scu","eventType":"assistant_message_address","details":{"session_id":"asst-Dcjf7X7Scu","message_id":"msg-mgl82D0UZO","user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","effective_address_user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"1Hd7N_clAt_Qk2","address_llm_predecompose_reason":"normalized_fragment_rejected_semantic_guard","address_fallback_rule_hit":null,"address_sanitized_user_message":"относится ли товар шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_aging_by_purchase_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_aging_by_purchase_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_aging_by_purchase_date","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2020-03-31"},"selected_recipe":null,"mcp_call_status_legacy":"skipped","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":null,"resolver_confidence":null,"match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"skipped","rows_fetched":0,"raw_rows_received":0,"rows_after_account_scope":0,"rows_after_recipe_filter":0,"rows_materialized":0,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"DEEP_ONLY","limited_reason_category":"unsupported","response_type":"LIMITED_WITH_REASON","limitations":["capability_route_disabled_by_flag"],"assistant_reply":"Сейчас не дам прямой адресный ответ, чтобы не ошибиться в выводах.\n\nДля этого запроса пока нет надежного ответа в текущем адресном режиме.\n\nКонтекст запроса: срез на 2020-03-31.","reply_type":"partial_coverage","trace_id":"address-QsKAeMzQHO"}} +{"timestamp":"2026-04-14T08:23:20.867Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Dcjf7X7Scu","eventType":"assistant_message_address","details":{"session_id":"asst-Dcjf7X7Scu","message_id":"msg-NbZKA3MWpf","user_message":"Есть ли на складе Основной склад товары с остатком без понятной привязки к поставщику","effective_address_user_message":"Проверить наличие товаров на Основном складе с остатками, у которых нет ясной привязки к поставщику.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"mhJ1A_X5jjIHG2","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли на складе основной склад товары с остатком без понятной привязки к поставщику","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract","deep_investigation_signal_detected"],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-NjnxRxV1oI"}} +{"timestamp":"2026-04-14T08:23:28.089Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Dcjf7X7Scu","eventType":"assistant_message_address","details":{"session_id":"asst-Dcjf7X7Scu","message_id":"msg-aifJWtySSx","user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","effective_address_user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"mM4Cx3ekFzg8Nj","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли среди текущих остатков на складе основной склад позиции, закупленные задолго до 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-ZAJllWkwdZ"}} +{"timestamp":"2026-04-14T08:23:34.164Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-qoy9ymPiDo","eventType":"assistant_message_address","details":{"session_id":"asst-qoy9ymPiDo","message_id":"msg-l6q1CFu1_o","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31 на складе Основной склад","effective_address_user_message":"Получить список товаров, находящихся на 41 счете по состоянию на 2020-03-31 для склада 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"_P_UcgC_-y1cPW","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31 на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-RcL0ewGD4o"}} +{"timestamp":"2026-04-14T08:23:41.108Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-qoy9ymPiDo","eventType":"assistant_message_address","details":{"session_id":"asst-qoy9ymPiDo","message_id":"msg-POEfS1wO-u","user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","effective_address_user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"hVS8BAFAYrYCK5","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"кому был продан товар шкаф картотечный 1000*400*2100","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_sale_trace_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_sale_trace_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_sale_trace_for_item","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_sale_trace_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный след выбытия по товару товар до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные движения выбытия товара со счета 41.01.\n\nБлок 2. Сводка\n- Первая найденная дата выбытия: 01.04.2020.\n- Последняя найденная дата выбытия: 01.04.2020.\n- Документов выбытия: 1.\n- Операций выбытия: 1.\n- Документы выбытия найдены, но покупатель не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Документы выбытия\n1. Реализация товаров и услуг 00000000001 от 01.04.2020 0:00:00 | дата: 01.04.2020 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-6sU3MaOvM5"}} +{"timestamp":"2026-04-14T08:23:50.315Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-qoy9ymPiDo","eventType":"assistant_message_address","details":{"session_id":"asst-qoy9ymPiDo","message_id":"msg-wN_waE_2Cd","user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","effective_address_user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"bcl17_JuTK42Me","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"через какие документы прошел путь товара шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_to_sale_chain","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_to_sale_chain","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_to_sale_chain_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":600,"raw_rows_received":600,"rows_after_account_scope":600,"rows_after_recipe_filter":2,"rows_materialized":600,"rows_matched":2,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собрана документальная цепочка по товару Шкаф картотечный 1000*400*2100 до 14.04.2026.\n\nБлок 1. Статус результата\n- Закупочных движений на 41.01: 1.\n- Движений выбытия со счета 41.01: 1.\n- В текущем контуре найдены обе стороны цепочки: поступление и последующее выбытие.\n\nБлок 2. Закупка\n- Первая дата: 10.12.2019.\n- Последняя дата: 10.12.2019.\n1. Поступление товаров и услуг 00000000111 от 10.12.2019 12:00:01 | дата: 10.12.2019 | сумма: 712.500,00 ₽ | склад: Основной склад\n\nБлок 3. Выбытие\n- Первая дата: 01.04.2020.\n- Последняя дата: 01.04.2020.\n1. Реализация товаров и услуг 00000000001 от 01.04.2020 0:00:00 | дата: 01.04.2020 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-XvKoYCMlqN"}} +{"timestamp":"2026-04-14T08:23:59.943Z","level":"info","service":"assistant_loop","message":"assistant_address_tool_gate_skip","sessionId":"asst-qoy9ymPiDo","details":{"session_id":"asst-qoy9ymPiDo","user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","effective_address_user_message":"Проверить наличие документально подтвержденной цепочки: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотечный 1000*400*2100 -> покупатель департамент капитального ремонта города москвы","assistant_orchestration_contract_v1":{"schema_version":"assistant_orchestration_contract_v1","hard_meta_mode":null,"address_mode":"deep_analysis","address_mode_confidence":"high","address_intent":"inventory_purchase_to_sale_chain","address_intent_confidence":"medium","strong_data_signal_detected":true,"data_retrieval_signal_detected":true,"semantic_contract_valid":true,"semantic_apply_canonical_recommended":true,"semantic_reason_codes":["deep_investigation_signal_detected"],"semantic_route_arbitration":{"supported_address_intent_detected":false,"semantic_deep_investigation_hint_detected":true,"semantic_aggregate_shape_detected":false,"followup_semantic_override_to_deep_allowed":false},"followup_context_detected":false,"unsupported_address_intent_fallback_to_deep":false,"deep_analysis_signal_fallback_to_deep":true,"aggregate_analytics_signal_fallback_to_deep":false,"deep_session_continuation_fallback_to_deep":false,"final_decision":{"run_address_lane":false,"tool_gate_decision":"skip_address_lane","tool_gate_reason":"deep_analysis_signal_fallback_to_deep","living_mode":"deep_analysis","living_reason":"deep_analysis_signal_fallback_to_deep"}},"address_tool_gate_decision":"skip_address_lane","address_tool_gate_reason":"deep_analysis_signal_fallback_to_deep","address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["deep_investigation_signal_detected"]}} +{"timestamp":"2026-04-14T08:24:19.448Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-qoy9ymPiDo","eventType":"assistant_message","details":{"session_id":"asst-qoy9ymPiDo","message_id":"msg-pdUaW5mpsE","user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","normalizer_output":null,"execution_plan":[],"resolved_execution_state":[],"routes":[],"retrieval_calls":[],"retrieval_results_raw":[],"retrieval_results_normalized":[],"requirements_extracted":[{"requirement_id":"R1","source_fragment_id":null,"requirement_text":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","subject_tokens":["counterparty","document","chain"],"status":"clarification_needed","route":null}],"requirements_total":1,"requirements_covered":0,"requirements_uncovered":[],"coverage_status":"partial_or_limited","answer_grounding_status":"no_grounded_answer","reply_semantic_type":"clarification_required","why_included_summary":[],"selection_reason_summary":[],"route_subject_match":true,"clarification_target":["R1"],"dropped_intent_segments":[],"question_type_class":"unknown","company_anchors":{"contract_numbers":[],"document_numbers":[],"dates":[],"amounts":[],"accounts":[],"periods":[],"document_types":[],"all":[]},"analysis_context_applied":true,"analysis_context":{"as_of_date":"2026-04-13","period_from":null,"period_to":null,"source":"scenario_pack","snapshot_mode":"auto"},"business_scope_raw":[],"business_scope_resolved":["company_specific_accounting"],"company_grounding_applied":true,"scope_resolution_reason":["settlement_claim_company_scope_recovery"],"company_scope_resolution_reason":["settlement_claim_company_scope_recovery"],"raw_time_anchor":"2026-04-13","raw_time_scope":"2026-04-13..2026-04-13","resolved_time_anchor":"2026-04-13","resolved_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"effective_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"temporal_guard_input":"2026-04-13..2026-04-13","temporal_alignment_status":"aligned","temporal_resolution_source":"scenario_pack","temporal_guard_basis":"raw_time_scope_unlocked","temporal_guard_applied":false,"temporal_guard_outcome":"passed","temporal_guard":{"raw_time_anchor":"2026-04-13","raw_time_scope":"2026-04-13..2026-04-13","resolved_time_anchor":"2026-04-13","resolved_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"effective_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"temporal_guard_input":"2026-04-13..2026-04-13","temporal_alignment_status":"aligned","temporal_resolution_source":"scenario_pack","temporal_guard_basis":"raw_time_scope_unlocked","temporal_guard_applied":false,"temporal_guard_outcome":"passed","primary_period_window":null,"allowed_context_window":null,"controlled_temporal_expansion_enabled":false,"context_expansion_reasons_allowed":["prehistory","carryover","post_period_closure","long_running_contract_context"],"normalized_anchor_drift_detected":false,"reason_codes":["analysis_context_applied"]},"raw_numeric_tokens":["1000","400","2100"],"classified_numeric_tokens":[],"rejected_as_non_accounts":[],"resolved_account_anchors":[],"domain_polarity_guard":{"applied":true,"polarity":"mixed_or_unresolved","outcome":"limited_unresolved_polarity","supplier_score":2,"customer_score":2,"account_scope":[],"raw_numeric_tokens":["1000","400","2100"],"classified_numeric_tokens":[],"rejected_as_non_accounts":[],"resolved_account_anchors":[],"rejected_problem_units":0,"rejected_evidence":0,"critical_contradiction":true,"reason_codes":["unresolved_supplier_customer_polarity","supplier_customer_signals_conflict"]},"claim_anchor_audit":{"claim_type":"prove_settlement_closure_state","settlement_role":"mixed","settlement_role_resolution_reason":["settlement_role_resolved_mixed"],"polarity_resolution_status":"mixed","required_anchors":["period","account_scope","counterparty_scope_or_contract","closure_signal"],"resolved_anchors":{"period":["2026-04-13"],"account_scope":[],"amounts":[],"contract":[],"document_numbers":[],"document_types":[],"counterparty_scope":["supplier","customer"],"advance_signal":[],"closure_signal":[],"vat_signal":[],"chain_signal":[],"close_signal":[],"cost_scope":[],"rbp_signal":[],"writeoff_signal":[],"fixed_asset_signal":[],"amortization_signal":[],"expected_fa_set":[],"actual_fa_set":[]},"missing_anchors":["account_scope","closure_signal"],"claim_anchor_resolution_rate":0.5,"primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"allowed_context_window":{"from":"2025-04-13","to":"2027-04-13","granularity":"month"},"context_expansion_reasons_allowed":["prehistory","carryover","post_period_closure","long_running_contract_context"],"reason_codes":["claim_missing_required_anchors","claim_anchor_resolution_low","unresolved_supplier_customer_polarity"]},"settlement_role":"mixed","settlement_role_resolution_reason":["settlement_role_resolved_mixed"],"polarity_resolution_status":"mixed","targeted_evidence_acquisition":{"claim_type":"prove_settlement_closure_state","required_checks":["payment_document_found","contract_matched","settlement_object_matched","closing_document_found","register_closure_entry_found","posting_link_found"],"check_status":{"payment_document_found":"not_found","contract_matched":"not_found","settlement_object_matched":"not_found","closing_document_found":"not_found","register_closure_entry_found":"not_found","posting_link_found":"not_found"},"targeted_item_hits":0,"targeted_evidence_hits":0,"targeted_evidence_hit_rate":0,"targeted_evidence_source_refs":[],"reason_codes":["targeted_evidence_not_found","targeted_evidence_hit_rate_low"]},"evidence_admissibility_gate":{"candidate_evidence_total":0,"admissible_evidence_count":0,"rejected_evidence_count":0,"rejected_item_count":0,"reject_breakdown":{"wrong_period":0,"wrong_domain":0,"wrong_account_scope":0,"weak_source_mapping":0,"zero_live_match":0,"future_dated_or_out_of_window":0},"category_breakdown":{"hard_evidence":0,"supporting_signal":0,"inadmissible_noise":0},"reason_codes":["no_admissible_evidence_for_grounded_answer"]},"eligibility_time_basis":"raw_time_scope_unlocked","grounded_answer_eligibility_guard":{"eligible":false,"temporal_passed":true,"eligibility_time_basis":"raw_time_scope_unlocked","business_scope_passed":true,"polarity_passed":false,"claim_anchors_passed":true,"claim_anchor_resolution_rate":0.5,"missing_required_anchors":2,"admissible_evidence_count":0,"critical_contradiction":true,"outcome":"limited_or_insufficient_evidence","grounding_mode":"limited_or_insufficient_evidence","reason_codes":["polarity_guard_limited_unresolved_polarity","admissible_evidence_count_zero","targeted_evidence_hit_rate_zero","critical_domain_or_account_contradiction"]},"problem_centric_answer_applied":false,"problem_units_used_count":0,"problem_answer_mode":"stage1_policy_v11","assistant_outcome_class_v1":"BLOCKED_BY_AMBIGUITY","assistant_orchestration_contracts_v1":{"query_frame":{"schema_version":"assistant_query_frame_v1","original_user_question":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","normalized_question":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","route_summary_mode":"none","fragments_total":0,"dropped_intent_segments":[],"analysis_context":{"as_of_date":"2026-04-13","period_from":null,"period_to":null,"source":"scenario_pack","snapshot_mode":"auto"}},"execution_plan":{"schema_version":"assistant_execution_plan_v1","steps":[],"requirements_total":1},"evidence_bundle":{"schema_version":"assistant_evidence_bundle_v1","retrieval_calls_total":0,"retrieval_results_total":0,"retrieval_status_breakdown":{"ok":0,"partial":0,"empty":0,"error":0},"evidence_total":0,"source_refs_total":0,"limitation_total":0,"error_total":0},"coverage":{"schema_version":"assistant_coverage_contract_v1","coverage_report":{"requirements_total":1,"requirements_covered":0,"requirements_uncovered":[],"requirements_partially_covered":[],"clarification_needed_for":["R1"],"out_of_scope_requirements":[]},"grounding":{"status":"no_grounded_answer","route_subject_match":true,"missing_requirements":["R1"],"reasons":["Ни одно требование не получило подтвержденного покрытия.","В текущей выборке не хватает явных подтверждений, почему записи попали в ответ.","Часть контекста вопроса не подтверждена напрямую в найденных данных: counterparty, document, chain","Не удалось однозначно определить сторону расчета (нам должны или мы должны).","Недостаточно подтвержденных данных для уверенного ответа.","Не хватило целевых подтверждений по выбранному сценарию.","Есть противоречие по выбранному домену или контуру счета."],"why_included_summary":[],"selection_reason_summary":[]},"outcome_class":"BLOCKED_BY_AMBIGUITY"}},"answer_contract_stage4_v1":{"schema_version":"stage4_answer_contract_audit_v1","stage4_blocks_expected":["Коротко","Что именно проверено","Что найдено","Что пока не доказано","Что проверить первым/Что могу сделать сейчас"],"stage4_blocks_present":["Коротко","Что именно проверено","Что найдено","Что пока не доказано","Что проверить первым/Что могу сделать сейчас"],"stage4_blocks_missing":[],"legacy_blocks_present":[],"is_stage4_shape":true},"answer_structure_v11":{"schema_version":"answer_structure_v1_1","answer_summary":"Нужны уточнения: без сужения фокуса надежный вывод невозможен.","direct_answer":"Есть признаки проблемы, но без уточнений по периоду и объекту вывод ненадежен.","mechanism_block":{"status":"unresolved","mechanism_notes":[],"limitation_reason_codes":[]},"evidence_block":{"evidence_ids":[],"source_refs":[],"mechanism_notes":[],"coverage_note":"coverage_partial_or_limited"},"uncertainty_block":{"open_uncertainties":["R1","missing_anchor:period","missing_anchor:account","missing_anchor:counterparty"],"limitations":["Ни одно требование не получило подтвержденного покрытия.","В текущей выборке не хватает явных подтверждений, почему записи попали в ответ.","Часть контекста вопроса не подтверждена напрямую в найденных данных: counterparty, document, chain","Не удалось однозначно определить сторону расчета (нам должны или мы должны).","Недостаточно подтвержденных данных для уверенного ответа.","Не хватило целевых подтверждений по выбранному сценарию.","Есть противоречие по выбранному домену или контуру счета."]},"next_step_block":{"recommended_actions":["Дайте недостающие якоря (период/счет/объект), иначе сильный factual вывод невозможен."],"clarification_questions":["Уточните период проверки (например, июль 2020).","Уточните счет или группу счетов (например, 19, 60, 62).","Укажите контрагента или группу контрагентов.","Закройте уточнения для требований: R1."]}},"investigation_state_snapshot":{"schema_version":"investigation_state_v1","session_id":"asst-qoy9ymPiDo","status":"active","turn_index":1,"updated_at":"2026-04-14T08:24:19.444Z","question_id":"msg-Rp7j9Ya42U","question_scope_id":"d:settlements_60_62|s:есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотеч","scope_origin":"explicit_from_message","focus":{"domain":"settlements_60_62","period":null,"primary_accounts":[],"active_query_subject":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы"},"narrowing_status":"unknown","evidence_refs":[],"open_uncertainties":["clarify:R1"],"last_answer_mode":"clarification_required","followup_context":{"previous_question_id":null,"last_user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","referenced_requirement_ids":["R1"],"active_domain":"settlements_60_62","active_requirement_ids":["R1"],"uncovered_requirement_ids":["R1"],"last_problem_unit_id":null,"settlement_next_actions":["Проверьте договор и объект расчетов по платежу.","Сверьте регистр расчетов и привязку платежа к закрывающему документу.","Проверьте зачет аванса или взаимозачет по связке 60/62."],"evidence_summary":[],"question_scope_id":"d:settlements_60_62|s:есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотеч","scope_origin":"explicit_from_message"},"query_mode_hint":"investigation_candidate"},"fallback_type":"clarification","assistant_reply":"Коротко: По этому запросу у меня нет надежного доменного покрытия, поэтому даю мягкий отказ вместо технического шаблона.\n\nЧто именно проверено:\n- Проверен доступный контур 1С и возможность маршрутизации запроса.\n- Надежный доменный путь для текущей формулировки не подтвержден.\n\nЧто найдено:\n- Взаиморасчеты 60/62: найти хвосты, незакрытые оплаты и рисковые связки по контрагентам.\n- НДС 19/68: проверить цепочку документ -> счет-фактура -> регистр -> книга.\n- Закрытие месяца 20/44: проверить распределение затрат и остатки после регламентных операций.\n\nЧто пока не доказано:\n- Запрос не подтвержден в поддерживаемом контуре как надежный бухгалтерский сценарий.\n\nЧто могу сделать сейчас:\n- Взаиморасчеты 60/62 — найти хвосты, незакрытые оплаты и рисковые связки по контрагентам.\n- НДС 19/68 — проверить цепочку документ -> счет-фактура -> регистр -> книга.\n- Закрытие месяца 20/44 — проверить распределение затрат и остатки после регламентных операций.","reply_type":"clarification_required","trace_id":"-nB07p30ipnMC9"}} +{"timestamp":"2026-04-14T08:27:42.250Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-uge5vl6GC1","eventType":"assistant_message_address","details":{"session_id":"asst-uge5vl6GC1","message_id":"msg-X5xevu2H7c","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"TkBeAehxRI7H7u","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-yb8IrtGAPn"}} +{"timestamp":"2026-04-14T08:27:48.371Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-uge5vl6GC1","eventType":"assistant_message_address","details":{"session_id":"asst-uge5vl6GC1","message_id":"msg-Hf9AhKd8kV","user_message":"Из каких товаров состоит остаток по 41 счету","effective_address_user_message":"Какие товары составляют остаток на счете 41","address_followup_context_applied":true,"address_followup_context_previous_intent":"inventory_on_hand_as_of_date","address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"6PVHmNUAMdbkR_","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"из каких товаров состоит остаток по 41 счету","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"continue_previous","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-hFaqiNX1Fq"}} +{"timestamp":"2026-04-14T08:27:54.458Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-uge5vl6GC1","eventType":"assistant_message_address","details":{"session_id":"asst-uge5vl6GC1","message_id":"msg-2ydOmT4qfz","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31","effective_address_user_message":"Получить список товаров, находящихся на счете 41 на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"wFSnyFBIxGpx4U","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-Gk6C8XQ1I_"}} +{"timestamp":"2026-04-14T08:28:00.537Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-uge5vl6GC1","eventType":"assistant_message_address","details":{"session_id":"asst-uge5vl6GC1","message_id":"msg-9HLxvdiu_7","user_message":"Какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","effective_address_user_message":"Получить список номенклатур, формирующих остаток на складе на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"_dPLhZhbpfTPBO","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-v0P9Vc72Ts"}} +{"timestamp":"2026-04-14T08:28:06.672Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-P6Wu9YSHQa","eventType":"assistant_message_address","details":{"session_id":"asst-P6Wu9YSHQa","message_id":"msg-RljS5Pmyii","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"-lpuiGbsHeol0F","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-A3igiU8y7e"}} +{"timestamp":"2026-04-14T08:28:14.593Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-P6Wu9YSHQa","eventType":"assistant_message_address","details":{"session_id":"asst-P6Wu9YSHQa","message_id":"msg-PondpRjCnm","user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"OSC-eE9wrGBBss","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"от какого поставщика куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный закупочный след по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные закупочные движения на 41.01 по выбранному товару.\n- Важно: без партионности этот контур не подменяет собой лот-level доказательство происхождения текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 24.08.2018.\n- Последняя найденная дата закупочного движения: 24.08.2018.\n- Документов поступления: 1.\n- Операций поступления: 1.\n- Закупочные документы найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Опорные документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-3zGgB5F-oZ"}} +{"timestamp":"2026-04-14T08:28:22.817Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-P6Wu9YSHQa","eventType":"assistant_message_address","details":{"session_id":"asst-P6Wu9YSHQa","message_id":"msg-DrwG3tfX0I","user_message":"У какого поставщика были куплены товары, которые сейчас лежат на складе Основной склад организации ООО \\Альтернатива Плюс\\","effective_address_user_message":"Определить поставщиков, у которых были приобретены товары, находящиеся на складе 'Основной склад' в компании 'ООО Альтернатива Плюс'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"ZoOaqAa9xCw_Ba","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"у какого поставщика были куплены товары, которые сейчас лежат на складе основной склад организации ооо \\альтернатива плюс\\","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-UeVGsw70LL"}} +{"timestamp":"2026-04-14T08:28:29.984Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-P6Wu9YSHQa","eventType":"assistant_message_address","details":{"session_id":"asst-P6Wu9YSHQa","message_id":"msg-NRyWyh1k0v","user_message":"По какому поставщику проходит текущий товарный остаток на складе Основной склад","effective_address_user_message":"Получить информацию о поставщике, связанным с текущим товарным остатком на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"KoH1LOUIObiE7u","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"по какому поставщику проходит текущий товарный остаток на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-J3lDpNQbRr"}} +{"timestamp":"2026-04-14T08:28:37.021Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-P6Wu9YSHQa","eventType":"assistant_message_address","details":{"session_id":"asst-P6Wu9YSHQa","message_id":"msg-_n6eeLTLGk","user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"ndEDrpA8eNO8WU","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"когда был куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный закупочный след по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные закупочные движения на 41.01 по выбранному товару.\n- Важно: без партионности этот контур не подменяет собой лот-level доказательство происхождения текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 24.08.2018.\n- Последняя найденная дата закупочного движения: 24.08.2018.\n- Документов поступления: 1.\n- Операций поступления: 1.\n- Закупочные документы найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Опорные документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-0itYYAfGi8"}} +{"timestamp":"2026-04-14T08:28:45.051Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-P6Wu9YSHQa","eventType":"assistant_message_address","details":{"session_id":"asst-P6Wu9YSHQa","message_id":"msg-LRi1zNCs9q","user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","effective_address_user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"amU9FoC-nzbOXb","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"по каким документам был куплен товар диван трехместный для остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_documents_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_documents_for_item","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_documents_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный для остатка на складе Основной склад","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_documents_for_item_v1","mcp_call_status_legacy":"materialized_but_not_matched","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"materialized_but_not_anchor_matched","match_failure_reason":"item_anchor_not_matched_in_materialized_rows","mcp_call_status":"materialized_but_not_anchor_matched","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":0,"rows_materialized":400,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":"empty_match","response_type":"LIMITED_WITH_REASON","limitations":["no_rows_for_anchor_after_materialization"],"assistant_reply":"По заданным фильтрам в текущем срезе совпадений пока нет.\n\nпо указанному якорю и фильтрам в выборке данных нет строк.\n\nСигнал запроса: список документов/операций.\n\nКонтекст запроса: срез на 2026-04-14.\n\nЧто могу сделать сейчас: показать документы поступления по товару на 41.01; показать документы/платежи по контрагенту или договору; показать незакрытые договоры или хвосты на дату.","reply_type":"partial_coverage","trace_id":"address-36Vb2jy1-Y"}} +{"timestamp":"2026-04-14T08:28:53.333Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-P6Wu9YSHQa","eventType":"assistant_message_address","details":{"session_id":"asst-P6Wu9YSHQa","message_id":"msg-n4f5yzg2yW","user_message":"Какие товары от поставщика Гамма-мебель, ООО сейчас еще лежат на складе Основной склад","effective_address_user_message":"Получить информацию о товарах от поставщика 'Гамма-мебель, ООО', которые находятся на складе 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"ifLvlGgLd_ABii","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары от поставщика гамма-мебель, ооо сейчас еще лежат на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","counterparty":"Гамма-мебель, ООО',","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":41,"rows_materialized":500,"rows_matched":41,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 13.05.2019.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 11.\n- Закупочных операций в выборке: 41.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 41.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n3. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n4. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 28.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n5. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 199.671,66 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n6. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 62.150,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n7. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 16.880,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 159.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n9. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 23.660,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n10. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 75.075,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-38y1GvtFTV"}} +{"timestamp":"2026-04-14T08:29:01.464Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-P6Wu9YSHQa","eventType":"assistant_message_address","details":{"session_id":"asst-P6Wu9YSHQa","message_id":"msg-GefD_53yuj","user_message":"Какие товары по состоянию на дату 2020-03-31 на складе Основной склад были куплены у поставщика Гамма-мебель, ООО","effective_address_user_message":"Получить список товаров на складе 'Основной склад' по состоянию на 2020-03-31, приобретенных у поставщика 'Гамма-мебель, ООО'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"1_GyLZ3X1PCjYs","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары по состоянию на дату 2020-03-31 на складе основной склад были куплены у поставщика гамма-мебель, ооо","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","counterparty":"Гамма-мебель, ООО","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":41,"rows_materialized":500,"rows_matched":41,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 31.03.2020.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 13.05.2019.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 11.\n- Закупочных операций в выборке: 41.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 41.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n3. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n4. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 28.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n5. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 199.671,66 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n6. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 159.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n7. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 23.660,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 62.150,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n9. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 16.880,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n10. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 75.075,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-zG_fxTpJic"}} +{"timestamp":"2026-04-14T08:29:07.725Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-JnmDYV3eYC","eventType":"assistant_message_address","details":{"session_id":"asst-JnmDYV3eYC","message_id":"msg-eBxZlpNl6h","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"J-v1hBUj94hGhK","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-GDVRZfnM-Q"}} +{"timestamp":"2026-04-14T08:29:14.566Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-JnmDYV3eYC","eventType":"assistant_message_address","details":{"session_id":"asst-JnmDYV3eYC","message_id":"msg-oa7o28klrB","user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","effective_address_user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"8JxV44_oIGwBtZ","address_llm_predecompose_reason":"normalized_fragment_rejected_semantic_guard","address_fallback_rule_hit":null,"address_sanitized_user_message":"относится ли товар шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_aging_by_purchase_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_aging_by_purchase_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_aging_by_purchase_date","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2020-03-31"},"selected_recipe":null,"mcp_call_status_legacy":"skipped","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":null,"resolver_confidence":null,"match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"skipped","rows_fetched":0,"raw_rows_received":0,"rows_after_account_scope":0,"rows_after_recipe_filter":0,"rows_materialized":0,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"DEEP_ONLY","limited_reason_category":"unsupported","response_type":"LIMITED_WITH_REASON","limitations":["capability_route_disabled_by_flag"],"assistant_reply":"Сейчас не дам прямой адресный ответ, чтобы не ошибиться в выводах.\n\nДля этого запроса пока нет надежного ответа в текущем адресном режиме.\n\nКонтекст запроса: срез на 2020-03-31.","reply_type":"partial_coverage","trace_id":"address-CpgqiHy5Uo"}} +{"timestamp":"2026-04-14T08:29:22.734Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-JnmDYV3eYC","eventType":"assistant_message_address","details":{"session_id":"asst-JnmDYV3eYC","message_id":"msg-F5IPKJSpRX","user_message":"Есть ли на складе Основной склад товары с остатком без понятной привязки к поставщику","effective_address_user_message":"Есть ли на складе Основной склад товары с остатком без понятной привязки к поставщику","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"1im0WhjrpL1Fqj","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли на складе основной склад товары с остатком без понятной привязки к поставщику","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract","deep_investigation_signal_detected"],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад товары","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":487,"rows_materialized":500,"rows_matched":487,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 90.\n- Закупочных операций в выборке: 487.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 464.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-n5z6Mus8Vm"}} +{"timestamp":"2026-04-14T08:29:30.055Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-JnmDYV3eYC","eventType":"assistant_message_address","details":{"session_id":"asst-JnmDYV3eYC","message_id":"msg-kFK8lhiC8X","user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","effective_address_user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"qv1PZnOGPsHfEg","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли среди текущих остатков на складе основной склад позиции, закупленные задолго до 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-tVWfmtGMr_"}} +{"timestamp":"2026-04-14T08:29:36.167Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-MQkyipNNl9","eventType":"assistant_message_address","details":{"session_id":"asst-MQkyipNNl9","message_id":"msg-2QrXzS0y1n","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31 на складе Основной склад","effective_address_user_message":"Получить список товаров, находящихся на счете 41 на дату 2020-03-31 для склада 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"eXTkzlQmDxhBwJ","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31 на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-Quj7DIn9Tw"}} +{"timestamp":"2026-04-14T08:29:43.219Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-MQkyipNNl9","eventType":"assistant_message_address","details":{"session_id":"asst-MQkyipNNl9","message_id":"msg-1CE9SWhQML","user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","effective_address_user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"lDHIcgLwDAdm0_","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"кому был продан товар шкаф картотечный 1000*400*2100","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_sale_trace_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_sale_trace_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_sale_trace_for_item","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_sale_trace_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный след выбытия по товару товар до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные движения выбытия товара со счета 41.01.\n\nБлок 2. Сводка\n- Первая найденная дата выбытия: 01.04.2020.\n- Последняя найденная дата выбытия: 01.04.2020.\n- Документов выбытия: 1.\n- Операций выбытия: 1.\n- Документы выбытия найдены, но покупатель не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Документы выбытия\n1. Реализация товаров и услуг 00000000001 от 01.04.2020 0:00:00 | дата: 01.04.2020 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-DSeQhu97L5"}} +{"timestamp":"2026-04-14T08:29:52.640Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-MQkyipNNl9","eventType":"assistant_message_address","details":{"session_id":"asst-MQkyipNNl9","message_id":"msg-3bG-10Pjzk","user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","effective_address_user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"ZlpxLsr8Sxn0kW","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"через какие документы прошел путь товара шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_to_sale_chain","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_to_sale_chain","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_to_sale_chain_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":600,"raw_rows_received":600,"rows_after_account_scope":600,"rows_after_recipe_filter":2,"rows_materialized":600,"rows_matched":2,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собрана документальная цепочка по товару Шкаф картотечный 1000*400*2100 до 14.04.2026.\n\nБлок 1. Статус результата\n- Закупочных движений на 41.01: 1.\n- Движений выбытия со счета 41.01: 1.\n- В текущем контуре найдены обе стороны цепочки: поступление и последующее выбытие.\n\nБлок 2. Закупка\n- Первая дата: 10.12.2019.\n- Последняя дата: 10.12.2019.\n1. Поступление товаров и услуг 00000000111 от 10.12.2019 12:00:01 | дата: 10.12.2019 | сумма: 712.500,00 ₽ | склад: Основной склад\n\nБлок 3. Выбытие\n- Первая дата: 01.04.2020.\n- Последняя дата: 01.04.2020.\n1. Реализация товаров и услуг 00000000001 от 01.04.2020 0:00:00 | дата: 01.04.2020 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-4p33jQdMem"}} +{"timestamp":"2026-04-14T08:30:02.711Z","level":"info","service":"assistant_loop","message":"assistant_address_tool_gate_skip","sessionId":"asst-MQkyipNNl9","details":{"session_id":"asst-MQkyipNNl9","user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","effective_address_user_message":"Проверить наличие документально подтвержденной цепочки: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотечный 1000*400*2100 -> покупатель департамент капитального ремонта города москвы","assistant_orchestration_contract_v1":{"schema_version":"assistant_orchestration_contract_v1","hard_meta_mode":null,"address_mode":"deep_analysis","address_mode_confidence":"high","address_intent":"inventory_purchase_to_sale_chain","address_intent_confidence":"medium","strong_data_signal_detected":true,"data_retrieval_signal_detected":true,"semantic_contract_valid":true,"semantic_apply_canonical_recommended":true,"semantic_reason_codes":["deep_investigation_signal_detected"],"semantic_route_arbitration":{"supported_address_intent_detected":false,"semantic_deep_investigation_hint_detected":true,"semantic_aggregate_shape_detected":false,"followup_semantic_override_to_deep_allowed":false},"followup_context_detected":false,"unsupported_address_intent_fallback_to_deep":false,"deep_analysis_signal_fallback_to_deep":true,"aggregate_analytics_signal_fallback_to_deep":false,"deep_session_continuation_fallback_to_deep":false,"final_decision":{"run_address_lane":false,"tool_gate_decision":"skip_address_lane","tool_gate_reason":"deep_analysis_signal_fallback_to_deep","living_mode":"deep_analysis","living_reason":"deep_analysis_signal_fallback_to_deep"}},"address_tool_gate_decision":"skip_address_lane","address_tool_gate_reason":"deep_analysis_signal_fallback_to_deep","address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["deep_investigation_signal_detected"]}} +{"timestamp":"2026-04-14T08:30:22.464Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-MQkyipNNl9","eventType":"assistant_message","details":{"session_id":"asst-MQkyipNNl9","message_id":"msg-iJNiWo6KAV","user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","normalizer_output":null,"execution_plan":[],"resolved_execution_state":[],"routes":[],"retrieval_calls":[],"retrieval_results_raw":[],"retrieval_results_normalized":[],"requirements_extracted":[{"requirement_id":"R1","source_fragment_id":null,"requirement_text":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","subject_tokens":["counterparty","document","chain"],"status":"clarification_needed","route":null}],"requirements_total":1,"requirements_covered":0,"requirements_uncovered":[],"coverage_status":"partial_or_limited","answer_grounding_status":"no_grounded_answer","reply_semantic_type":"clarification_required","why_included_summary":[],"selection_reason_summary":[],"route_subject_match":true,"clarification_target":["R1"],"dropped_intent_segments":[],"question_type_class":"unknown","company_anchors":{"contract_numbers":[],"document_numbers":[],"dates":[],"amounts":[],"accounts":[],"periods":[],"document_types":[],"all":[]},"analysis_context_applied":true,"analysis_context":{"as_of_date":"2026-04-13","period_from":null,"period_to":null,"source":"scenario_pack","snapshot_mode":"auto"},"business_scope_raw":[],"business_scope_resolved":["company_specific_accounting"],"company_grounding_applied":true,"scope_resolution_reason":["settlement_claim_company_scope_recovery"],"company_scope_resolution_reason":["settlement_claim_company_scope_recovery"],"raw_time_anchor":"2026-04-13","raw_time_scope":"2026-04-13..2026-04-13","resolved_time_anchor":"2026-04-13","resolved_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"effective_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"temporal_guard_input":"2026-04-13..2026-04-13","temporal_alignment_status":"aligned","temporal_resolution_source":"scenario_pack","temporal_guard_basis":"raw_time_scope_unlocked","temporal_guard_applied":false,"temporal_guard_outcome":"passed","temporal_guard":{"raw_time_anchor":"2026-04-13","raw_time_scope":"2026-04-13..2026-04-13","resolved_time_anchor":"2026-04-13","resolved_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"effective_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"temporal_guard_input":"2026-04-13..2026-04-13","temporal_alignment_status":"aligned","temporal_resolution_source":"scenario_pack","temporal_guard_basis":"raw_time_scope_unlocked","temporal_guard_applied":false,"temporal_guard_outcome":"passed","primary_period_window":null,"allowed_context_window":null,"controlled_temporal_expansion_enabled":false,"context_expansion_reasons_allowed":["prehistory","carryover","post_period_closure","long_running_contract_context"],"normalized_anchor_drift_detected":false,"reason_codes":["analysis_context_applied"]},"raw_numeric_tokens":["1000","400","2100"],"classified_numeric_tokens":[],"rejected_as_non_accounts":[],"resolved_account_anchors":[],"domain_polarity_guard":{"applied":true,"polarity":"mixed_or_unresolved","outcome":"limited_unresolved_polarity","supplier_score":2,"customer_score":2,"account_scope":[],"raw_numeric_tokens":["1000","400","2100"],"classified_numeric_tokens":[],"rejected_as_non_accounts":[],"resolved_account_anchors":[],"rejected_problem_units":0,"rejected_evidence":0,"critical_contradiction":true,"reason_codes":["unresolved_supplier_customer_polarity","supplier_customer_signals_conflict"]},"claim_anchor_audit":{"claim_type":"prove_settlement_closure_state","settlement_role":"mixed","settlement_role_resolution_reason":["settlement_role_resolved_mixed"],"polarity_resolution_status":"mixed","required_anchors":["period","account_scope","counterparty_scope_or_contract","closure_signal"],"resolved_anchors":{"period":["2026-04-13"],"account_scope":[],"amounts":[],"contract":[],"document_numbers":[],"document_types":[],"counterparty_scope":["supplier","customer"],"advance_signal":[],"closure_signal":[],"vat_signal":[],"chain_signal":[],"close_signal":[],"cost_scope":[],"rbp_signal":[],"writeoff_signal":[],"fixed_asset_signal":[],"amortization_signal":[],"expected_fa_set":[],"actual_fa_set":[]},"missing_anchors":["account_scope","closure_signal"],"claim_anchor_resolution_rate":0.5,"primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"allowed_context_window":{"from":"2025-04-13","to":"2027-04-13","granularity":"month"},"context_expansion_reasons_allowed":["prehistory","carryover","post_period_closure","long_running_contract_context"],"reason_codes":["claim_missing_required_anchors","claim_anchor_resolution_low","unresolved_supplier_customer_polarity"]},"settlement_role":"mixed","settlement_role_resolution_reason":["settlement_role_resolved_mixed"],"polarity_resolution_status":"mixed","targeted_evidence_acquisition":{"claim_type":"prove_settlement_closure_state","required_checks":["payment_document_found","contract_matched","settlement_object_matched","closing_document_found","register_closure_entry_found","posting_link_found"],"check_status":{"payment_document_found":"not_found","contract_matched":"not_found","settlement_object_matched":"not_found","closing_document_found":"not_found","register_closure_entry_found":"not_found","posting_link_found":"not_found"},"targeted_item_hits":0,"targeted_evidence_hits":0,"targeted_evidence_hit_rate":0,"targeted_evidence_source_refs":[],"reason_codes":["targeted_evidence_not_found","targeted_evidence_hit_rate_low"]},"evidence_admissibility_gate":{"candidate_evidence_total":0,"admissible_evidence_count":0,"rejected_evidence_count":0,"rejected_item_count":0,"reject_breakdown":{"wrong_period":0,"wrong_domain":0,"wrong_account_scope":0,"weak_source_mapping":0,"zero_live_match":0,"future_dated_or_out_of_window":0},"category_breakdown":{"hard_evidence":0,"supporting_signal":0,"inadmissible_noise":0},"reason_codes":["no_admissible_evidence_for_grounded_answer"]},"eligibility_time_basis":"raw_time_scope_unlocked","grounded_answer_eligibility_guard":{"eligible":false,"temporal_passed":true,"eligibility_time_basis":"raw_time_scope_unlocked","business_scope_passed":true,"polarity_passed":false,"claim_anchors_passed":true,"claim_anchor_resolution_rate":0.5,"missing_required_anchors":2,"admissible_evidence_count":0,"critical_contradiction":true,"outcome":"limited_or_insufficient_evidence","grounding_mode":"limited_or_insufficient_evidence","reason_codes":["polarity_guard_limited_unresolved_polarity","admissible_evidence_count_zero","targeted_evidence_hit_rate_zero","critical_domain_or_account_contradiction"]},"problem_centric_answer_applied":false,"problem_units_used_count":0,"problem_answer_mode":"stage1_policy_v11","assistant_outcome_class_v1":"BLOCKED_BY_AMBIGUITY","assistant_orchestration_contracts_v1":{"query_frame":{"schema_version":"assistant_query_frame_v1","original_user_question":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","normalized_question":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","route_summary_mode":"none","fragments_total":0,"dropped_intent_segments":[],"analysis_context":{"as_of_date":"2026-04-13","period_from":null,"period_to":null,"source":"scenario_pack","snapshot_mode":"auto"}},"execution_plan":{"schema_version":"assistant_execution_plan_v1","steps":[],"requirements_total":1},"evidence_bundle":{"schema_version":"assistant_evidence_bundle_v1","retrieval_calls_total":0,"retrieval_results_total":0,"retrieval_status_breakdown":{"ok":0,"partial":0,"empty":0,"error":0},"evidence_total":0,"source_refs_total":0,"limitation_total":0,"error_total":0},"coverage":{"schema_version":"assistant_coverage_contract_v1","coverage_report":{"requirements_total":1,"requirements_covered":0,"requirements_uncovered":[],"requirements_partially_covered":[],"clarification_needed_for":["R1"],"out_of_scope_requirements":[]},"grounding":{"status":"no_grounded_answer","route_subject_match":true,"missing_requirements":["R1"],"reasons":["Ни одно требование не получило подтвержденного покрытия.","В текущей выборке не хватает явных подтверждений, почему записи попали в ответ.","Часть контекста вопроса не подтверждена напрямую в найденных данных: counterparty, document, chain","Не удалось однозначно определить сторону расчета (нам должны или мы должны).","Недостаточно подтвержденных данных для уверенного ответа.","Не хватило целевых подтверждений по выбранному сценарию.","Есть противоречие по выбранному домену или контуру счета."],"why_included_summary":[],"selection_reason_summary":[]},"outcome_class":"BLOCKED_BY_AMBIGUITY"}},"answer_contract_stage4_v1":{"schema_version":"stage4_answer_contract_audit_v1","stage4_blocks_expected":["Коротко","Что именно проверено","Что найдено","Что пока не доказано","Что проверить первым/Что могу сделать сейчас"],"stage4_blocks_present":["Коротко","Что именно проверено","Что найдено","Что пока не доказано","Что проверить первым/Что могу сделать сейчас"],"stage4_blocks_missing":[],"legacy_blocks_present":[],"is_stage4_shape":true},"answer_structure_v11":{"schema_version":"answer_structure_v1_1","answer_summary":"Нужны уточнения: без сужения фокуса надежный вывод невозможен.","direct_answer":"Есть признаки проблемы, но без уточнений по периоду и объекту вывод ненадежен.","mechanism_block":{"status":"unresolved","mechanism_notes":[],"limitation_reason_codes":[]},"evidence_block":{"evidence_ids":[],"source_refs":[],"mechanism_notes":[],"coverage_note":"coverage_partial_or_limited"},"uncertainty_block":{"open_uncertainties":["R1","missing_anchor:period","missing_anchor:account","missing_anchor:counterparty"],"limitations":["Ни одно требование не получило подтвержденного покрытия.","В текущей выборке не хватает явных подтверждений, почему записи попали в ответ.","Часть контекста вопроса не подтверждена напрямую в найденных данных: counterparty, document, chain","Не удалось однозначно определить сторону расчета (нам должны или мы должны).","Недостаточно подтвержденных данных для уверенного ответа.","Не хватило целевых подтверждений по выбранному сценарию.","Есть противоречие по выбранному домену или контуру счета."]},"next_step_block":{"recommended_actions":["Дайте недостающие якоря (период/счет/объект), иначе сильный factual вывод невозможен."],"clarification_questions":["Уточните период проверки (например, июль 2020).","Уточните счет или группу счетов (например, 19, 60, 62).","Укажите контрагента или группу контрагентов.","Закройте уточнения для требований: R1."]}},"investigation_state_snapshot":{"schema_version":"investigation_state_v1","session_id":"asst-MQkyipNNl9","status":"active","turn_index":1,"updated_at":"2026-04-14T08:30:22.461Z","question_id":"msg-RuVPhlKCz-","question_scope_id":"d:settlements_60_62|s:есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотеч","scope_origin":"explicit_from_message","focus":{"domain":"settlements_60_62","period":null,"primary_accounts":[],"active_query_subject":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы"},"narrowing_status":"unknown","evidence_refs":[],"open_uncertainties":["clarify:R1"],"last_answer_mode":"clarification_required","followup_context":{"previous_question_id":null,"last_user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","referenced_requirement_ids":["R1"],"active_domain":"settlements_60_62","active_requirement_ids":["R1"],"uncovered_requirement_ids":["R1"],"last_problem_unit_id":null,"settlement_next_actions":["Проверьте договор и объект расчетов по платежу.","Сверьте регистр расчетов и привязку платежа к закрывающему документу.","Проверьте зачет аванса или взаимозачет по связке 60/62."],"evidence_summary":[],"question_scope_id":"d:settlements_60_62|s:есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотеч","scope_origin":"explicit_from_message"},"query_mode_hint":"investigation_candidate"},"fallback_type":"clarification","assistant_reply":"Коротко: По этому запросу у меня нет надежного доменного покрытия, поэтому даю мягкий отказ вместо технического шаблона.\n\nЧто именно проверено:\n- Проверен доступный контур 1С и возможность маршрутизации запроса.\n- Надежный доменный путь для текущей формулировки не подтвержден.\n\nЧто найдено:\n- Взаиморасчеты 60/62: найти хвосты, незакрытые оплаты и рисковые связки по контрагентам.\n- НДС 19/68: проверить цепочку документ -> счет-фактура -> регистр -> книга.\n- Закрытие месяца 20/44: проверить распределение затрат и остатки после регламентных операций.\n\nЧто пока не доказано:\n- Запрос не подтвержден в поддерживаемом контуре как надежный бухгалтерский сценарий.\n\nЧто могу сделать сейчас:\n- Взаиморасчеты 60/62 — найти хвосты, незакрытые оплаты и рисковые связки по контрагентам.\n- НДС 19/68 — проверить цепочку документ -> счет-фактура -> регистр -> книга.\n- Закрытие месяца 20/44 — проверить распределение затрат и остатки после регламентных операций.","reply_type":"clarification_required","trace_id":"xyJUh372ge9qh1"}} +{"timestamp":"2026-04-14T08:34:30.376Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Y9TZvi-Pzr","eventType":"assistant_message_address","details":{"session_id":"asst-Y9TZvi-Pzr","message_id":"msg-ESebMt70B5","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"GrqJww3EvZvSLX","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-mqsUrTMu7F"}} +{"timestamp":"2026-04-14T08:34:36.476Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Y9TZvi-Pzr","eventType":"assistant_message_address","details":{"session_id":"asst-Y9TZvi-Pzr","message_id":"msg-4A5R0WV9Xw","user_message":"Из каких товаров состоит остаток по 41 счету","effective_address_user_message":"Из каких товаров состоит остаток по 41 счету","address_followup_context_applied":true,"address_followup_context_previous_intent":"inventory_on_hand_as_of_date","address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"A3386bpeghy_s3","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"из каких товаров состоит остаток по 41 счету","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"continue_previous","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-QWPf8MYmov"}} +{"timestamp":"2026-04-14T08:34:42.553Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Y9TZvi-Pzr","eventType":"assistant_message_address","details":{"session_id":"asst-Y9TZvi-Pzr","message_id":"msg-lc5pj3hkCd","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31","effective_address_user_message":"Получить список товаров, находящихся на счете 41 на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"YZz-I_jlvImCse","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-CW53RbrW8R"}} +{"timestamp":"2026-04-14T08:34:48.686Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Y9TZvi-Pzr","eventType":"assistant_message_address","details":{"session_id":"asst-Y9TZvi-Pzr","message_id":"msg-WGAzfMHdK-","user_message":"Какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","effective_address_user_message":"Получить список номенклатур, формирующих остаток на складе на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"8Xt26f6Rry3gBf","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-53UkS0GidV"}} +{"timestamp":"2026-04-14T08:34:54.788Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Z3DbIol4MP","eventType":"assistant_message_address","details":{"session_id":"asst-Z3DbIol4MP","message_id":"msg-SGT7p0LMRv","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"BXPi-QwDzX636G","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-eXk5Z66z43"}} +{"timestamp":"2026-04-14T08:35:02.686Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Z3DbIol4MP","eventType":"assistant_message_address","details":{"session_id":"asst-Z3DbIol4MP","message_id":"msg-Rhuz5qTwtp","user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"ifKq3XVajB1eNL","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"от какого поставщика куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный закупочный след по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные закупочные движения на 41.01 по выбранному товару.\n- Важно: без партионности этот контур не подменяет собой лот-level доказательство происхождения текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 24.08.2018.\n- Последняя найденная дата закупочного движения: 24.08.2018.\n- Документов поступления: 1.\n- Операций поступления: 1.\n- Закупочные документы найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Опорные документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-ytaDZ84IIZ"}} +{"timestamp":"2026-04-14T08:35:11.036Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Z3DbIol4MP","eventType":"assistant_message_address","details":{"session_id":"asst-Z3DbIol4MP","message_id":"msg-f-L86kPgn7","user_message":"У какого поставщика были куплены товары, которые сейчас лежат на складе Основной склад организации ООО \\Альтернатива Плюс\\","effective_address_user_message":"Определить поставщиков, у которых были приобретены товары, находящиеся на складе 'Основной склад' в компании 'ООО Альтернатива Плюс'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"qU3D0g7UWeNk84","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"у какого поставщика были куплены товары, которые сейчас лежат на складе основной склад организации ооо \\альтернатива плюс\\","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-E-oMyz3XMk"}} +{"timestamp":"2026-04-14T08:35:18.238Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Z3DbIol4MP","eventType":"assistant_message_address","details":{"session_id":"asst-Z3DbIol4MP","message_id":"msg-udmALIFmgK","user_message":"По какому поставщику проходит текущий товарный остаток на складе Основной склад","effective_address_user_message":"Получить информацию о поставщике, связанным с текущим товарным остатком на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"yW4LuX0gu2cn44","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"по какому поставщику проходит текущий товарный остаток на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-odLd0bBNoj"}} +{"timestamp":"2026-04-14T08:35:26.260Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Z3DbIol4MP","eventType":"assistant_message_address","details":{"session_id":"asst-Z3DbIol4MP","message_id":"msg-ChMvIrc7aY","user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"tVI5RNaHDcXcrR","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"когда был куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный закупочный след по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные закупочные движения на 41.01 по выбранному товару.\n- Важно: без партионности этот контур не подменяет собой лот-level доказательство происхождения текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 24.08.2018.\n- Последняя найденная дата закупочного движения: 24.08.2018.\n- Документов поступления: 1.\n- Операций поступления: 1.\n- Закупочные документы найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Опорные документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-c0pGwHoNeA"}} +{"timestamp":"2026-04-14T08:35:34.479Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Z3DbIol4MP","eventType":"assistant_message_address","details":{"session_id":"asst-Z3DbIol4MP","message_id":"msg-5CFZfCBgz4","user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","effective_address_user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"qtu_JiOUpa_-Zu","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"по каким документам был куплен товар диван трехместный для остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_documents_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_documents_for_item","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_documents_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный для остатка на складе Основной склад","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_documents_for_item_v1","mcp_call_status_legacy":"materialized_but_not_matched","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"materialized_but_not_anchor_matched","match_failure_reason":"item_anchor_not_matched_in_materialized_rows","mcp_call_status":"materialized_but_not_anchor_matched","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":0,"rows_materialized":400,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":"empty_match","response_type":"LIMITED_WITH_REASON","limitations":["no_rows_for_anchor_after_materialization"],"assistant_reply":"По заданным фильтрам в текущем срезе совпадений пока нет.\n\nпо указанному якорю и фильтрам в выборке данных нет строк.\n\nСигнал запроса: список документов/операций.\n\nКонтекст запроса: срез на 2026-04-14.\n\nЧто могу сделать сейчас: показать документы поступления по товару на 41.01; показать документы/платежи по контрагенту или договору; показать незакрытые договоры или хвосты на дату.","reply_type":"partial_coverage","trace_id":"address-0JRsqyeuVp"}} +{"timestamp":"2026-04-14T08:35:41.539Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Z3DbIol4MP","eventType":"assistant_message_address","details":{"session_id":"asst-Z3DbIol4MP","message_id":"msg-0aTCJUOABJ","user_message":"Какие товары от поставщика Гамма-мебель, ООО сейчас еще лежат на складе Основной склад","effective_address_user_message":"Получить информацию о товарах от поставщика 'Гамма-мебель, ООО', которые находятся на складе 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"28rhleegxkGcsp","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары от поставщика гамма-мебель, ооо сейчас еще лежат на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","counterparty":"Гамма-мебель, ООО',","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":41,"rows_materialized":500,"rows_matched":41,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 13.05.2019.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 11.\n- Закупочных операций в выборке: 41.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 41.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n3. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n4. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 28.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n5. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 199.671,66 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n6. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 62.150,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n7. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 16.880,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 159.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n9. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 23.660,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n10. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 75.075,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-8RoU1C8DD6"}} +{"timestamp":"2026-04-14T08:35:49.702Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Z3DbIol4MP","eventType":"assistant_message_address","details":{"session_id":"asst-Z3DbIol4MP","message_id":"msg-Vr5KglanxV","user_message":"Какие товары по состоянию на дату 2020-03-31 на складе Основной склад были куплены у поставщика Гамма-мебель, ООО","effective_address_user_message":"Список товаров на складе 'Основной склад' по состоянию на 2020-03-31, приобретенных у поставщика 'Гамма-мебель, ООО'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"ySXHBIKt4-ZPo8","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары по состоянию на дату 2020-03-31 на складе основной склад были куплены у поставщика гамма-мебель, ооо","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","counterparty":"Гамма-мебель, ООО","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":41,"rows_materialized":500,"rows_matched":41,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 31.03.2020.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 13.05.2019.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 11.\n- Закупочных операций в выборке: 41.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 41.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n3. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n4. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 28.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n5. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 199.671,66 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n6. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 159.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n7. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 23.660,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 62.150,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n9. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 16.880,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n10. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 75.075,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-p2FkfxhGba"}} +{"timestamp":"2026-04-14T08:35:56.005Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-qqG_1iVzQY","eventType":"assistant_message_address","details":{"session_id":"asst-qqG_1iVzQY","message_id":"msg-aYpH2Gi2tp","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"SQfC_9-TQwC9wC","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-IDaSE74qa8"}} +{"timestamp":"2026-04-14T08:36:02.815Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-qqG_1iVzQY","eventType":"assistant_message_address","details":{"session_id":"asst-qqG_1iVzQY","message_id":"msg-OM53e0ghEh","user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","effective_address_user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"Pyv_bKwn_QlY0w","address_llm_predecompose_reason":"normalized_fragment_rejected_semantic_guard","address_fallback_rule_hit":null,"address_sanitized_user_message":"относится ли товар шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_aging_by_purchase_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_aging_by_purchase_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_aging_by_purchase_date","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2020-03-31"},"selected_recipe":null,"mcp_call_status_legacy":"skipped","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":null,"resolver_confidence":null,"match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"skipped","rows_fetched":0,"raw_rows_received":0,"rows_after_account_scope":0,"rows_after_recipe_filter":0,"rows_materialized":0,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"DEEP_ONLY","limited_reason_category":"unsupported","response_type":"LIMITED_WITH_REASON","limitations":["capability_route_disabled_by_flag"],"assistant_reply":"Сейчас не дам прямой адресный ответ, чтобы не ошибиться в выводах.\n\nДля этого запроса пока нет надежного ответа в текущем адресном режиме.\n\nКонтекст запроса: срез на 2020-03-31.","reply_type":"partial_coverage","trace_id":"address-lPH7eM1xhJ"}} +{"timestamp":"2026-04-14T08:36:10.017Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-qqG_1iVzQY","eventType":"assistant_message_address","details":{"session_id":"asst-qqG_1iVzQY","message_id":"msg-Exx2Bur7H0","user_message":"Есть ли на складе Основной склад товары с остатком без понятной привязки к поставщику","effective_address_user_message":"Проверить наличие товаров на Основном складе с остатками, у которых нет ясной привязки к поставщику.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"8yaNT5VY4updzW","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли на складе основной склад товары с остатком без понятной привязки к поставщику","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract","deep_investigation_signal_detected"],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-SuVTH3eckj"}} +{"timestamp":"2026-04-14T08:36:16.278Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-qqG_1iVzQY","eventType":"assistant_message_address","details":{"session_id":"asst-qqG_1iVzQY","message_id":"msg-Wi7cPV8qGv","user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","effective_address_user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"0UEurv4f8fw7eG","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли среди текущих остатков на складе основной склад позиции, закупленные задолго до 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-RdbaLdEZrS"}} +{"timestamp":"2026-04-14T08:36:22.395Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-rhwrLRxdid","eventType":"assistant_message_address","details":{"session_id":"asst-rhwrLRxdid","message_id":"msg-C6eS0jyhiS","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31 на складе Основной склад","effective_address_user_message":"Получить список товаров, находящихся на 41 счете по состоянию на 2020-03-31 для склада 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"jz28LNoTGv7V0i","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31 на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-z_4iHkonRi"}} +{"timestamp":"2026-04-14T08:36:29.417Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-rhwrLRxdid","eventType":"assistant_message_address","details":{"session_id":"asst-rhwrLRxdid","message_id":"msg-o4KWLQOyUz","user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","effective_address_user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"xW9rZtmtQYzTyn","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"кому был продан товар шкаф картотечный 1000*400*2100","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_sale_trace_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_sale_trace_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_sale_trace_for_item","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_sale_trace_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный след выбытия по товару товар до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные движения выбытия товара со счета 41.01.\n\nБлок 2. Сводка\n- Первая найденная дата выбытия: 01.04.2020.\n- Последняя найденная дата выбытия: 01.04.2020.\n- Документов выбытия: 1.\n- Операций выбытия: 1.\n- Документы выбытия найдены, но покупатель не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Документы выбытия\n1. Реализация товаров и услуг 00000000001 от 01.04.2020 0:00:00 | дата: 01.04.2020 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-FwBTXSvvNk"}} +{"timestamp":"2026-04-14T08:36:38.599Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-rhwrLRxdid","eventType":"assistant_message_address","details":{"session_id":"asst-rhwrLRxdid","message_id":"msg-y4qbFeZrof","user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","effective_address_user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"ayEZJ99_h5gd48","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"через какие документы прошел путь товара шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_to_sale_chain","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_to_sale_chain","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_to_sale_chain_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":600,"raw_rows_received":600,"rows_after_account_scope":600,"rows_after_recipe_filter":2,"rows_materialized":600,"rows_matched":2,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собрана документальная цепочка по товару Шкаф картотечный 1000*400*2100 до 14.04.2026.\n\nБлок 1. Статус результата\n- Закупочных движений на 41.01: 1.\n- Движений выбытия со счета 41.01: 1.\n- В текущем контуре найдены обе стороны цепочки: поступление и последующее выбытие.\n\nБлок 2. Закупка\n- Первая дата: 10.12.2019.\n- Последняя дата: 10.12.2019.\n1. Поступление товаров и услуг 00000000111 от 10.12.2019 12:00:01 | дата: 10.12.2019 | сумма: 712.500,00 ₽ | склад: Основной склад\n\nБлок 3. Выбытие\n- Первая дата: 01.04.2020.\n- Последняя дата: 01.04.2020.\n1. Реализация товаров и услуг 00000000001 от 01.04.2020 0:00:00 | дата: 01.04.2020 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-uFTnw_HkvF"}} +{"timestamp":"2026-04-14T08:36:48.252Z","level":"info","service":"assistant_loop","message":"assistant_address_tool_gate_skip","sessionId":"asst-rhwrLRxdid","details":{"session_id":"asst-rhwrLRxdid","user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","effective_address_user_message":"Проверить наличие документально подтвержденной цепочки: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотечный 1000*400*2100 -> покупатель департамент капитального ремонта города москвы","assistant_orchestration_contract_v1":{"schema_version":"assistant_orchestration_contract_v1","hard_meta_mode":null,"address_mode":"deep_analysis","address_mode_confidence":"high","address_intent":"inventory_purchase_to_sale_chain","address_intent_confidence":"medium","strong_data_signal_detected":true,"data_retrieval_signal_detected":true,"semantic_contract_valid":true,"semantic_apply_canonical_recommended":true,"semantic_reason_codes":["deep_investigation_signal_detected"],"semantic_route_arbitration":{"supported_address_intent_detected":false,"semantic_deep_investigation_hint_detected":true,"semantic_aggregate_shape_detected":false,"followup_semantic_override_to_deep_allowed":false},"followup_context_detected":false,"unsupported_address_intent_fallback_to_deep":false,"deep_analysis_signal_fallback_to_deep":true,"aggregate_analytics_signal_fallback_to_deep":false,"deep_session_continuation_fallback_to_deep":false,"final_decision":{"run_address_lane":false,"tool_gate_decision":"skip_address_lane","tool_gate_reason":"deep_analysis_signal_fallback_to_deep","living_mode":"deep_analysis","living_reason":"deep_analysis_signal_fallback_to_deep"}},"address_tool_gate_decision":"skip_address_lane","address_tool_gate_reason":"deep_analysis_signal_fallback_to_deep","address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["deep_investigation_signal_detected"]}} +{"timestamp":"2026-04-14T08:37:07.743Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-rhwrLRxdid","eventType":"assistant_message","details":{"session_id":"asst-rhwrLRxdid","message_id":"msg-HRNTSQGgke","user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","normalizer_output":null,"execution_plan":[],"resolved_execution_state":[],"routes":[],"retrieval_calls":[],"retrieval_results_raw":[],"retrieval_results_normalized":[],"requirements_extracted":[{"requirement_id":"R1","source_fragment_id":null,"requirement_text":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","subject_tokens":["counterparty","document","chain"],"status":"clarification_needed","route":null}],"requirements_total":1,"requirements_covered":0,"requirements_uncovered":[],"coverage_status":"partial_or_limited","answer_grounding_status":"no_grounded_answer","reply_semantic_type":"clarification_required","why_included_summary":[],"selection_reason_summary":[],"route_subject_match":true,"clarification_target":["R1"],"dropped_intent_segments":[],"question_type_class":"unknown","company_anchors":{"contract_numbers":[],"document_numbers":[],"dates":[],"amounts":[],"accounts":[],"periods":[],"document_types":[],"all":[]},"analysis_context_applied":true,"analysis_context":{"as_of_date":"2026-04-13","period_from":null,"period_to":null,"source":"scenario_pack","snapshot_mode":"auto"},"business_scope_raw":[],"business_scope_resolved":["company_specific_accounting"],"company_grounding_applied":true,"scope_resolution_reason":["settlement_claim_company_scope_recovery"],"company_scope_resolution_reason":["settlement_claim_company_scope_recovery"],"raw_time_anchor":"2026-04-13","raw_time_scope":"2026-04-13..2026-04-13","resolved_time_anchor":"2026-04-13","resolved_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"effective_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"temporal_guard_input":"2026-04-13..2026-04-13","temporal_alignment_status":"aligned","temporal_resolution_source":"scenario_pack","temporal_guard_basis":"raw_time_scope_unlocked","temporal_guard_applied":false,"temporal_guard_outcome":"passed","temporal_guard":{"raw_time_anchor":"2026-04-13","raw_time_scope":"2026-04-13..2026-04-13","resolved_time_anchor":"2026-04-13","resolved_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"effective_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"temporal_guard_input":"2026-04-13..2026-04-13","temporal_alignment_status":"aligned","temporal_resolution_source":"scenario_pack","temporal_guard_basis":"raw_time_scope_unlocked","temporal_guard_applied":false,"temporal_guard_outcome":"passed","primary_period_window":null,"allowed_context_window":null,"controlled_temporal_expansion_enabled":false,"context_expansion_reasons_allowed":["prehistory","carryover","post_period_closure","long_running_contract_context"],"normalized_anchor_drift_detected":false,"reason_codes":["analysis_context_applied"]},"raw_numeric_tokens":["1000","400","2100"],"classified_numeric_tokens":[],"rejected_as_non_accounts":[],"resolved_account_anchors":[],"domain_polarity_guard":{"applied":true,"polarity":"mixed_or_unresolved","outcome":"limited_unresolved_polarity","supplier_score":2,"customer_score":2,"account_scope":[],"raw_numeric_tokens":["1000","400","2100"],"classified_numeric_tokens":[],"rejected_as_non_accounts":[],"resolved_account_anchors":[],"rejected_problem_units":0,"rejected_evidence":0,"critical_contradiction":true,"reason_codes":["unresolved_supplier_customer_polarity","supplier_customer_signals_conflict"]},"claim_anchor_audit":{"claim_type":"prove_settlement_closure_state","settlement_role":"mixed","settlement_role_resolution_reason":["settlement_role_resolved_mixed"],"polarity_resolution_status":"mixed","required_anchors":["period","account_scope","counterparty_scope_or_contract","closure_signal"],"resolved_anchors":{"period":["2026-04-13"],"account_scope":[],"amounts":[],"contract":[],"document_numbers":[],"document_types":[],"counterparty_scope":["supplier","customer"],"advance_signal":[],"closure_signal":[],"vat_signal":[],"chain_signal":[],"close_signal":[],"cost_scope":[],"rbp_signal":[],"writeoff_signal":[],"fixed_asset_signal":[],"amortization_signal":[],"expected_fa_set":[],"actual_fa_set":[]},"missing_anchors":["account_scope","closure_signal"],"claim_anchor_resolution_rate":0.5,"primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"allowed_context_window":{"from":"2025-04-13","to":"2027-04-13","granularity":"month"},"context_expansion_reasons_allowed":["prehistory","carryover","post_period_closure","long_running_contract_context"],"reason_codes":["claim_missing_required_anchors","claim_anchor_resolution_low","unresolved_supplier_customer_polarity"]},"settlement_role":"mixed","settlement_role_resolution_reason":["settlement_role_resolved_mixed"],"polarity_resolution_status":"mixed","targeted_evidence_acquisition":{"claim_type":"prove_settlement_closure_state","required_checks":["payment_document_found","contract_matched","settlement_object_matched","closing_document_found","register_closure_entry_found","posting_link_found"],"check_status":{"payment_document_found":"not_found","contract_matched":"not_found","settlement_object_matched":"not_found","closing_document_found":"not_found","register_closure_entry_found":"not_found","posting_link_found":"not_found"},"targeted_item_hits":0,"targeted_evidence_hits":0,"targeted_evidence_hit_rate":0,"targeted_evidence_source_refs":[],"reason_codes":["targeted_evidence_not_found","targeted_evidence_hit_rate_low"]},"evidence_admissibility_gate":{"candidate_evidence_total":0,"admissible_evidence_count":0,"rejected_evidence_count":0,"rejected_item_count":0,"reject_breakdown":{"wrong_period":0,"wrong_domain":0,"wrong_account_scope":0,"weak_source_mapping":0,"zero_live_match":0,"future_dated_or_out_of_window":0},"category_breakdown":{"hard_evidence":0,"supporting_signal":0,"inadmissible_noise":0},"reason_codes":["no_admissible_evidence_for_grounded_answer"]},"eligibility_time_basis":"raw_time_scope_unlocked","grounded_answer_eligibility_guard":{"eligible":false,"temporal_passed":true,"eligibility_time_basis":"raw_time_scope_unlocked","business_scope_passed":true,"polarity_passed":false,"claim_anchors_passed":true,"claim_anchor_resolution_rate":0.5,"missing_required_anchors":2,"admissible_evidence_count":0,"critical_contradiction":true,"outcome":"limited_or_insufficient_evidence","grounding_mode":"limited_or_insufficient_evidence","reason_codes":["polarity_guard_limited_unresolved_polarity","admissible_evidence_count_zero","targeted_evidence_hit_rate_zero","critical_domain_or_account_contradiction"]},"problem_centric_answer_applied":false,"problem_units_used_count":0,"problem_answer_mode":"stage1_policy_v11","assistant_outcome_class_v1":"BLOCKED_BY_AMBIGUITY","assistant_orchestration_contracts_v1":{"query_frame":{"schema_version":"assistant_query_frame_v1","original_user_question":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","normalized_question":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","route_summary_mode":"none","fragments_total":0,"dropped_intent_segments":[],"analysis_context":{"as_of_date":"2026-04-13","period_from":null,"period_to":null,"source":"scenario_pack","snapshot_mode":"auto"}},"execution_plan":{"schema_version":"assistant_execution_plan_v1","steps":[],"requirements_total":1},"evidence_bundle":{"schema_version":"assistant_evidence_bundle_v1","retrieval_calls_total":0,"retrieval_results_total":0,"retrieval_status_breakdown":{"ok":0,"partial":0,"empty":0,"error":0},"evidence_total":0,"source_refs_total":0,"limitation_total":0,"error_total":0},"coverage":{"schema_version":"assistant_coverage_contract_v1","coverage_report":{"requirements_total":1,"requirements_covered":0,"requirements_uncovered":[],"requirements_partially_covered":[],"clarification_needed_for":["R1"],"out_of_scope_requirements":[]},"grounding":{"status":"no_grounded_answer","route_subject_match":true,"missing_requirements":["R1"],"reasons":["Ни одно требование не получило подтвержденного покрытия.","В текущей выборке не хватает явных подтверждений, почему записи попали в ответ.","Часть контекста вопроса не подтверждена напрямую в найденных данных: counterparty, document, chain","Не удалось однозначно определить сторону расчета (нам должны или мы должны).","Недостаточно подтвержденных данных для уверенного ответа.","Не хватило целевых подтверждений по выбранному сценарию.","Есть противоречие по выбранному домену или контуру счета."],"why_included_summary":[],"selection_reason_summary":[]},"outcome_class":"BLOCKED_BY_AMBIGUITY"}},"answer_contract_stage4_v1":{"schema_version":"stage4_answer_contract_audit_v1","stage4_blocks_expected":["Коротко","Что именно проверено","Что найдено","Что пока не доказано","Что проверить первым/Что могу сделать сейчас"],"stage4_blocks_present":["Коротко","Что именно проверено","Что найдено","Что пока не доказано","Что проверить первым/Что могу сделать сейчас"],"stage4_blocks_missing":[],"legacy_blocks_present":[],"is_stage4_shape":true},"answer_structure_v11":{"schema_version":"answer_structure_v1_1","answer_summary":"Нужны уточнения: без сужения фокуса надежный вывод невозможен.","direct_answer":"Есть признаки проблемы, но без уточнений по периоду и объекту вывод ненадежен.","mechanism_block":{"status":"unresolved","mechanism_notes":[],"limitation_reason_codes":[]},"evidence_block":{"evidence_ids":[],"source_refs":[],"mechanism_notes":[],"coverage_note":"coverage_partial_or_limited"},"uncertainty_block":{"open_uncertainties":["R1","missing_anchor:period","missing_anchor:account","missing_anchor:counterparty"],"limitations":["Ни одно требование не получило подтвержденного покрытия.","В текущей выборке не хватает явных подтверждений, почему записи попали в ответ.","Часть контекста вопроса не подтверждена напрямую в найденных данных: counterparty, document, chain","Не удалось однозначно определить сторону расчета (нам должны или мы должны).","Недостаточно подтвержденных данных для уверенного ответа.","Не хватило целевых подтверждений по выбранному сценарию.","Есть противоречие по выбранному домену или контуру счета."]},"next_step_block":{"recommended_actions":["Дайте недостающие якоря (период/счет/объект), иначе сильный factual вывод невозможен."],"clarification_questions":["Уточните период проверки (например, июль 2020).","Уточните счет или группу счетов (например, 19, 60, 62).","Укажите контрагента или группу контрагентов.","Закройте уточнения для требований: R1."]}},"investigation_state_snapshot":{"schema_version":"investigation_state_v1","session_id":"asst-rhwrLRxdid","status":"active","turn_index":1,"updated_at":"2026-04-14T08:37:07.740Z","question_id":"msg-HlzgD8b8pA","question_scope_id":"d:settlements_60_62|s:есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотеч","scope_origin":"explicit_from_message","focus":{"domain":"settlements_60_62","period":null,"primary_accounts":[],"active_query_subject":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы"},"narrowing_status":"unknown","evidence_refs":[],"open_uncertainties":["clarify:R1"],"last_answer_mode":"clarification_required","followup_context":{"previous_question_id":null,"last_user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","referenced_requirement_ids":["R1"],"active_domain":"settlements_60_62","active_requirement_ids":["R1"],"uncovered_requirement_ids":["R1"],"last_problem_unit_id":null,"settlement_next_actions":["Проверьте договор и объект расчетов по платежу.","Сверьте регистр расчетов и привязку платежа к закрывающему документу.","Проверьте зачет аванса или взаимозачет по связке 60/62."],"evidence_summary":[],"question_scope_id":"d:settlements_60_62|s:есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотеч","scope_origin":"explicit_from_message"},"query_mode_hint":"investigation_candidate"},"fallback_type":"clarification","assistant_reply":"Коротко: По этому запросу у меня нет надежного доменного покрытия, поэтому даю мягкий отказ вместо технического шаблона.\n\nЧто именно проверено:\n- Проверен доступный контур 1С и возможность маршрутизации запроса.\n- Надежный доменный путь для текущей формулировки не подтвержден.\n\nЧто найдено:\n- Взаиморасчеты 60/62: найти хвосты, незакрытые оплаты и рисковые связки по контрагентам.\n- НДС 19/68: проверить цепочку документ -> счет-фактура -> регистр -> книга.\n- Закрытие месяца 20/44: проверить распределение затрат и остатки после регламентных операций.\n\nЧто пока не доказано:\n- Запрос не подтвержден в поддерживаемом контуре как надежный бухгалтерский сценарий.\n\nЧто могу сделать сейчас:\n- Взаиморасчеты 60/62 — найти хвосты, незакрытые оплаты и рисковые связки по контрагентам.\n- НДС 19/68 — проверить цепочку документ -> счет-фактура -> регистр -> книга.\n- Закрытие месяца 20/44 — проверить распределение затрат и остатки после регламентных операций.","reply_type":"clarification_required","trace_id":"diT7xjvfkD7An2"}} +{"timestamp":"2026-04-14T08:39:58.124Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Wdu_ZnVT13","eventType":"assistant_message_address","details":{"session_id":"asst-Wdu_ZnVT13","message_id":"msg-uEjI7UL5YJ","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"lazLNEEkjpRn8h","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-xYt3F5IYC4"}} +{"timestamp":"2026-04-14T08:40:04.216Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Wdu_ZnVT13","eventType":"assistant_message_address","details":{"session_id":"asst-Wdu_ZnVT13","message_id":"msg-yZ2omFP8ll","user_message":"Из каких товаров состоит остаток по 41 счету","effective_address_user_message":"Какие товары составляют остаток на счете 41","address_followup_context_applied":true,"address_followup_context_previous_intent":"inventory_on_hand_as_of_date","address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"SyROH1lCD1bOKB","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"из каких товаров состоит остаток по 41 счету","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"continue_previous","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-Gy2guEFipc"}} +{"timestamp":"2026-04-14T08:40:10.315Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Wdu_ZnVT13","eventType":"assistant_message_address","details":{"session_id":"asst-Wdu_ZnVT13","message_id":"msg-MINMh3o6Ow","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31","effective_address_user_message":"Получить список товаров, находящихся на счете 41 на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"QX7gWZNwXksq0i","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-u3w5xnD5wV"}} +{"timestamp":"2026-04-14T08:40:16.432Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Wdu_ZnVT13","eventType":"assistant_message_address","details":{"session_id":"asst-Wdu_ZnVT13","message_id":"msg-xKShU-g6mG","user_message":"Какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","effective_address_user_message":"Получить список номенклатур, формирующих остаток на складе на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"VQtvkYYUizdkgA","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-LIJXgxa8g2"}} +{"timestamp":"2026-04-14T08:40:22.510Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-gndL-l20Bg","eventType":"assistant_message_address","details":{"session_id":"asst-gndL-l20Bg","message_id":"msg-42d9JN52EQ","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"XSI1HEObUtunki","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-0o54Jtx0OE"}} +{"timestamp":"2026-04-14T08:40:30.426Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-gndL-l20Bg","eventType":"assistant_message_address","details":{"session_id":"asst-gndL-l20Bg","message_id":"msg-AFzPJFh-OU","user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"a217gmejGV-079","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"от какого поставщика куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный закупочный след по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные закупочные движения на 41.01 по выбранному товару.\n- Важно: без партионности этот контур не подменяет собой лот-level доказательство происхождения текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 24.08.2018.\n- Последняя найденная дата закупочного движения: 24.08.2018.\n- Документов поступления: 1.\n- Операций поступления: 1.\n- Закупочные документы найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Опорные документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-FI0R6TXGWL"}} +{"timestamp":"2026-04-14T08:40:38.674Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-gndL-l20Bg","eventType":"assistant_message_address","details":{"session_id":"asst-gndL-l20Bg","message_id":"msg-QaZTZOV7oP","user_message":"У какого поставщика были куплены товары, которые сейчас лежат на складе Основной склад организации ООО \\Альтернатива Плюс\\","effective_address_user_message":"Определить поставщиков, у которых были приобретены товары, находящиеся на складе 'Основной склад' в компании 'ООО Альтернатива Плюс'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"xVxymHucr6X80j","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"у какого поставщика были куплены товары, которые сейчас лежат на складе основной склад организации ооо \\альтернатива плюс\\","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-xGdLpI_2bn"}} +{"timestamp":"2026-04-14T08:40:45.779Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-gndL-l20Bg","eventType":"assistant_message_address","details":{"session_id":"asst-gndL-l20Bg","message_id":"msg-yvsXW33TuR","user_message":"По какому поставщику проходит текущий товарный остаток на складе Основной склад","effective_address_user_message":"Получить информацию о поставщике, связанным с текущим товарным остатком на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"kKr7zG7D3rIzjq","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"по какому поставщику проходит текущий товарный остаток на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-rW3m-EBv-R"}} +{"timestamp":"2026-04-14T08:40:52.798Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-gndL-l20Bg","eventType":"assistant_message_address","details":{"session_id":"asst-gndL-l20Bg","message_id":"msg-mIp73LotLt","user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"_jCO3JbwiIwTH4","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"когда был куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный закупочный след по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные закупочные движения на 41.01 по выбранному товару.\n- Важно: без партионности этот контур не подменяет собой лот-level доказательство происхождения текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 24.08.2018.\n- Последняя найденная дата закупочного движения: 24.08.2018.\n- Документов поступления: 1.\n- Операций поступления: 1.\n- Закупочные документы найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Опорные документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-MsvbiTCA5V"}} +{"timestamp":"2026-04-14T08:40:59.868Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-gndL-l20Bg","eventType":"assistant_message_address","details":{"session_id":"asst-gndL-l20Bg","message_id":"msg-c-vS3s_Bwq","user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","effective_address_user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"iCeln1RPEvyx34","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"по каким документам был куплен товар диван трехместный для остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_documents_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_documents_for_item","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_documents_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный для остатка на складе Основной склад","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_documents_for_item_v1","mcp_call_status_legacy":"materialized_but_not_matched","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"materialized_but_not_anchor_matched","match_failure_reason":"item_anchor_not_matched_in_materialized_rows","mcp_call_status":"materialized_but_not_anchor_matched","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":0,"rows_materialized":400,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":"empty_match","response_type":"LIMITED_WITH_REASON","limitations":["no_rows_for_anchor_after_materialization"],"assistant_reply":"По заданным фильтрам в текущем срезе совпадений пока нет.\n\nпо указанному якорю и фильтрам в выборке данных нет строк.\n\nСигнал запроса: список документов/операций.\n\nКонтекст запроса: срез на 2026-04-14.\n\nЧто могу сделать сейчас: показать документы поступления по товару на 41.01; показать документы/платежи по контрагенту или договору; показать незакрытые договоры или хвосты на дату.","reply_type":"partial_coverage","trace_id":"address-KmSnG8WipF"}} +{"timestamp":"2026-04-14T08:41:07.080Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-gndL-l20Bg","eventType":"assistant_message_address","details":{"session_id":"asst-gndL-l20Bg","message_id":"msg-w9OsqRJpMw","user_message":"Какие товары от поставщика Гамма-мебель, ООО сейчас еще лежат на складе Основной склад","effective_address_user_message":"Получить информацию о товарах от поставщика 'Гамма-мебель, ООО', которые находятся на складе 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"8GOakrS_HSwiNX","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары от поставщика гамма-мебель, ооо сейчас еще лежат на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","counterparty":"Гамма-мебель, ООО',","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":41,"rows_materialized":500,"rows_matched":41,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 13.05.2019.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 11.\n- Закупочных операций в выборке: 41.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 41.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n3. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n4. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 28.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n5. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 199.671,66 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n6. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 62.150,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n7. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 16.880,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 159.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n9. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 23.660,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n10. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 75.075,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-WTFRoeGfwi"}} +{"timestamp":"2026-04-14T08:41:15.275Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-gndL-l20Bg","eventType":"assistant_message_address","details":{"session_id":"asst-gndL-l20Bg","message_id":"msg-WLINLb_jP9","user_message":"Какие товары по состоянию на дату 2020-03-31 на складе Основной склад были куплены у поставщика Гамма-мебель, ООО","effective_address_user_message":"Получить список товаров на складе 'Основной склад' по состоянию на 2020-03-31, приобретенных у поставщика 'Гамма-мебель, ООО'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"-sVNV2znyauqM8","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары по состоянию на дату 2020-03-31 на складе основной склад были куплены у поставщика гамма-мебель, ооо","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","counterparty":"Гамма-мебель, ООО","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":41,"rows_materialized":500,"rows_matched":41,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 31.03.2020.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 13.05.2019.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 11.\n- Закупочных операций в выборке: 41.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 41.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n3. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n4. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 28.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n5. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 199.671,66 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n6. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 159.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n7. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 23.660,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 62.150,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n9. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 16.880,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n10. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 75.075,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-KJGgIWLyaP"}} +{"timestamp":"2026-04-14T08:41:21.560Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-G1zxjUdsGL","eventType":"assistant_message_address","details":{"session_id":"asst-G1zxjUdsGL","message_id":"msg-zoQ7aD83vi","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"fXtYoaLMncf5Ho","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-PWz721_soJ"}} +{"timestamp":"2026-04-14T08:41:28.327Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-G1zxjUdsGL","eventType":"assistant_message_address","details":{"session_id":"asst-G1zxjUdsGL","message_id":"msg-_XprW0WcM3","user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","effective_address_user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"sSQpuw3S0l9_ap","address_llm_predecompose_reason":"normalized_fragment_rejected_semantic_guard","address_fallback_rule_hit":null,"address_sanitized_user_message":"относится ли товар шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_aging_by_purchase_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_aging_by_purchase_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_aging_by_purchase_date","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2020-03-31"},"selected_recipe":null,"mcp_call_status_legacy":"skipped","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":null,"resolver_confidence":null,"match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"skipped","rows_fetched":0,"raw_rows_received":0,"rows_after_account_scope":0,"rows_after_recipe_filter":0,"rows_materialized":0,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"DEEP_ONLY","limited_reason_category":"unsupported","response_type":"LIMITED_WITH_REASON","limitations":["capability_route_disabled_by_flag"],"assistant_reply":"Сейчас не дам прямой адресный ответ, чтобы не ошибиться в выводах.\n\nДля этого запроса пока нет надежного ответа в текущем адресном режиме.\n\nКонтекст запроса: срез на 2020-03-31.","reply_type":"partial_coverage","trace_id":"address-7p92iQtPK_"}} +{"timestamp":"2026-04-14T08:41:36.702Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-G1zxjUdsGL","eventType":"assistant_message_address","details":{"session_id":"asst-G1zxjUdsGL","message_id":"msg-Xbb_bOjNkT","user_message":"Есть ли на складе Основной склад товары с остатком без понятной привязки к поставщику","effective_address_user_message":"Есть ли на складе Основной склад товары с остатком без понятной привязки к поставщику","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"_0uihAQCKZrUXP","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли на складе основной склад товары с остатком без понятной привязки к поставщику","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract","deep_investigation_signal_detected"],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад товары","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":487,"rows_materialized":500,"rows_matched":487,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 90.\n- Закупочных операций в выборке: 487.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 464.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-0EHrTEXTMQ"}} +{"timestamp":"2026-04-14T08:41:43.083Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-G1zxjUdsGL","eventType":"assistant_message_address","details":{"session_id":"asst-G1zxjUdsGL","message_id":"msg-VHCWk7r9-z","user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","effective_address_user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"T0aXNoMOflWsjO","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли среди текущих остатков на складе основной склад позиции, закупленные задолго до 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-mcBWezOrEO"}} +{"timestamp":"2026-04-14T08:41:49.182Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-nMvosP7E-z","eventType":"assistant_message_address","details":{"session_id":"asst-nMvosP7E-z","message_id":"msg-K3fbxZf9Sz","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31 на складе Основной склад","effective_address_user_message":"Получить список товаров, находящихся на счете 41 на дату 2020-03-31 для склада 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"IEDSeYZB9COijf","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31 на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-gK65jf8pkD"}} +{"timestamp":"2026-04-14T08:41:56.178Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-nMvosP7E-z","eventType":"assistant_message_address","details":{"session_id":"asst-nMvosP7E-z","message_id":"msg-fyirXyp4hH","user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","effective_address_user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"4NMZVYYKUyt7fv","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"кому был продан товар шкаф картотечный 1000*400*2100","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_sale_trace_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_sale_trace_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_sale_trace_for_item","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_sale_trace_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный след выбытия по товару товар до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные движения выбытия товара со счета 41.01.\n\nБлок 2. Сводка\n- Первая найденная дата выбытия: 01.04.2020.\n- Последняя найденная дата выбытия: 01.04.2020.\n- Документов выбытия: 1.\n- Операций выбытия: 1.\n- Документы выбытия найдены, но покупатель не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Документы выбытия\n1. Реализация товаров и услуг 00000000001 от 01.04.2020 0:00:00 | дата: 01.04.2020 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-cggcY7l3sm"}} +{"timestamp":"2026-04-14T08:42:05.431Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-nMvosP7E-z","eventType":"assistant_message_address","details":{"session_id":"asst-nMvosP7E-z","message_id":"msg-ipgGR1uioj","user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","effective_address_user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"-mOluwtP4CSNLy","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"через какие документы прошел путь товара шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_to_sale_chain","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_to_sale_chain","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_to_sale_chain_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":600,"raw_rows_received":600,"rows_after_account_scope":600,"rows_after_recipe_filter":2,"rows_materialized":600,"rows_matched":2,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собрана документальная цепочка по товару Шкаф картотечный 1000*400*2100 до 14.04.2026.\n\nБлок 1. Статус результата\n- Закупочных движений на 41.01: 1.\n- Движений выбытия со счета 41.01: 1.\n- В текущем контуре найдены обе стороны цепочки: поступление и последующее выбытие.\n\nБлок 2. Закупка\n- Первая дата: 10.12.2019.\n- Последняя дата: 10.12.2019.\n1. Поступление товаров и услуг 00000000111 от 10.12.2019 12:00:01 | дата: 10.12.2019 | сумма: 712.500,00 ₽ | склад: Основной склад\n\nБлок 3. Выбытие\n- Первая дата: 01.04.2020.\n- Последняя дата: 01.04.2020.\n1. Реализация товаров и услуг 00000000001 от 01.04.2020 0:00:00 | дата: 01.04.2020 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-SiAUE64IBS"}} +{"timestamp":"2026-04-14T08:42:15.380Z","level":"info","service":"assistant_loop","message":"assistant_address_tool_gate_skip","sessionId":"asst-nMvosP7E-z","details":{"session_id":"asst-nMvosP7E-z","user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","effective_address_user_message":"Проверить наличие документально подтвержденной цепочки: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотечный 1000*400*2100 -> покупатель департамент капитального ремонта города москвы","assistant_orchestration_contract_v1":{"schema_version":"assistant_orchestration_contract_v1","hard_meta_mode":null,"address_mode":"deep_analysis","address_mode_confidence":"high","address_intent":"inventory_purchase_to_sale_chain","address_intent_confidence":"medium","strong_data_signal_detected":true,"data_retrieval_signal_detected":true,"semantic_contract_valid":true,"semantic_apply_canonical_recommended":true,"semantic_reason_codes":["deep_investigation_signal_detected"],"semantic_route_arbitration":{"supported_address_intent_detected":false,"semantic_deep_investigation_hint_detected":true,"semantic_aggregate_shape_detected":false,"followup_semantic_override_to_deep_allowed":false},"followup_context_detected":false,"unsupported_address_intent_fallback_to_deep":false,"deep_analysis_signal_fallback_to_deep":true,"aggregate_analytics_signal_fallback_to_deep":false,"deep_session_continuation_fallback_to_deep":false,"final_decision":{"run_address_lane":false,"tool_gate_decision":"skip_address_lane","tool_gate_reason":"deep_analysis_signal_fallback_to_deep","living_mode":"deep_analysis","living_reason":"deep_analysis_signal_fallback_to_deep"}},"address_tool_gate_decision":"skip_address_lane","address_tool_gate_reason":"deep_analysis_signal_fallback_to_deep","address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["deep_investigation_signal_detected"]}} +{"timestamp":"2026-04-14T08:42:35.060Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-nMvosP7E-z","eventType":"assistant_message","details":{"session_id":"asst-nMvosP7E-z","message_id":"msg-G6W0ZBCqFt","user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","normalizer_output":null,"execution_plan":[],"resolved_execution_state":[],"routes":[],"retrieval_calls":[],"retrieval_results_raw":[],"retrieval_results_normalized":[],"requirements_extracted":[{"requirement_id":"R1","source_fragment_id":null,"requirement_text":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","subject_tokens":["counterparty","document","chain"],"status":"clarification_needed","route":null}],"requirements_total":1,"requirements_covered":0,"requirements_uncovered":[],"coverage_status":"partial_or_limited","answer_grounding_status":"no_grounded_answer","reply_semantic_type":"clarification_required","why_included_summary":[],"selection_reason_summary":[],"route_subject_match":true,"clarification_target":["R1"],"dropped_intent_segments":[],"question_type_class":"unknown","company_anchors":{"contract_numbers":[],"document_numbers":[],"dates":[],"amounts":[],"accounts":[],"periods":[],"document_types":[],"all":[]},"analysis_context_applied":true,"analysis_context":{"as_of_date":"2026-04-13","period_from":null,"period_to":null,"source":"scenario_pack","snapshot_mode":"auto"},"business_scope_raw":[],"business_scope_resolved":["company_specific_accounting"],"company_grounding_applied":true,"scope_resolution_reason":["settlement_claim_company_scope_recovery"],"company_scope_resolution_reason":["settlement_claim_company_scope_recovery"],"raw_time_anchor":"2026-04-13","raw_time_scope":"2026-04-13..2026-04-13","resolved_time_anchor":"2026-04-13","resolved_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"effective_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"temporal_guard_input":"2026-04-13..2026-04-13","temporal_alignment_status":"aligned","temporal_resolution_source":"scenario_pack","temporal_guard_basis":"raw_time_scope_unlocked","temporal_guard_applied":false,"temporal_guard_outcome":"passed","temporal_guard":{"raw_time_anchor":"2026-04-13","raw_time_scope":"2026-04-13..2026-04-13","resolved_time_anchor":"2026-04-13","resolved_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"effective_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"temporal_guard_input":"2026-04-13..2026-04-13","temporal_alignment_status":"aligned","temporal_resolution_source":"scenario_pack","temporal_guard_basis":"raw_time_scope_unlocked","temporal_guard_applied":false,"temporal_guard_outcome":"passed","primary_period_window":null,"allowed_context_window":null,"controlled_temporal_expansion_enabled":false,"context_expansion_reasons_allowed":["prehistory","carryover","post_period_closure","long_running_contract_context"],"normalized_anchor_drift_detected":false,"reason_codes":["analysis_context_applied"]},"raw_numeric_tokens":["1000","400","2100"],"classified_numeric_tokens":[],"rejected_as_non_accounts":[],"resolved_account_anchors":[],"domain_polarity_guard":{"applied":true,"polarity":"mixed_or_unresolved","outcome":"limited_unresolved_polarity","supplier_score":2,"customer_score":2,"account_scope":[],"raw_numeric_tokens":["1000","400","2100"],"classified_numeric_tokens":[],"rejected_as_non_accounts":[],"resolved_account_anchors":[],"rejected_problem_units":0,"rejected_evidence":0,"critical_contradiction":true,"reason_codes":["unresolved_supplier_customer_polarity","supplier_customer_signals_conflict"]},"claim_anchor_audit":{"claim_type":"prove_settlement_closure_state","settlement_role":"mixed","settlement_role_resolution_reason":["settlement_role_resolved_mixed"],"polarity_resolution_status":"mixed","required_anchors":["period","account_scope","counterparty_scope_or_contract","closure_signal"],"resolved_anchors":{"period":["2026-04-13"],"account_scope":[],"amounts":[],"contract":[],"document_numbers":[],"document_types":[],"counterparty_scope":["supplier","customer"],"advance_signal":[],"closure_signal":[],"vat_signal":[],"chain_signal":[],"close_signal":[],"cost_scope":[],"rbp_signal":[],"writeoff_signal":[],"fixed_asset_signal":[],"amortization_signal":[],"expected_fa_set":[],"actual_fa_set":[]},"missing_anchors":["account_scope","closure_signal"],"claim_anchor_resolution_rate":0.5,"primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"allowed_context_window":{"from":"2025-04-13","to":"2027-04-13","granularity":"month"},"context_expansion_reasons_allowed":["prehistory","carryover","post_period_closure","long_running_contract_context"],"reason_codes":["claim_missing_required_anchors","claim_anchor_resolution_low","unresolved_supplier_customer_polarity"]},"settlement_role":"mixed","settlement_role_resolution_reason":["settlement_role_resolved_mixed"],"polarity_resolution_status":"mixed","targeted_evidence_acquisition":{"claim_type":"prove_settlement_closure_state","required_checks":["payment_document_found","contract_matched","settlement_object_matched","closing_document_found","register_closure_entry_found","posting_link_found"],"check_status":{"payment_document_found":"not_found","contract_matched":"not_found","settlement_object_matched":"not_found","closing_document_found":"not_found","register_closure_entry_found":"not_found","posting_link_found":"not_found"},"targeted_item_hits":0,"targeted_evidence_hits":0,"targeted_evidence_hit_rate":0,"targeted_evidence_source_refs":[],"reason_codes":["targeted_evidence_not_found","targeted_evidence_hit_rate_low"]},"evidence_admissibility_gate":{"candidate_evidence_total":0,"admissible_evidence_count":0,"rejected_evidence_count":0,"rejected_item_count":0,"reject_breakdown":{"wrong_period":0,"wrong_domain":0,"wrong_account_scope":0,"weak_source_mapping":0,"zero_live_match":0,"future_dated_or_out_of_window":0},"category_breakdown":{"hard_evidence":0,"supporting_signal":0,"inadmissible_noise":0},"reason_codes":["no_admissible_evidence_for_grounded_answer"]},"eligibility_time_basis":"raw_time_scope_unlocked","grounded_answer_eligibility_guard":{"eligible":false,"temporal_passed":true,"eligibility_time_basis":"raw_time_scope_unlocked","business_scope_passed":true,"polarity_passed":false,"claim_anchors_passed":true,"claim_anchor_resolution_rate":0.5,"missing_required_anchors":2,"admissible_evidence_count":0,"critical_contradiction":true,"outcome":"limited_or_insufficient_evidence","grounding_mode":"limited_or_insufficient_evidence","reason_codes":["polarity_guard_limited_unresolved_polarity","admissible_evidence_count_zero","targeted_evidence_hit_rate_zero","critical_domain_or_account_contradiction"]},"problem_centric_answer_applied":false,"problem_units_used_count":0,"problem_answer_mode":"stage1_policy_v11","assistant_outcome_class_v1":"BLOCKED_BY_AMBIGUITY","assistant_orchestration_contracts_v1":{"query_frame":{"schema_version":"assistant_query_frame_v1","original_user_question":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","normalized_question":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","route_summary_mode":"none","fragments_total":0,"dropped_intent_segments":[],"analysis_context":{"as_of_date":"2026-04-13","period_from":null,"period_to":null,"source":"scenario_pack","snapshot_mode":"auto"}},"execution_plan":{"schema_version":"assistant_execution_plan_v1","steps":[],"requirements_total":1},"evidence_bundle":{"schema_version":"assistant_evidence_bundle_v1","retrieval_calls_total":0,"retrieval_results_total":0,"retrieval_status_breakdown":{"ok":0,"partial":0,"empty":0,"error":0},"evidence_total":0,"source_refs_total":0,"limitation_total":0,"error_total":0},"coverage":{"schema_version":"assistant_coverage_contract_v1","coverage_report":{"requirements_total":1,"requirements_covered":0,"requirements_uncovered":[],"requirements_partially_covered":[],"clarification_needed_for":["R1"],"out_of_scope_requirements":[]},"grounding":{"status":"no_grounded_answer","route_subject_match":true,"missing_requirements":["R1"],"reasons":["Ни одно требование не получило подтвержденного покрытия.","В текущей выборке не хватает явных подтверждений, почему записи попали в ответ.","Часть контекста вопроса не подтверждена напрямую в найденных данных: counterparty, document, chain","Не удалось однозначно определить сторону расчета (нам должны или мы должны).","Недостаточно подтвержденных данных для уверенного ответа.","Не хватило целевых подтверждений по выбранному сценарию.","Есть противоречие по выбранному домену или контуру счета."],"why_included_summary":[],"selection_reason_summary":[]},"outcome_class":"BLOCKED_BY_AMBIGUITY"}},"answer_contract_stage4_v1":{"schema_version":"stage4_answer_contract_audit_v1","stage4_blocks_expected":["Коротко","Что именно проверено","Что найдено","Что пока не доказано","Что проверить первым/Что могу сделать сейчас"],"stage4_blocks_present":["Коротко","Что именно проверено","Что найдено","Что пока не доказано","Что проверить первым/Что могу сделать сейчас"],"stage4_blocks_missing":[],"legacy_blocks_present":[],"is_stage4_shape":true},"answer_structure_v11":{"schema_version":"answer_structure_v1_1","answer_summary":"Нужны уточнения: без сужения фокуса надежный вывод невозможен.","direct_answer":"Есть признаки проблемы, но без уточнений по периоду и объекту вывод ненадежен.","mechanism_block":{"status":"unresolved","mechanism_notes":[],"limitation_reason_codes":[]},"evidence_block":{"evidence_ids":[],"source_refs":[],"mechanism_notes":[],"coverage_note":"coverage_partial_or_limited"},"uncertainty_block":{"open_uncertainties":["R1","missing_anchor:period","missing_anchor:account","missing_anchor:counterparty"],"limitations":["Ни одно требование не получило подтвержденного покрытия.","В текущей выборке не хватает явных подтверждений, почему записи попали в ответ.","Часть контекста вопроса не подтверждена напрямую в найденных данных: counterparty, document, chain","Не удалось однозначно определить сторону расчета (нам должны или мы должны).","Недостаточно подтвержденных данных для уверенного ответа.","Не хватило целевых подтверждений по выбранному сценарию.","Есть противоречие по выбранному домену или контуру счета."]},"next_step_block":{"recommended_actions":["Дайте недостающие якоря (период/счет/объект), иначе сильный factual вывод невозможен."],"clarification_questions":["Уточните период проверки (например, июль 2020).","Уточните счет или группу счетов (например, 19, 60, 62).","Укажите контрагента или группу контрагентов.","Закройте уточнения для требований: R1."]}},"investigation_state_snapshot":{"schema_version":"investigation_state_v1","session_id":"asst-nMvosP7E-z","status":"active","turn_index":1,"updated_at":"2026-04-14T08:42:35.058Z","question_id":"msg-tnSVgflZD4","question_scope_id":"d:settlements_60_62|s:есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотеч","scope_origin":"explicit_from_message","focus":{"domain":"settlements_60_62","period":null,"primary_accounts":[],"active_query_subject":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы"},"narrowing_status":"unknown","evidence_refs":[],"open_uncertainties":["clarify:R1"],"last_answer_mode":"clarification_required","followup_context":{"previous_question_id":null,"last_user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","referenced_requirement_ids":["R1"],"active_domain":"settlements_60_62","active_requirement_ids":["R1"],"uncovered_requirement_ids":["R1"],"last_problem_unit_id":null,"settlement_next_actions":["Проверьте договор и объект расчетов по платежу.","Сверьте регистр расчетов и привязку платежа к закрывающему документу.","Проверьте зачет аванса или взаимозачет по связке 60/62."],"evidence_summary":[],"question_scope_id":"d:settlements_60_62|s:есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотеч","scope_origin":"explicit_from_message"},"query_mode_hint":"investigation_candidate"},"fallback_type":"clarification","assistant_reply":"Коротко: По этому запросу у меня нет надежного доменного покрытия, поэтому даю мягкий отказ вместо технического шаблона.\n\nЧто именно проверено:\n- Проверен доступный контур 1С и возможность маршрутизации запроса.\n- Надежный доменный путь для текущей формулировки не подтвержден.\n\nЧто найдено:\n- Взаиморасчеты 60/62: найти хвосты, незакрытые оплаты и рисковые связки по контрагентам.\n- НДС 19/68: проверить цепочку документ -> счет-фактура -> регистр -> книга.\n- Закрытие месяца 20/44: проверить распределение затрат и остатки после регламентных операций.\n\nЧто пока не доказано:\n- Запрос не подтвержден в поддерживаемом контуре как надежный бухгалтерский сценарий.\n\nЧто могу сделать сейчас:\n- Взаиморасчеты 60/62 — найти хвосты, незакрытые оплаты и рисковые связки по контрагентам.\n- НДС 19/68 — проверить цепочку документ -> счет-фактура -> регистр -> книга.\n- Закрытие месяца 20/44 — проверить распределение затрат и остатки после регламентных операций.","reply_type":"clarification_required","trace_id":"fV-syC1Uct-PMK"}} +{"timestamp":"2026-04-14T08:45:35.912Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Ip2YjfcK6s","eventType":"assistant_message_address","details":{"session_id":"asst-Ip2YjfcK6s","message_id":"msg-33lPmL1Svr","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"8OyLUUaO4FrUUl","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-GEkqGrWVl5"}} +{"timestamp":"2026-04-14T08:45:41.979Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Ip2YjfcK6s","eventType":"assistant_message_address","details":{"session_id":"asst-Ip2YjfcK6s","message_id":"msg-xGe0hE0cKF","user_message":"Из каких товаров состоит остаток по 41 счету","effective_address_user_message":"Из каких товаров состоит остаток по 41 счету","address_followup_context_applied":true,"address_followup_context_previous_intent":"inventory_on_hand_as_of_date","address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"pXzaFYqR1dLJBh","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"из каких товаров состоит остаток по 41 счету","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"continue_previous","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-REwNXvuEpR"}} +{"timestamp":"2026-04-14T08:45:48.090Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Ip2YjfcK6s","eventType":"assistant_message_address","details":{"session_id":"asst-Ip2YjfcK6s","message_id":"msg-NIjAyi5sLK","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31","effective_address_user_message":"Получить список товаров, находящихся на счете 41 на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"gcGeClpAXBHTOg","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-jTPjFJxZML"}} +{"timestamp":"2026-04-14T08:45:54.156Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Ip2YjfcK6s","eventType":"assistant_message_address","details":{"session_id":"asst-Ip2YjfcK6s","message_id":"msg-OKKBKYXZ52","user_message":"Какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","effective_address_user_message":"Получить список номенклатур, формирующих остаток на складе на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"KVaISWTaP4yjRd","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-bSxZQNXLex"}} +{"timestamp":"2026-04-14T08:46:00.284Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-hfVbfU1NsI","eventType":"assistant_message_address","details":{"session_id":"asst-hfVbfU1NsI","message_id":"msg-U6c9yrmdZw","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"gBSe7ltDPFrg5e","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-LIrHRiyOJc"}} +{"timestamp":"2026-04-14T08:46:08.152Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-hfVbfU1NsI","eventType":"assistant_message_address","details":{"session_id":"asst-hfVbfU1NsI","message_id":"msg-fTVstM8Pqz","user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"hhzQtKas-KpjCx","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"от какого поставщика куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный закупочный след по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные закупочные движения на 41.01 по выбранному товару.\n- Важно: без партионности этот контур не подменяет собой лот-level доказательство происхождения текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 24.08.2018.\n- Последняя найденная дата закупочного движения: 24.08.2018.\n- Документов поступления: 1.\n- Операций поступления: 1.\n- Закупочные документы найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Опорные документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-TGYo69U3Ac"}} +{"timestamp":"2026-04-14T08:46:16.302Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-hfVbfU1NsI","eventType":"assistant_message_address","details":{"session_id":"asst-hfVbfU1NsI","message_id":"msg-GEhH1dEjMw","user_message":"У какого поставщика были куплены товары, которые сейчас лежат на складе Основной склад организации ООО \\Альтернатива Плюс\\","effective_address_user_message":"Определить поставщиков, у которых были приобретены товары, находящиеся на складе 'Основной склад' в компании 'ООО Альтернатива Плюс'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"j39KSqD0sPiTpe","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"у какого поставщика были куплены товары, которые сейчас лежат на складе основной склад организации ооо \\альтернатива плюс\\","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-QEai4S0l2M"}} +{"timestamp":"2026-04-14T08:46:23.487Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-hfVbfU1NsI","eventType":"assistant_message_address","details":{"session_id":"asst-hfVbfU1NsI","message_id":"msg-IUsmrZE12G","user_message":"По какому поставщику проходит текущий товарный остаток на складе Основной склад","effective_address_user_message":"Получить информацию о поставщике, связанным с текущим товарным остатком на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"6UugcZSYkVYy1e","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"по какому поставщику проходит текущий товарный остаток на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-lHi0Yi9lXj"}} +{"timestamp":"2026-04-14T08:46:30.551Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-hfVbfU1NsI","eventType":"assistant_message_address","details":{"session_id":"asst-hfVbfU1NsI","message_id":"msg-Fkdxr0gG6c","user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"fKKv8Uj01F61cU","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"когда был куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный закупочный след по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные закупочные движения на 41.01 по выбранному товару.\n- Важно: без партионности этот контур не подменяет собой лот-level доказательство происхождения текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 24.08.2018.\n- Последняя найденная дата закупочного движения: 24.08.2018.\n- Документов поступления: 1.\n- Операций поступления: 1.\n- Закупочные документы найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Опорные документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-FUy_WsPuR6"}} +{"timestamp":"2026-04-14T08:46:38.637Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-hfVbfU1NsI","eventType":"assistant_message_address","details":{"session_id":"asst-hfVbfU1NsI","message_id":"msg-CHh8oTojq_","user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","effective_address_user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"XA16S2LD1xiew_","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"по каким документам был куплен товар диван трехместный для остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_documents_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_documents_for_item","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_documents_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный для остатка на складе Основной склад","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_documents_for_item_v1","mcp_call_status_legacy":"materialized_but_not_matched","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"materialized_but_not_anchor_matched","match_failure_reason":"item_anchor_not_matched_in_materialized_rows","mcp_call_status":"materialized_but_not_anchor_matched","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":0,"rows_materialized":400,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":"empty_match","response_type":"LIMITED_WITH_REASON","limitations":["no_rows_for_anchor_after_materialization"],"assistant_reply":"По заданным фильтрам в текущем срезе совпадений пока нет.\n\nпо указанному якорю и фильтрам в выборке данных нет строк.\n\nСигнал запроса: список документов/операций.\n\nКонтекст запроса: срез на 2026-04-14.\n\nЧто могу сделать сейчас: показать документы поступления по товару на 41.01; показать документы/платежи по контрагенту или договору; показать незакрытые договоры или хвосты на дату.","reply_type":"partial_coverage","trace_id":"address-CeVpklguOU"}} +{"timestamp":"2026-04-14T08:46:45.920Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-hfVbfU1NsI","eventType":"assistant_message_address","details":{"session_id":"asst-hfVbfU1NsI","message_id":"msg-Vfk5ktbMOL","user_message":"Какие товары от поставщика Гамма-мебель, ООО сейчас еще лежат на складе Основной склад","effective_address_user_message":"Получить информацию о товарах от поставщика 'Гамма-мебель, ООО', которые находятся на складе 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"hK-NS54LF7v53D","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары от поставщика гамма-мебель, ооо сейчас еще лежат на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","counterparty":"Гамма-мебель, ООО',","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":41,"rows_materialized":500,"rows_matched":41,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 13.05.2019.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 11.\n- Закупочных операций в выборке: 41.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 41.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n3. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n4. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 28.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n5. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 199.671,66 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n6. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 62.150,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n7. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 16.880,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 159.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n9. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 23.660,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n10. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 75.075,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-5McW42HmSf"}} +{"timestamp":"2026-04-14T08:46:53.926Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-hfVbfU1NsI","eventType":"assistant_message_address","details":{"session_id":"asst-hfVbfU1NsI","message_id":"msg-yHoxtu_Ygw","user_message":"Какие товары по состоянию на дату 2020-03-31 на складе Основной склад были куплены у поставщика Гамма-мебель, ООО","effective_address_user_message":"Список товаров на складе 'Основной склад' по состоянию на 2020-03-31, приобретенных у поставщика 'Гамма-мебель, ООО'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"_nqf82-70V-f_i","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары по состоянию на дату 2020-03-31 на складе основной склад были куплены у поставщика гамма-мебель, ооо","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","counterparty":"Гамма-мебель, ООО","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":41,"rows_materialized":500,"rows_matched":41,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 31.03.2020.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 13.05.2019.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 11.\n- Закупочных операций в выборке: 41.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 41.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n3. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n4. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 28.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n5. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 199.671,66 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n6. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 159.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n7. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 23.660,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 62.150,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n9. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 16.880,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n10. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 75.075,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-X8qEAKRn9A"}} +{"timestamp":"2026-04-14T08:47:00.254Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-8Vi24WEan1","eventType":"assistant_message_address","details":{"session_id":"asst-8Vi24WEan1","message_id":"msg-eUuq-t_ywT","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"X1_eDIV6pY-I_-","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-PVVIUI2yHI"}} +{"timestamp":"2026-04-14T08:47:07.110Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-8Vi24WEan1","eventType":"assistant_message_address","details":{"session_id":"asst-8Vi24WEan1","message_id":"msg-Uf19kFdOwr","user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","effective_address_user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"oyJDwhfin_DXwc","address_llm_predecompose_reason":"normalized_fragment_rejected_semantic_guard","address_fallback_rule_hit":null,"address_sanitized_user_message":"относится ли товар шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_aging_by_purchase_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_aging_by_purchase_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_aging_by_purchase_date","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2020-03-31"},"selected_recipe":null,"mcp_call_status_legacy":"skipped","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":null,"resolver_confidence":null,"match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"skipped","rows_fetched":0,"raw_rows_received":0,"rows_after_account_scope":0,"rows_after_recipe_filter":0,"rows_materialized":0,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"DEEP_ONLY","limited_reason_category":"unsupported","response_type":"LIMITED_WITH_REASON","limitations":["capability_route_disabled_by_flag"],"assistant_reply":"Сейчас не дам прямой адресный ответ, чтобы не ошибиться в выводах.\n\nДля этого запроса пока нет надежного ответа в текущем адресном режиме.\n\nКонтекст запроса: срез на 2020-03-31.","reply_type":"partial_coverage","trace_id":"address-hPhFmN00vh"}} +{"timestamp":"2026-04-14T08:47:14.280Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-8Vi24WEan1","eventType":"assistant_message_address","details":{"session_id":"asst-8Vi24WEan1","message_id":"msg-LCFmCivgew","user_message":"Есть ли на складе Основной склад товары с остатком без понятной привязки к поставщику","effective_address_user_message":"Проверить наличие товаров на Основном складе с остатками, у которых нет ясной привязки к поставщику.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"6Lw7_5qjAhG5ts","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли на складе основной склад товары с остатком без понятной привязки к поставщику","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract","deep_investigation_signal_detected"],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-i-hizPYqJ8"}} +{"timestamp":"2026-04-14T08:47:20.559Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-8Vi24WEan1","eventType":"assistant_message_address","details":{"session_id":"asst-8Vi24WEan1","message_id":"msg--lCby_8qoo","user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","effective_address_user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"KT79_KN5Fe3IGv","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли среди текущих остатков на складе основной склад позиции, закупленные задолго до 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-XZ2vf6_H7s"}} +{"timestamp":"2026-04-14T08:47:26.675Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-xOMz3Jn6LL","eventType":"assistant_message_address","details":{"session_id":"asst-xOMz3Jn6LL","message_id":"msg-0g4iEKMF3E","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31 на складе Основной склад","effective_address_user_message":"Получить список товаров, находящихся на 41 счете по состоянию на 2020-03-31 для склада 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"3dCopiOuNlPutd","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31 на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-2Yu4-V5MHp"}} +{"timestamp":"2026-04-14T08:47:33.650Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-xOMz3Jn6LL","eventType":"assistant_message_address","details":{"session_id":"asst-xOMz3Jn6LL","message_id":"msg-t6ZBE02dsb","user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","effective_address_user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"Oufk_w7m62ZQ1A","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"кому был продан товар шкаф картотечный 1000*400*2100","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_sale_trace_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_sale_trace_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_sale_trace_for_item","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_sale_trace_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный след выбытия по товару товар до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные движения выбытия товара со счета 41.01.\n\nБлок 2. Сводка\n- Первая найденная дата выбытия: 01.04.2020.\n- Последняя найденная дата выбытия: 01.04.2020.\n- Документов выбытия: 1.\n- Операций выбытия: 1.\n- Документы выбытия найдены, но покупатель не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Документы выбытия\n1. Реализация товаров и услуг 00000000001 от 01.04.2020 0:00:00 | дата: 01.04.2020 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-6B1UGXWqL6"}} +{"timestamp":"2026-04-14T08:47:42.791Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-xOMz3Jn6LL","eventType":"assistant_message_address","details":{"session_id":"asst-xOMz3Jn6LL","message_id":"msg-rNHo1l3l91","user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","effective_address_user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"1hGe1ENxIRjm1B","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"через какие документы прошел путь товара шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_to_sale_chain","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_to_sale_chain","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_to_sale_chain_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":600,"raw_rows_received":600,"rows_after_account_scope":600,"rows_after_recipe_filter":2,"rows_materialized":600,"rows_matched":2,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собрана документальная цепочка по товару Шкаф картотечный 1000*400*2100 до 14.04.2026.\n\nБлок 1. Статус результата\n- Закупочных движений на 41.01: 1.\n- Движений выбытия со счета 41.01: 1.\n- В текущем контуре найдены обе стороны цепочки: поступление и последующее выбытие.\n\nБлок 2. Закупка\n- Первая дата: 10.12.2019.\n- Последняя дата: 10.12.2019.\n1. Поступление товаров и услуг 00000000111 от 10.12.2019 12:00:01 | дата: 10.12.2019 | сумма: 712.500,00 ₽ | склад: Основной склад\n\nБлок 3. Выбытие\n- Первая дата: 01.04.2020.\n- Последняя дата: 01.04.2020.\n1. Реализация товаров и услуг 00000000001 от 01.04.2020 0:00:00 | дата: 01.04.2020 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-V0-ySzIQTi"}} +{"timestamp":"2026-04-14T08:47:52.416Z","level":"info","service":"assistant_loop","message":"assistant_address_tool_gate_skip","sessionId":"asst-xOMz3Jn6LL","details":{"session_id":"asst-xOMz3Jn6LL","user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","effective_address_user_message":"Проверить наличие документально подтвержденной цепочки: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотечный 1000*400*2100 -> покупатель департамент капитального ремонта города москвы","assistant_orchestration_contract_v1":{"schema_version":"assistant_orchestration_contract_v1","hard_meta_mode":null,"address_mode":"deep_analysis","address_mode_confidence":"high","address_intent":"inventory_purchase_to_sale_chain","address_intent_confidence":"medium","strong_data_signal_detected":true,"data_retrieval_signal_detected":true,"semantic_contract_valid":true,"semantic_apply_canonical_recommended":true,"semantic_reason_codes":["deep_investigation_signal_detected"],"semantic_route_arbitration":{"supported_address_intent_detected":false,"semantic_deep_investigation_hint_detected":true,"semantic_aggregate_shape_detected":false,"followup_semantic_override_to_deep_allowed":false},"followup_context_detected":false,"unsupported_address_intent_fallback_to_deep":false,"deep_analysis_signal_fallback_to_deep":true,"aggregate_analytics_signal_fallback_to_deep":false,"deep_session_continuation_fallback_to_deep":false,"final_decision":{"run_address_lane":false,"tool_gate_decision":"skip_address_lane","tool_gate_reason":"deep_analysis_signal_fallback_to_deep","living_mode":"deep_analysis","living_reason":"deep_analysis_signal_fallback_to_deep"}},"address_tool_gate_decision":"skip_address_lane","address_tool_gate_reason":"deep_analysis_signal_fallback_to_deep","address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["deep_investigation_signal_detected"]}} +{"timestamp":"2026-04-14T08:48:11.972Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-xOMz3Jn6LL","eventType":"assistant_message","details":{"session_id":"asst-xOMz3Jn6LL","message_id":"msg-ofWuZ7FM0E","user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","normalizer_output":null,"execution_plan":[],"resolved_execution_state":[],"routes":[],"retrieval_calls":[],"retrieval_results_raw":[],"retrieval_results_normalized":[],"requirements_extracted":[{"requirement_id":"R1","source_fragment_id":null,"requirement_text":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","subject_tokens":["counterparty","document","chain"],"status":"clarification_needed","route":null}],"requirements_total":1,"requirements_covered":0,"requirements_uncovered":[],"coverage_status":"partial_or_limited","answer_grounding_status":"no_grounded_answer","reply_semantic_type":"clarification_required","why_included_summary":[],"selection_reason_summary":[],"route_subject_match":true,"clarification_target":["R1"],"dropped_intent_segments":[],"question_type_class":"unknown","company_anchors":{"contract_numbers":[],"document_numbers":[],"dates":[],"amounts":[],"accounts":[],"periods":[],"document_types":[],"all":[]},"analysis_context_applied":true,"analysis_context":{"as_of_date":"2026-04-13","period_from":null,"period_to":null,"source":"scenario_pack","snapshot_mode":"auto"},"business_scope_raw":[],"business_scope_resolved":["company_specific_accounting"],"company_grounding_applied":true,"scope_resolution_reason":["settlement_claim_company_scope_recovery"],"company_scope_resolution_reason":["settlement_claim_company_scope_recovery"],"raw_time_anchor":"2026-04-13","raw_time_scope":"2026-04-13..2026-04-13","resolved_time_anchor":"2026-04-13","resolved_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"effective_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"temporal_guard_input":"2026-04-13..2026-04-13","temporal_alignment_status":"aligned","temporal_resolution_source":"scenario_pack","temporal_guard_basis":"raw_time_scope_unlocked","temporal_guard_applied":false,"temporal_guard_outcome":"passed","temporal_guard":{"raw_time_anchor":"2026-04-13","raw_time_scope":"2026-04-13..2026-04-13","resolved_time_anchor":"2026-04-13","resolved_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"effective_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"temporal_guard_input":"2026-04-13..2026-04-13","temporal_alignment_status":"aligned","temporal_resolution_source":"scenario_pack","temporal_guard_basis":"raw_time_scope_unlocked","temporal_guard_applied":false,"temporal_guard_outcome":"passed","primary_period_window":null,"allowed_context_window":null,"controlled_temporal_expansion_enabled":false,"context_expansion_reasons_allowed":["prehistory","carryover","post_period_closure","long_running_contract_context"],"normalized_anchor_drift_detected":false,"reason_codes":["analysis_context_applied"]},"raw_numeric_tokens":["1000","400","2100"],"classified_numeric_tokens":[],"rejected_as_non_accounts":[],"resolved_account_anchors":[],"domain_polarity_guard":{"applied":true,"polarity":"mixed_or_unresolved","outcome":"limited_unresolved_polarity","supplier_score":2,"customer_score":2,"account_scope":[],"raw_numeric_tokens":["1000","400","2100"],"classified_numeric_tokens":[],"rejected_as_non_accounts":[],"resolved_account_anchors":[],"rejected_problem_units":0,"rejected_evidence":0,"critical_contradiction":true,"reason_codes":["unresolved_supplier_customer_polarity","supplier_customer_signals_conflict"]},"claim_anchor_audit":{"claim_type":"prove_settlement_closure_state","settlement_role":"mixed","settlement_role_resolution_reason":["settlement_role_resolved_mixed"],"polarity_resolution_status":"mixed","required_anchors":["period","account_scope","counterparty_scope_or_contract","closure_signal"],"resolved_anchors":{"period":["2026-04-13"],"account_scope":[],"amounts":[],"contract":[],"document_numbers":[],"document_types":[],"counterparty_scope":["supplier","customer"],"advance_signal":[],"closure_signal":[],"vat_signal":[],"chain_signal":[],"close_signal":[],"cost_scope":[],"rbp_signal":[],"writeoff_signal":[],"fixed_asset_signal":[],"amortization_signal":[],"expected_fa_set":[],"actual_fa_set":[]},"missing_anchors":["account_scope","closure_signal"],"claim_anchor_resolution_rate":0.5,"primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"allowed_context_window":{"from":"2025-04-13","to":"2027-04-13","granularity":"month"},"context_expansion_reasons_allowed":["prehistory","carryover","post_period_closure","long_running_contract_context"],"reason_codes":["claim_missing_required_anchors","claim_anchor_resolution_low","unresolved_supplier_customer_polarity"]},"settlement_role":"mixed","settlement_role_resolution_reason":["settlement_role_resolved_mixed"],"polarity_resolution_status":"mixed","targeted_evidence_acquisition":{"claim_type":"prove_settlement_closure_state","required_checks":["payment_document_found","contract_matched","settlement_object_matched","closing_document_found","register_closure_entry_found","posting_link_found"],"check_status":{"payment_document_found":"not_found","contract_matched":"not_found","settlement_object_matched":"not_found","closing_document_found":"not_found","register_closure_entry_found":"not_found","posting_link_found":"not_found"},"targeted_item_hits":0,"targeted_evidence_hits":0,"targeted_evidence_hit_rate":0,"targeted_evidence_source_refs":[],"reason_codes":["targeted_evidence_not_found","targeted_evidence_hit_rate_low"]},"evidence_admissibility_gate":{"candidate_evidence_total":0,"admissible_evidence_count":0,"rejected_evidence_count":0,"rejected_item_count":0,"reject_breakdown":{"wrong_period":0,"wrong_domain":0,"wrong_account_scope":0,"weak_source_mapping":0,"zero_live_match":0,"future_dated_or_out_of_window":0},"category_breakdown":{"hard_evidence":0,"supporting_signal":0,"inadmissible_noise":0},"reason_codes":["no_admissible_evidence_for_grounded_answer"]},"eligibility_time_basis":"raw_time_scope_unlocked","grounded_answer_eligibility_guard":{"eligible":false,"temporal_passed":true,"eligibility_time_basis":"raw_time_scope_unlocked","business_scope_passed":true,"polarity_passed":false,"claim_anchors_passed":true,"claim_anchor_resolution_rate":0.5,"missing_required_anchors":2,"admissible_evidence_count":0,"critical_contradiction":true,"outcome":"limited_or_insufficient_evidence","grounding_mode":"limited_or_insufficient_evidence","reason_codes":["polarity_guard_limited_unresolved_polarity","admissible_evidence_count_zero","targeted_evidence_hit_rate_zero","critical_domain_or_account_contradiction"]},"problem_centric_answer_applied":false,"problem_units_used_count":0,"problem_answer_mode":"stage1_policy_v11","assistant_outcome_class_v1":"BLOCKED_BY_AMBIGUITY","assistant_orchestration_contracts_v1":{"query_frame":{"schema_version":"assistant_query_frame_v1","original_user_question":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","normalized_question":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","route_summary_mode":"none","fragments_total":0,"dropped_intent_segments":[],"analysis_context":{"as_of_date":"2026-04-13","period_from":null,"period_to":null,"source":"scenario_pack","snapshot_mode":"auto"}},"execution_plan":{"schema_version":"assistant_execution_plan_v1","steps":[],"requirements_total":1},"evidence_bundle":{"schema_version":"assistant_evidence_bundle_v1","retrieval_calls_total":0,"retrieval_results_total":0,"retrieval_status_breakdown":{"ok":0,"partial":0,"empty":0,"error":0},"evidence_total":0,"source_refs_total":0,"limitation_total":0,"error_total":0},"coverage":{"schema_version":"assistant_coverage_contract_v1","coverage_report":{"requirements_total":1,"requirements_covered":0,"requirements_uncovered":[],"requirements_partially_covered":[],"clarification_needed_for":["R1"],"out_of_scope_requirements":[]},"grounding":{"status":"no_grounded_answer","route_subject_match":true,"missing_requirements":["R1"],"reasons":["Ни одно требование не получило подтвержденного покрытия.","В текущей выборке не хватает явных подтверждений, почему записи попали в ответ.","Часть контекста вопроса не подтверждена напрямую в найденных данных: counterparty, document, chain","Не удалось однозначно определить сторону расчета (нам должны или мы должны).","Недостаточно подтвержденных данных для уверенного ответа.","Не хватило целевых подтверждений по выбранному сценарию.","Есть противоречие по выбранному домену или контуру счета."],"why_included_summary":[],"selection_reason_summary":[]},"outcome_class":"BLOCKED_BY_AMBIGUITY"}},"answer_contract_stage4_v1":{"schema_version":"stage4_answer_contract_audit_v1","stage4_blocks_expected":["Коротко","Что именно проверено","Что найдено","Что пока не доказано","Что проверить первым/Что могу сделать сейчас"],"stage4_blocks_present":["Коротко","Что именно проверено","Что найдено","Что пока не доказано","Что проверить первым/Что могу сделать сейчас"],"stage4_blocks_missing":[],"legacy_blocks_present":[],"is_stage4_shape":true},"answer_structure_v11":{"schema_version":"answer_structure_v1_1","answer_summary":"Нужны уточнения: без сужения фокуса надежный вывод невозможен.","direct_answer":"Есть признаки проблемы, но без уточнений по периоду и объекту вывод ненадежен.","mechanism_block":{"status":"unresolved","mechanism_notes":[],"limitation_reason_codes":[]},"evidence_block":{"evidence_ids":[],"source_refs":[],"mechanism_notes":[],"coverage_note":"coverage_partial_or_limited"},"uncertainty_block":{"open_uncertainties":["R1","missing_anchor:period","missing_anchor:account","missing_anchor:counterparty"],"limitations":["Ни одно требование не получило подтвержденного покрытия.","В текущей выборке не хватает явных подтверждений, почему записи попали в ответ.","Часть контекста вопроса не подтверждена напрямую в найденных данных: counterparty, document, chain","Не удалось однозначно определить сторону расчета (нам должны или мы должны).","Недостаточно подтвержденных данных для уверенного ответа.","Не хватило целевых подтверждений по выбранному сценарию.","Есть противоречие по выбранному домену или контуру счета."]},"next_step_block":{"recommended_actions":["Дайте недостающие якоря (период/счет/объект), иначе сильный factual вывод невозможен."],"clarification_questions":["Уточните период проверки (например, июль 2020).","Уточните счет или группу счетов (например, 19, 60, 62).","Укажите контрагента или группу контрагентов.","Закройте уточнения для требований: R1."]}},"investigation_state_snapshot":{"schema_version":"investigation_state_v1","session_id":"asst-xOMz3Jn6LL","status":"active","turn_index":1,"updated_at":"2026-04-14T08:48:11.970Z","question_id":"msg-hC3SnFlbV3","question_scope_id":"d:settlements_60_62|s:есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотеч","scope_origin":"explicit_from_message","focus":{"domain":"settlements_60_62","period":null,"primary_accounts":[],"active_query_subject":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы"},"narrowing_status":"unknown","evidence_refs":[],"open_uncertainties":["clarify:R1"],"last_answer_mode":"clarification_required","followup_context":{"previous_question_id":null,"last_user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","referenced_requirement_ids":["R1"],"active_domain":"settlements_60_62","active_requirement_ids":["R1"],"uncovered_requirement_ids":["R1"],"last_problem_unit_id":null,"settlement_next_actions":["Проверьте договор и объект расчетов по платежу.","Сверьте регистр расчетов и привязку платежа к закрывающему документу.","Проверьте зачет аванса или взаимозачет по связке 60/62."],"evidence_summary":[],"question_scope_id":"d:settlements_60_62|s:есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотеч","scope_origin":"explicit_from_message"},"query_mode_hint":"investigation_candidate"},"fallback_type":"clarification","assistant_reply":"Коротко: По этому запросу у меня нет надежного доменного покрытия, поэтому даю мягкий отказ вместо технического шаблона.\n\nЧто именно проверено:\n- Проверен доступный контур 1С и возможность маршрутизации запроса.\n- Надежный доменный путь для текущей формулировки не подтвержден.\n\nЧто найдено:\n- Взаиморасчеты 60/62: найти хвосты, незакрытые оплаты и рисковые связки по контрагентам.\n- НДС 19/68: проверить цепочку документ -> счет-фактура -> регистр -> книга.\n- Закрытие месяца 20/44: проверить распределение затрат и остатки после регламентных операций.\n\nЧто пока не доказано:\n- Запрос не подтвержден в поддерживаемом контуре как надежный бухгалтерский сценарий.\n\nЧто могу сделать сейчас:\n- Взаиморасчеты 60/62 — найти хвосты, незакрытые оплаты и рисковые связки по контрагентам.\n- НДС 19/68 — проверить цепочку документ -> счет-фактура -> регистр -> книга.\n- Закрытие месяца 20/44 — проверить распределение затрат и остатки после регламентных операций.","reply_type":"clarification_required","trace_id":"gNDDzj4rdhRaKA"}} +{"timestamp":"2026-04-14T08:52:18.603Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-nmQ2DcCowK","eventType":"assistant_message_address","details":{"session_id":"asst-nmQ2DcCowK","message_id":"msg-vwIgprMxUD","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"mdSISuoBNk6JzK","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-HLMyjcZ3p8"}} +{"timestamp":"2026-04-14T08:52:24.658Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-nmQ2DcCowK","eventType":"assistant_message_address","details":{"session_id":"asst-nmQ2DcCowK","message_id":"msg-HSoLYsPo6o","user_message":"Из каких товаров состоит остаток по 41 счету","effective_address_user_message":"Какие товары составляют остаток на счете 41","address_followup_context_applied":true,"address_followup_context_previous_intent":"inventory_on_hand_as_of_date","address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"OXaHCAuuVlFsag","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"из каких товаров состоит остаток по 41 счету","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"continue_previous","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-vt-eMp1ymO"}} +{"timestamp":"2026-04-14T08:52:30.784Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-nmQ2DcCowK","eventType":"assistant_message_address","details":{"session_id":"asst-nmQ2DcCowK","message_id":"msg-2ILzc3yy5p","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31","effective_address_user_message":"Получить список товаров, находящихся на счете 41 на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"MKq8aEVokzxbIG","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-cF8b-ceD84"}} +{"timestamp":"2026-04-14T08:52:36.898Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-nmQ2DcCowK","eventType":"assistant_message_address","details":{"session_id":"asst-nmQ2DcCowK","message_id":"msg-29O5BzJMdr","user_message":"Какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","effective_address_user_message":"Получить список номенклатур, формирующих остаток на складе на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"-jt5JluGBgfqzl","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-dsRcEMQ4za"}} +{"timestamp":"2026-04-14T08:52:43.032Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Z_CQuHYSv9","eventType":"assistant_message_address","details":{"session_id":"asst-Z_CQuHYSv9","message_id":"msg-S2AjZJpALC","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"WrFp6EqVXTITni","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-qM9wt0p9Qy"}} +{"timestamp":"2026-04-14T08:52:50.984Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Z_CQuHYSv9","eventType":"assistant_message_address","details":{"session_id":"asst-Z_CQuHYSv9","message_id":"msg-qfCq67hlfK","user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"02jaSRLwCtvpqy","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"от какого поставщика куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный закупочный след по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные закупочные движения на 41.01 по выбранному товару.\n- Важно: без партионности этот контур не подменяет собой лот-level доказательство происхождения текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 24.08.2018.\n- Последняя найденная дата закупочного движения: 24.08.2018.\n- Документов поступления: 1.\n- Операций поступления: 1.\n- Закупочные документы найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Опорные документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-lJ-66EbxAr"}} +{"timestamp":"2026-04-14T08:52:59.146Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Z_CQuHYSv9","eventType":"assistant_message_address","details":{"session_id":"asst-Z_CQuHYSv9","message_id":"msg-szBfhRn-vZ","user_message":"У какого поставщика были куплены товары, которые сейчас лежат на складе Основной склад организации ООО \\Альтернатива Плюс\\","effective_address_user_message":"Определить поставщиков, у которых были приобретены товары, находящиеся на складе 'Основной склад' в компании 'ООО Альтернатива Плюс'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"oXIH7lp6jyaakm","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"у какого поставщика были куплены товары, которые сейчас лежат на складе основной склад организации ооо \\альтернатива плюс\\","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-Xu0_kZxdGz"}} +{"timestamp":"2026-04-14T08:53:06.296Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Z_CQuHYSv9","eventType":"assistant_message_address","details":{"session_id":"asst-Z_CQuHYSv9","message_id":"msg-wPIVhd7-dV","user_message":"По какому поставщику проходит текущий товарный остаток на складе Основной склад","effective_address_user_message":"Получить информацию о поставщике, связанным с текущим товарным остатком на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"PaSFRd7GVweqj7","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"по какому поставщику проходит текущий товарный остаток на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-O6jdItpmZv"}} +{"timestamp":"2026-04-14T08:53:14.430Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Z_CQuHYSv9","eventType":"assistant_message_address","details":{"session_id":"asst-Z_CQuHYSv9","message_id":"msg-i_9Fx5OYZv","user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"8Zhz1PagnwY1yl","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"когда был куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный закупочный след по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные закупочные движения на 41.01 по выбранному товару.\n- Важно: без партионности этот контур не подменяет собой лот-level доказательство происхождения текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 24.08.2018.\n- Последняя найденная дата закупочного движения: 24.08.2018.\n- Документов поступления: 1.\n- Операций поступления: 1.\n- Закупочные документы найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Опорные документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-I_ogc2z8q0"}} +{"timestamp":"2026-04-14T08:53:22.420Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Z_CQuHYSv9","eventType":"assistant_message_address","details":{"session_id":"asst-Z_CQuHYSv9","message_id":"msg-erkW8vOTwQ","user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","effective_address_user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"tKgawXz_n05Z7L","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"по каким документам был куплен товар диван трехместный для остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_documents_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_documents_for_item","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_documents_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный для остатка на складе Основной склад","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_documents_for_item_v1","mcp_call_status_legacy":"materialized_but_not_matched","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"materialized_but_not_anchor_matched","match_failure_reason":"item_anchor_not_matched_in_materialized_rows","mcp_call_status":"materialized_but_not_anchor_matched","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":0,"rows_materialized":400,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":"empty_match","response_type":"LIMITED_WITH_REASON","limitations":["no_rows_for_anchor_after_materialization"],"assistant_reply":"По заданным фильтрам в текущем срезе совпадений пока нет.\n\nпо указанному якорю и фильтрам в выборке данных нет строк.\n\nСигнал запроса: список документов/операций.\n\nКонтекст запроса: срез на 2026-04-14.\n\nЧто могу сделать сейчас: показать документы поступления по товару на 41.01; показать документы/платежи по контрагенту или договору; показать незакрытые договоры или хвосты на дату.","reply_type":"partial_coverage","trace_id":"address-Wr3WmtNadl"}} +{"timestamp":"2026-04-14T08:53:29.609Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Z_CQuHYSv9","eventType":"assistant_message_address","details":{"session_id":"asst-Z_CQuHYSv9","message_id":"msg-TAJ15oisbC","user_message":"Какие товары от поставщика Гамма-мебель, ООО сейчас еще лежат на складе Основной склад","effective_address_user_message":"Получить информацию о товарах от поставщика 'Гамма-мебель, ООО', которые находятся на складе 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"3KaqdnzEJaOdQF","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары от поставщика гамма-мебель, ооо сейчас еще лежат на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","counterparty":"Гамма-мебель, ООО',","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":41,"rows_materialized":500,"rows_matched":41,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 13.05.2019.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 11.\n- Закупочных операций в выборке: 41.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 41.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n3. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n4. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 28.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n5. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 199.671,66 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n6. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 62.150,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n7. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 16.880,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 159.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n9. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 23.660,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n10. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 75.075,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-E5sR7-qnxQ"}} +{"timestamp":"2026-04-14T08:53:37.718Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Z_CQuHYSv9","eventType":"assistant_message_address","details":{"session_id":"asst-Z_CQuHYSv9","message_id":"msg-z_znzsoo0E","user_message":"Какие товары по состоянию на дату 2020-03-31 на складе Основной склад были куплены у поставщика Гамма-мебель, ООО","effective_address_user_message":"Получить список товаров на складе 'Основной склад' по состоянию на 2020-03-31, приобретенных у поставщика 'Гамма-мебель, ООО'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"51lolAAibHlnr9","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары по состоянию на дату 2020-03-31 на складе основной склад были куплены у поставщика гамма-мебель, ооо","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","counterparty":"Гамма-мебель, ООО","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":41,"rows_materialized":500,"rows_matched":41,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 31.03.2020.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 13.05.2019.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 11.\n- Закупочных операций в выборке: 41.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 41.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n3. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n4. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 28.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n5. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 199.671,66 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n6. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 159.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n7. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 23.660,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 62.150,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n9. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 16.880,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n10. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 75.075,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-QHqwx0URv5"}} +{"timestamp":"2026-04-14T08:53:44.025Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-78PC-OVdcu","eventType":"assistant_message_address","details":{"session_id":"asst-78PC-OVdcu","message_id":"msg-oT8cjH5dHx","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"gk5IUsq2pTY_DD","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-P-byQhMyZ0"}} +{"timestamp":"2026-04-14T08:53:50.778Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-78PC-OVdcu","eventType":"assistant_message_address","details":{"session_id":"asst-78PC-OVdcu","message_id":"msg-aCSSoNNLZh","user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","effective_address_user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"CzNdUhloBP-X5q","address_llm_predecompose_reason":"normalized_fragment_rejected_semantic_guard","address_fallback_rule_hit":null,"address_sanitized_user_message":"относится ли товар шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_aging_by_purchase_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_aging_by_purchase_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_aging_by_purchase_date","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2020-03-31"},"selected_recipe":null,"mcp_call_status_legacy":"skipped","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":null,"resolver_confidence":null,"match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"skipped","rows_fetched":0,"raw_rows_received":0,"rows_after_account_scope":0,"rows_after_recipe_filter":0,"rows_materialized":0,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"DEEP_ONLY","limited_reason_category":"unsupported","response_type":"LIMITED_WITH_REASON","limitations":["capability_route_disabled_by_flag"],"assistant_reply":"Сейчас не дам прямой адресный ответ, чтобы не ошибиться в выводах.\n\nДля этого запроса пока нет надежного ответа в текущем адресном режиме.\n\nКонтекст запроса: срез на 2020-03-31.","reply_type":"partial_coverage","trace_id":"address-RtLBY5nx9I"}} +{"timestamp":"2026-04-14T08:53:59.056Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-78PC-OVdcu","eventType":"assistant_message_address","details":{"session_id":"asst-78PC-OVdcu","message_id":"msg-Lwf-jwA8zd","user_message":"Есть ли на складе Основной склад товары с остатком без понятной привязки к поставщику","effective_address_user_message":"Есть ли на складе Основной склад товары с остатком без понятной привязки к поставщику","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"-Z--eRr8UDDaRY","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли на складе основной склад товары с остатком без понятной привязки к поставщику","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract","deep_investigation_signal_detected"],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад товары","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":487,"rows_materialized":500,"rows_matched":487,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 90.\n- Закупочных операций в выборке: 487.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 464.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-RKvYCQPgEb"}} +{"timestamp":"2026-04-14T08:54:06.443Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-78PC-OVdcu","eventType":"assistant_message_address","details":{"session_id":"asst-78PC-OVdcu","message_id":"msg-oKs4u6eVTz","user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","effective_address_user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"5ipvj1tyhHBWRt","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли среди текущих остатков на складе основной склад позиции, закупленные задолго до 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-C0w4dOThGl"}} +{"timestamp":"2026-04-14T08:54:12.495Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Awv8ph7JNo","eventType":"assistant_message_address","details":{"session_id":"asst-Awv8ph7JNo","message_id":"msg-7mjMsmSD0C","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31 на складе Основной склад","effective_address_user_message":"Получить список товаров, находящихся на счете 41 на дату 2020-03-31 для склада 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"tOuZ7dDUFsQ5ZW","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31 на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-e8wnm1OsJT"}} +{"timestamp":"2026-04-14T08:54:19.340Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Awv8ph7JNo","eventType":"assistant_message_address","details":{"session_id":"asst-Awv8ph7JNo","message_id":"msg-8__HwKxa0T","user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","effective_address_user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"gC3RrvXiteI6Ij","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"кому был продан товар шкаф картотечный 1000*400*2100","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_sale_trace_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_sale_trace_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_sale_trace_for_item","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_sale_trace_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный след выбытия по товару товар до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные движения выбытия товара со счета 41.01.\n\nБлок 2. Сводка\n- Первая найденная дата выбытия: 01.04.2020.\n- Последняя найденная дата выбытия: 01.04.2020.\n- Документов выбытия: 1.\n- Операций выбытия: 1.\n- Документы выбытия найдены, но покупатель не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Документы выбытия\n1. Реализация товаров и услуг 00000000001 от 01.04.2020 0:00:00 | дата: 01.04.2020 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-ZijR-Yt6Dg"}} +{"timestamp":"2026-04-14T08:54:28.613Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Awv8ph7JNo","eventType":"assistant_message_address","details":{"session_id":"asst-Awv8ph7JNo","message_id":"msg-pYYJwKCnQn","user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","effective_address_user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"3hVniq3NRBhWQy","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"через какие документы прошел путь товара шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_to_sale_chain","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_to_sale_chain","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_to_sale_chain_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":600,"raw_rows_received":600,"rows_after_account_scope":600,"rows_after_recipe_filter":2,"rows_materialized":600,"rows_matched":2,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собрана документальная цепочка по товару Шкаф картотечный 1000*400*2100 до 14.04.2026.\n\nБлок 1. Статус результата\n- Закупочных движений на 41.01: 1.\n- Движений выбытия со счета 41.01: 1.\n- В текущем контуре найдены обе стороны цепочки: поступление и последующее выбытие.\n\nБлок 2. Закупка\n- Первая дата: 10.12.2019.\n- Последняя дата: 10.12.2019.\n1. Поступление товаров и услуг 00000000111 от 10.12.2019 12:00:01 | дата: 10.12.2019 | сумма: 712.500,00 ₽ | склад: Основной склад\n\nБлок 3. Выбытие\n- Первая дата: 01.04.2020.\n- Последняя дата: 01.04.2020.\n1. Реализация товаров и услуг 00000000001 от 01.04.2020 0:00:00 | дата: 01.04.2020 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-pyFx3NfTv1"}} +{"timestamp":"2026-04-14T08:54:38.498Z","level":"info","service":"assistant_loop","message":"assistant_address_tool_gate_skip","sessionId":"asst-Awv8ph7JNo","details":{"session_id":"asst-Awv8ph7JNo","user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","effective_address_user_message":"Проверить наличие документально подтвержденной цепочки: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотечный 1000*400*2100 -> покупатель департамент капитального ремонта города москвы","assistant_orchestration_contract_v1":{"schema_version":"assistant_orchestration_contract_v1","hard_meta_mode":null,"address_mode":"deep_analysis","address_mode_confidence":"high","address_intent":"inventory_purchase_to_sale_chain","address_intent_confidence":"medium","strong_data_signal_detected":true,"data_retrieval_signal_detected":true,"semantic_contract_valid":true,"semantic_apply_canonical_recommended":true,"semantic_reason_codes":["deep_investigation_signal_detected"],"semantic_route_arbitration":{"supported_address_intent_detected":false,"semantic_deep_investigation_hint_detected":true,"semantic_aggregate_shape_detected":false,"followup_semantic_override_to_deep_allowed":false},"followup_context_detected":false,"unsupported_address_intent_fallback_to_deep":false,"deep_analysis_signal_fallback_to_deep":true,"aggregate_analytics_signal_fallback_to_deep":false,"deep_session_continuation_fallback_to_deep":false,"final_decision":{"run_address_lane":false,"tool_gate_decision":"skip_address_lane","tool_gate_reason":"deep_analysis_signal_fallback_to_deep","living_mode":"deep_analysis","living_reason":"deep_analysis_signal_fallback_to_deep"}},"address_tool_gate_decision":"skip_address_lane","address_tool_gate_reason":"deep_analysis_signal_fallback_to_deep","address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["deep_investigation_signal_detected"]}} +{"timestamp":"2026-04-14T08:54:58.216Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Awv8ph7JNo","eventType":"assistant_message","details":{"session_id":"asst-Awv8ph7JNo","message_id":"msg-tuSsy4Xi9Z","user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","normalizer_output":null,"execution_plan":[],"resolved_execution_state":[],"routes":[],"retrieval_calls":[],"retrieval_results_raw":[],"retrieval_results_normalized":[],"requirements_extracted":[{"requirement_id":"R1","source_fragment_id":null,"requirement_text":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","subject_tokens":["counterparty","document","chain"],"status":"clarification_needed","route":null}],"requirements_total":1,"requirements_covered":0,"requirements_uncovered":[],"coverage_status":"partial_or_limited","answer_grounding_status":"no_grounded_answer","reply_semantic_type":"clarification_required","why_included_summary":[],"selection_reason_summary":[],"route_subject_match":true,"clarification_target":["R1"],"dropped_intent_segments":[],"question_type_class":"unknown","company_anchors":{"contract_numbers":[],"document_numbers":[],"dates":[],"amounts":[],"accounts":[],"periods":[],"document_types":[],"all":[]},"analysis_context_applied":true,"analysis_context":{"as_of_date":"2026-04-13","period_from":null,"period_to":null,"source":"scenario_pack","snapshot_mode":"auto"},"business_scope_raw":[],"business_scope_resolved":["company_specific_accounting"],"company_grounding_applied":true,"scope_resolution_reason":["settlement_claim_company_scope_recovery"],"company_scope_resolution_reason":["settlement_claim_company_scope_recovery"],"raw_time_anchor":"2026-04-13","raw_time_scope":"2026-04-13..2026-04-13","resolved_time_anchor":"2026-04-13","resolved_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"effective_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"temporal_guard_input":"2026-04-13..2026-04-13","temporal_alignment_status":"aligned","temporal_resolution_source":"scenario_pack","temporal_guard_basis":"raw_time_scope_unlocked","temporal_guard_applied":false,"temporal_guard_outcome":"passed","temporal_guard":{"raw_time_anchor":"2026-04-13","raw_time_scope":"2026-04-13..2026-04-13","resolved_time_anchor":"2026-04-13","resolved_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"effective_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"temporal_guard_input":"2026-04-13..2026-04-13","temporal_alignment_status":"aligned","temporal_resolution_source":"scenario_pack","temporal_guard_basis":"raw_time_scope_unlocked","temporal_guard_applied":false,"temporal_guard_outcome":"passed","primary_period_window":null,"allowed_context_window":null,"controlled_temporal_expansion_enabled":false,"context_expansion_reasons_allowed":["prehistory","carryover","post_period_closure","long_running_contract_context"],"normalized_anchor_drift_detected":false,"reason_codes":["analysis_context_applied"]},"raw_numeric_tokens":["1000","400","2100"],"classified_numeric_tokens":[],"rejected_as_non_accounts":[],"resolved_account_anchors":[],"domain_polarity_guard":{"applied":true,"polarity":"mixed_or_unresolved","outcome":"limited_unresolved_polarity","supplier_score":2,"customer_score":2,"account_scope":[],"raw_numeric_tokens":["1000","400","2100"],"classified_numeric_tokens":[],"rejected_as_non_accounts":[],"resolved_account_anchors":[],"rejected_problem_units":0,"rejected_evidence":0,"critical_contradiction":true,"reason_codes":["unresolved_supplier_customer_polarity","supplier_customer_signals_conflict"]},"claim_anchor_audit":{"claim_type":"prove_settlement_closure_state","settlement_role":"mixed","settlement_role_resolution_reason":["settlement_role_resolved_mixed"],"polarity_resolution_status":"mixed","required_anchors":["period","account_scope","counterparty_scope_or_contract","closure_signal"],"resolved_anchors":{"period":["2026-04-13"],"account_scope":[],"amounts":[],"contract":[],"document_numbers":[],"document_types":[],"counterparty_scope":["supplier","customer"],"advance_signal":[],"closure_signal":[],"vat_signal":[],"chain_signal":[],"close_signal":[],"cost_scope":[],"rbp_signal":[],"writeoff_signal":[],"fixed_asset_signal":[],"amortization_signal":[],"expected_fa_set":[],"actual_fa_set":[]},"missing_anchors":["account_scope","closure_signal"],"claim_anchor_resolution_rate":0.5,"primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"allowed_context_window":{"from":"2025-04-13","to":"2027-04-13","granularity":"month"},"context_expansion_reasons_allowed":["prehistory","carryover","post_period_closure","long_running_contract_context"],"reason_codes":["claim_missing_required_anchors","claim_anchor_resolution_low","unresolved_supplier_customer_polarity"]},"settlement_role":"mixed","settlement_role_resolution_reason":["settlement_role_resolved_mixed"],"polarity_resolution_status":"mixed","targeted_evidence_acquisition":{"claim_type":"prove_settlement_closure_state","required_checks":["payment_document_found","contract_matched","settlement_object_matched","closing_document_found","register_closure_entry_found","posting_link_found"],"check_status":{"payment_document_found":"not_found","contract_matched":"not_found","settlement_object_matched":"not_found","closing_document_found":"not_found","register_closure_entry_found":"not_found","posting_link_found":"not_found"},"targeted_item_hits":0,"targeted_evidence_hits":0,"targeted_evidence_hit_rate":0,"targeted_evidence_source_refs":[],"reason_codes":["targeted_evidence_not_found","targeted_evidence_hit_rate_low"]},"evidence_admissibility_gate":{"candidate_evidence_total":0,"admissible_evidence_count":0,"rejected_evidence_count":0,"rejected_item_count":0,"reject_breakdown":{"wrong_period":0,"wrong_domain":0,"wrong_account_scope":0,"weak_source_mapping":0,"zero_live_match":0,"future_dated_or_out_of_window":0},"category_breakdown":{"hard_evidence":0,"supporting_signal":0,"inadmissible_noise":0},"reason_codes":["no_admissible_evidence_for_grounded_answer"]},"eligibility_time_basis":"raw_time_scope_unlocked","grounded_answer_eligibility_guard":{"eligible":false,"temporal_passed":true,"eligibility_time_basis":"raw_time_scope_unlocked","business_scope_passed":true,"polarity_passed":false,"claim_anchors_passed":true,"claim_anchor_resolution_rate":0.5,"missing_required_anchors":2,"admissible_evidence_count":0,"critical_contradiction":true,"outcome":"limited_or_insufficient_evidence","grounding_mode":"limited_or_insufficient_evidence","reason_codes":["polarity_guard_limited_unresolved_polarity","admissible_evidence_count_zero","targeted_evidence_hit_rate_zero","critical_domain_or_account_contradiction"]},"problem_centric_answer_applied":false,"problem_units_used_count":0,"problem_answer_mode":"stage1_policy_v11","assistant_outcome_class_v1":"BLOCKED_BY_AMBIGUITY","assistant_orchestration_contracts_v1":{"query_frame":{"schema_version":"assistant_query_frame_v1","original_user_question":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","normalized_question":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","route_summary_mode":"none","fragments_total":0,"dropped_intent_segments":[],"analysis_context":{"as_of_date":"2026-04-13","period_from":null,"period_to":null,"source":"scenario_pack","snapshot_mode":"auto"}},"execution_plan":{"schema_version":"assistant_execution_plan_v1","steps":[],"requirements_total":1},"evidence_bundle":{"schema_version":"assistant_evidence_bundle_v1","retrieval_calls_total":0,"retrieval_results_total":0,"retrieval_status_breakdown":{"ok":0,"partial":0,"empty":0,"error":0},"evidence_total":0,"source_refs_total":0,"limitation_total":0,"error_total":0},"coverage":{"schema_version":"assistant_coverage_contract_v1","coverage_report":{"requirements_total":1,"requirements_covered":0,"requirements_uncovered":[],"requirements_partially_covered":[],"clarification_needed_for":["R1"],"out_of_scope_requirements":[]},"grounding":{"status":"no_grounded_answer","route_subject_match":true,"missing_requirements":["R1"],"reasons":["Ни одно требование не получило подтвержденного покрытия.","В текущей выборке не хватает явных подтверждений, почему записи попали в ответ.","Часть контекста вопроса не подтверждена напрямую в найденных данных: counterparty, document, chain","Не удалось однозначно определить сторону расчета (нам должны или мы должны).","Недостаточно подтвержденных данных для уверенного ответа.","Не хватило целевых подтверждений по выбранному сценарию.","Есть противоречие по выбранному домену или контуру счета."],"why_included_summary":[],"selection_reason_summary":[]},"outcome_class":"BLOCKED_BY_AMBIGUITY"}},"answer_contract_stage4_v1":{"schema_version":"stage4_answer_contract_audit_v1","stage4_blocks_expected":["Коротко","Что именно проверено","Что найдено","Что пока не доказано","Что проверить первым/Что могу сделать сейчас"],"stage4_blocks_present":["Коротко","Что именно проверено","Что найдено","Что пока не доказано","Что проверить первым/Что могу сделать сейчас"],"stage4_blocks_missing":[],"legacy_blocks_present":[],"is_stage4_shape":true},"answer_structure_v11":{"schema_version":"answer_structure_v1_1","answer_summary":"Нужны уточнения: без сужения фокуса надежный вывод невозможен.","direct_answer":"Есть признаки проблемы, но без уточнений по периоду и объекту вывод ненадежен.","mechanism_block":{"status":"unresolved","mechanism_notes":[],"limitation_reason_codes":[]},"evidence_block":{"evidence_ids":[],"source_refs":[],"mechanism_notes":[],"coverage_note":"coverage_partial_or_limited"},"uncertainty_block":{"open_uncertainties":["R1","missing_anchor:period","missing_anchor:account","missing_anchor:counterparty"],"limitations":["Ни одно требование не получило подтвержденного покрытия.","В текущей выборке не хватает явных подтверждений, почему записи попали в ответ.","Часть контекста вопроса не подтверждена напрямую в найденных данных: counterparty, document, chain","Не удалось однозначно определить сторону расчета (нам должны или мы должны).","Недостаточно подтвержденных данных для уверенного ответа.","Не хватило целевых подтверждений по выбранному сценарию.","Есть противоречие по выбранному домену или контуру счета."]},"next_step_block":{"recommended_actions":["Дайте недостающие якоря (период/счет/объект), иначе сильный factual вывод невозможен."],"clarification_questions":["Уточните период проверки (например, июль 2020).","Уточните счет или группу счетов (например, 19, 60, 62).","Укажите контрагента или группу контрагентов.","Закройте уточнения для требований: R1."]}},"investigation_state_snapshot":{"schema_version":"investigation_state_v1","session_id":"asst-Awv8ph7JNo","status":"active","turn_index":1,"updated_at":"2026-04-14T08:54:58.211Z","question_id":"msg-e_VQff7QfC","question_scope_id":"d:settlements_60_62|s:есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотеч","scope_origin":"explicit_from_message","focus":{"domain":"settlements_60_62","period":null,"primary_accounts":[],"active_query_subject":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы"},"narrowing_status":"unknown","evidence_refs":[],"open_uncertainties":["clarify:R1"],"last_answer_mode":"clarification_required","followup_context":{"previous_question_id":null,"last_user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","referenced_requirement_ids":["R1"],"active_domain":"settlements_60_62","active_requirement_ids":["R1"],"uncovered_requirement_ids":["R1"],"last_problem_unit_id":null,"settlement_next_actions":["Проверьте договор и объект расчетов по платежу.","Сверьте регистр расчетов и привязку платежа к закрывающему документу.","Проверьте зачет аванса или взаимозачет по связке 60/62."],"evidence_summary":[],"question_scope_id":"d:settlements_60_62|s:есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотеч","scope_origin":"explicit_from_message"},"query_mode_hint":"investigation_candidate"},"fallback_type":"clarification","assistant_reply":"Коротко: По этому запросу у меня нет надежного доменного покрытия, поэтому даю мягкий отказ вместо технического шаблона.\n\nЧто именно проверено:\n- Проверен доступный контур 1С и возможность маршрутизации запроса.\n- Надежный доменный путь для текущей формулировки не подтвержден.\n\nЧто найдено:\n- Взаиморасчеты 60/62: найти хвосты, незакрытые оплаты и рисковые связки по контрагентам.\n- НДС 19/68: проверить цепочку документ -> счет-фактура -> регистр -> книга.\n- Закрытие месяца 20/44: проверить распределение затрат и остатки после регламентных операций.\n\nЧто пока не доказано:\n- Запрос не подтвержден в поддерживаемом контуре как надежный бухгалтерский сценарий.\n\nЧто могу сделать сейчас:\n- Взаиморасчеты 60/62 — найти хвосты, незакрытые оплаты и рисковые связки по контрагентам.\n- НДС 19/68 — проверить цепочку документ -> счет-фактура -> регистр -> книга.\n- Закрытие месяца 20/44 — проверить распределение затрат и остатки после регламентных операций.","reply_type":"clarification_required","trace_id":"-Tg-6Lsx4z0nIT"}} +{"timestamp":"2026-04-14T09:00:21.493Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-k7UH9KdJT0","eventType":"assistant_message_address","details":{"session_id":"asst-k7UH9KdJT0","message_id":"msg-2MKVNRDLql","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"xb3Q91X-rRO8SI","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-S1swkN22_l"}} +{"timestamp":"2026-04-14T09:00:27.598Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-k7UH9KdJT0","eventType":"assistant_message_address","details":{"session_id":"asst-k7UH9KdJT0","message_id":"msg-1gZfTl9UK2","user_message":"Из каких товаров состоит остаток по 41 счету","effective_address_user_message":"Из каких товаров состоит остаток по 41 счету","address_followup_context_applied":true,"address_followup_context_previous_intent":"inventory_on_hand_as_of_date","address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"bfbwkHMNvnbE6n","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"из каких товаров состоит остаток по 41 счету","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"continue_previous","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-zUnBFr8OnN"}} +{"timestamp":"2026-04-14T09:00:33.690Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-k7UH9KdJT0","eventType":"assistant_message_address","details":{"session_id":"asst-k7UH9KdJT0","message_id":"msg-0hA1cNxAJ8","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31","effective_address_user_message":"Получить список товаров, находящихся на счете 41 на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"T6ShYk5J7iinb7","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-365OxEEFcG"}} +{"timestamp":"2026-04-14T09:00:39.793Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-k7UH9KdJT0","eventType":"assistant_message_address","details":{"session_id":"asst-k7UH9KdJT0","message_id":"msg-L0xk3z5lBf","user_message":"Какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","effective_address_user_message":"Получить список номенклатур, формирующих остаток на складе на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"s_6FW-koFGu25G","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-XkdW3We-Oi"}} +{"timestamp":"2026-04-14T09:00:45.871Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-YSlnmRDeSi","eventType":"assistant_message_address","details":{"session_id":"asst-YSlnmRDeSi","message_id":"msg-bHG2KQaZC3","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"ezNaM93IxwveZh","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-_IRzLgvlss"}} +{"timestamp":"2026-04-14T09:00:53.777Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-YSlnmRDeSi","eventType":"assistant_message_address","details":{"session_id":"asst-YSlnmRDeSi","message_id":"msg-Mmgqm0Sqx5","user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"YDimCjhLImkUZT","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"от какого поставщика куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный закупочный след по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные закупочные движения на 41.01 по выбранному товару.\n- Важно: без партионности этот контур не подменяет собой лот-level доказательство происхождения текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 24.08.2018.\n- Последняя найденная дата закупочного движения: 24.08.2018.\n- Документов поступления: 1.\n- Операций поступления: 1.\n- Закупочные документы найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Опорные документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-WXZeHafEcY"}} +{"timestamp":"2026-04-14T09:01:01.990Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-YSlnmRDeSi","eventType":"assistant_message_address","details":{"session_id":"asst-YSlnmRDeSi","message_id":"msg-spu0tMkKjW","user_message":"У какого поставщика были куплены товары, которые сейчас лежат на складе Основной склад организации ООО \\Альтернатива Плюс\\","effective_address_user_message":"Определить поставщиков, у которых были приобретены товары, находящиеся на складе 'Основной склад' в компании 'ООО Альтернатива Плюс'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"SLHF79RVAhQj1U","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"у какого поставщика были куплены товары, которые сейчас лежат на складе основной склад организации ооо \\альтернатива плюс\\","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-3QHHuQJadS"}} +{"timestamp":"2026-04-14T09:01:09.132Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-YSlnmRDeSi","eventType":"assistant_message_address","details":{"session_id":"asst-YSlnmRDeSi","message_id":"msg-t5AFmELBsi","user_message":"По какому поставщику проходит текущий товарный остаток на складе Основной склад","effective_address_user_message":"Получить информацию о поставщике, связанным с текущим товарным остатком на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"6QAe8SyiI1et8s","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"по какому поставщику проходит текущий товарный остаток на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-DxH3awpb5F"}} +{"timestamp":"2026-04-14T09:01:16.217Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-YSlnmRDeSi","eventType":"assistant_message_address","details":{"session_id":"asst-YSlnmRDeSi","message_id":"msg-v5U8wsUn-W","user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"m3e37DXW-b9jeH","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"когда был куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный закупочный след по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные закупочные движения на 41.01 по выбранному товару.\n- Важно: без партионности этот контур не подменяет собой лот-level доказательство происхождения текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 24.08.2018.\n- Последняя найденная дата закупочного движения: 24.08.2018.\n- Документов поступления: 1.\n- Операций поступления: 1.\n- Закупочные документы найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Опорные документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-zYx_DztRDF"}} +{"timestamp":"2026-04-14T09:01:24.272Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-YSlnmRDeSi","eventType":"assistant_message_address","details":{"session_id":"asst-YSlnmRDeSi","message_id":"msg-Nkqoc0oZAY","user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","effective_address_user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"Itvn2q3cmlvy5m","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"по каким документам был куплен товар диван трехместный для остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_documents_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_documents_for_item","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_documents_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный для остатка на складе Основной склад","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_documents_for_item_v1","mcp_call_status_legacy":"materialized_but_not_matched","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"materialized_but_not_anchor_matched","match_failure_reason":"item_anchor_not_matched_in_materialized_rows","mcp_call_status":"materialized_but_not_anchor_matched","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":0,"rows_materialized":400,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":"empty_match","response_type":"LIMITED_WITH_REASON","limitations":["no_rows_for_anchor_after_materialization"],"assistant_reply":"По заданным фильтрам в текущем срезе совпадений пока нет.\n\nпо указанному якорю и фильтрам в выборке данных нет строк.\n\nСигнал запроса: список документов/операций.\n\nКонтекст запроса: срез на 2026-04-14.\n\nЧто могу сделать сейчас: показать документы поступления по товару на 41.01; показать документы/платежи по контрагенту или договору; показать незакрытые договоры или хвосты на дату.","reply_type":"partial_coverage","trace_id":"address-H0ptZDt48l"}} +{"timestamp":"2026-04-14T09:01:31.539Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-YSlnmRDeSi","eventType":"assistant_message_address","details":{"session_id":"asst-YSlnmRDeSi","message_id":"msg-P90d1p9jth","user_message":"Какие товары от поставщика Гамма-мебель, ООО сейчас еще лежат на складе Основной склад","effective_address_user_message":"Получить информацию о товарах от поставщика 'Гамма-мебель, ООО', которые находятся на складе 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"kOT_LZSTjvEo7A","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары от поставщика гамма-мебель, ооо сейчас еще лежат на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","counterparty":"Гамма-мебель, ООО',","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":41,"rows_materialized":500,"rows_matched":41,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 13.05.2019.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 11.\n- Закупочных операций в выборке: 41.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 41.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n3. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n4. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 28.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n5. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 199.671,66 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n6. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 62.150,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n7. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 16.880,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 159.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n9. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 23.660,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n10. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 75.075,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-Q88fC2jnZt"}} +{"timestamp":"2026-04-14T09:01:39.576Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-YSlnmRDeSi","eventType":"assistant_message_address","details":{"session_id":"asst-YSlnmRDeSi","message_id":"msg-tsB7pbGDSP","user_message":"Какие товары по состоянию на дату 2020-03-31 на складе Основной склад были куплены у поставщика Гамма-мебель, ООО","effective_address_user_message":"Список товаров на складе 'Основной склад' по состоянию на 2020-03-31, приобретенных у поставщика 'Гамма-мебель, ООО'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"EQ1RapeesJPKOJ","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары по состоянию на дату 2020-03-31 на складе основной склад были куплены у поставщика гамма-мебель, ооо","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","counterparty":"Гамма-мебель, ООО","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":41,"rows_materialized":500,"rows_matched":41,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 31.03.2020.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 13.05.2019.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 11.\n- Закупочных операций в выборке: 41.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 41.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n3. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n4. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 28.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n5. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 199.671,66 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n6. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 159.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n7. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 23.660,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 62.150,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n9. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 16.880,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n10. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 75.075,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-JXSBSCj5Zb"}} +{"timestamp":"2026-04-14T09:01:45.855Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-lNyiTm5fxn","eventType":"assistant_message_address","details":{"session_id":"asst-lNyiTm5fxn","message_id":"msg-J6pnlGa5pY","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"6syV-mvNopyyab","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-VrRwjkEAQF"}} +{"timestamp":"2026-04-14T09:01:52.633Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-lNyiTm5fxn","eventType":"assistant_message_address","details":{"session_id":"asst-lNyiTm5fxn","message_id":"msg-vPCmTy07pS","user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","effective_address_user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"m-t4U47zbmlw8j","address_llm_predecompose_reason":"normalized_fragment_rejected_semantic_guard","address_fallback_rule_hit":null,"address_sanitized_user_message":"относится ли товар шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_aging_by_purchase_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_aging_by_purchase_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_aging_by_purchase_date","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2020-03-31"},"selected_recipe":null,"mcp_call_status_legacy":"skipped","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":null,"resolver_confidence":null,"match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"skipped","rows_fetched":0,"raw_rows_received":0,"rows_after_account_scope":0,"rows_after_recipe_filter":0,"rows_materialized":0,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"DEEP_ONLY","limited_reason_category":"unsupported","response_type":"LIMITED_WITH_REASON","limitations":["capability_route_disabled_by_flag"],"assistant_reply":"Сейчас не дам прямой адресный ответ, чтобы не ошибиться в выводах.\n\nДля этого запроса пока нет надежного ответа в текущем адресном режиме.\n\nКонтекст запроса: срез на 2020-03-31.","reply_type":"partial_coverage","trace_id":"address-gPkIdK85bm"}} +{"timestamp":"2026-04-14T09:01:59.993Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-lNyiTm5fxn","eventType":"assistant_message_address","details":{"session_id":"asst-lNyiTm5fxn","message_id":"msg-9ka9vGw2bd","user_message":"Есть ли на складе Основной склад товары с остатком без понятной привязки к поставщику","effective_address_user_message":"Проверить наличие товаров на Основном складе с остатками, у которых нет ясной привязки к поставщику.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"hz3qQGK7M1uWXQ","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли на складе основной склад товары с остатком без понятной привязки к поставщику","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract","deep_investigation_signal_detected"],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-EXsXMeVjGO"}} +{"timestamp":"2026-04-14T09:02:07.233Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-lNyiTm5fxn","eventType":"assistant_message_address","details":{"session_id":"asst-lNyiTm5fxn","message_id":"msg-I8PhB2i9qn","user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","effective_address_user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"L7LBCaV9fkJpI9","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли среди текущих остатков на складе основной склад позиции, закупленные задолго до 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-mqSxNnSeqw"}} +{"timestamp":"2026-04-14T09:02:13.329Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-9qcscEdiYv","eventType":"assistant_message_address","details":{"session_id":"asst-9qcscEdiYv","message_id":"msg-0lXRtmSQbf","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31 на складе Основной склад","effective_address_user_message":"Получить список товаров, находящихся на 41 счете по состоянию на 2020-03-31 для склада 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"MRNh7WY_0WVgGd","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31 на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-VdNxSAsQHf"}} +{"timestamp":"2026-04-14T09:02:20.227Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-9qcscEdiYv","eventType":"assistant_message_address","details":{"session_id":"asst-9qcscEdiYv","message_id":"msg-5DD91LG1od","user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","effective_address_user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"P1iJvm6hQtPxbh","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"кому был продан товар шкаф картотечный 1000*400*2100","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_sale_trace_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_sale_trace_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_sale_trace_for_item","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_sale_trace_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный след выбытия по товару товар до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные движения выбытия товара со счета 41.01.\n\nБлок 2. Сводка\n- Первая найденная дата выбытия: 01.04.2020.\n- Последняя найденная дата выбытия: 01.04.2020.\n- Документов выбытия: 1.\n- Операций выбытия: 1.\n- Документы выбытия найдены, но покупатель не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Документы выбытия\n1. Реализация товаров и услуг 00000000001 от 01.04.2020 0:00:00 | дата: 01.04.2020 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-Q9e2Yrutty"}} +{"timestamp":"2026-04-14T09:02:29.470Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-9qcscEdiYv","eventType":"assistant_message_address","details":{"session_id":"asst-9qcscEdiYv","message_id":"msg-R68QK8Qb40","user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","effective_address_user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"J2u2Bm95t7UgoU","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"через какие документы прошел путь товара шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_to_sale_chain","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_to_sale_chain","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_to_sale_chain_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":600,"raw_rows_received":600,"rows_after_account_scope":600,"rows_after_recipe_filter":2,"rows_materialized":600,"rows_matched":2,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собрана документальная цепочка по товару Шкаф картотечный 1000*400*2100 до 14.04.2026.\n\nБлок 1. Статус результата\n- Закупочных движений на 41.01: 1.\n- Движений выбытия со счета 41.01: 1.\n- В текущем контуре найдены обе стороны цепочки: поступление и последующее выбытие.\n\nБлок 2. Закупка\n- Первая дата: 10.12.2019.\n- Последняя дата: 10.12.2019.\n1. Поступление товаров и услуг 00000000111 от 10.12.2019 12:00:01 | дата: 10.12.2019 | сумма: 712.500,00 ₽ | склад: Основной склад\n\nБлок 3. Выбытие\n- Первая дата: 01.04.2020.\n- Последняя дата: 01.04.2020.\n1. Реализация товаров и услуг 00000000001 от 01.04.2020 0:00:00 | дата: 01.04.2020 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-1siZOnPNg_"}} +{"timestamp":"2026-04-14T09:02:39.191Z","level":"info","service":"assistant_loop","message":"assistant_address_tool_gate_skip","sessionId":"asst-9qcscEdiYv","details":{"session_id":"asst-9qcscEdiYv","user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","effective_address_user_message":"Проверить наличие документально подтвержденной цепочки: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотечный 1000*400*2100 -> покупатель департамент капитального ремонта города москвы","assistant_orchestration_contract_v1":{"schema_version":"assistant_orchestration_contract_v1","hard_meta_mode":null,"address_mode":"deep_analysis","address_mode_confidence":"high","address_intent":"inventory_purchase_to_sale_chain","address_intent_confidence":"medium","strong_data_signal_detected":true,"data_retrieval_signal_detected":true,"semantic_contract_valid":true,"semantic_apply_canonical_recommended":true,"semantic_reason_codes":["deep_investigation_signal_detected"],"semantic_route_arbitration":{"supported_address_intent_detected":false,"semantic_deep_investigation_hint_detected":true,"semantic_aggregate_shape_detected":false,"followup_semantic_override_to_deep_allowed":false},"followup_context_detected":false,"unsupported_address_intent_fallback_to_deep":false,"deep_analysis_signal_fallback_to_deep":true,"aggregate_analytics_signal_fallback_to_deep":false,"deep_session_continuation_fallback_to_deep":false,"final_decision":{"run_address_lane":false,"tool_gate_decision":"skip_address_lane","tool_gate_reason":"deep_analysis_signal_fallback_to_deep","living_mode":"deep_analysis","living_reason":"deep_analysis_signal_fallback_to_deep"}},"address_tool_gate_decision":"skip_address_lane","address_tool_gate_reason":"deep_analysis_signal_fallback_to_deep","address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["deep_investigation_signal_detected"]}} +{"timestamp":"2026-04-14T09:02:58.616Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-9qcscEdiYv","eventType":"assistant_message","details":{"session_id":"asst-9qcscEdiYv","message_id":"msg-rhdfhyLeWZ","user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","normalizer_output":null,"execution_plan":[],"resolved_execution_state":[],"routes":[],"retrieval_calls":[],"retrieval_results_raw":[],"retrieval_results_normalized":[],"requirements_extracted":[{"requirement_id":"R1","source_fragment_id":null,"requirement_text":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","subject_tokens":["counterparty","document","chain"],"status":"clarification_needed","route":null}],"requirements_total":1,"requirements_covered":0,"requirements_uncovered":[],"coverage_status":"partial_or_limited","answer_grounding_status":"no_grounded_answer","reply_semantic_type":"clarification_required","why_included_summary":[],"selection_reason_summary":[],"route_subject_match":true,"clarification_target":["R1"],"dropped_intent_segments":[],"question_type_class":"unknown","company_anchors":{"contract_numbers":[],"document_numbers":[],"dates":[],"amounts":[],"accounts":[],"periods":[],"document_types":[],"all":[]},"analysis_context_applied":true,"analysis_context":{"as_of_date":"2026-04-13","period_from":null,"period_to":null,"source":"scenario_pack","snapshot_mode":"auto"},"business_scope_raw":[],"business_scope_resolved":["company_specific_accounting"],"company_grounding_applied":true,"scope_resolution_reason":["settlement_claim_company_scope_recovery"],"company_scope_resolution_reason":["settlement_claim_company_scope_recovery"],"raw_time_anchor":"2026-04-13","raw_time_scope":"2026-04-13..2026-04-13","resolved_time_anchor":"2026-04-13","resolved_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"effective_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"temporal_guard_input":"2026-04-13..2026-04-13","temporal_alignment_status":"aligned","temporal_resolution_source":"scenario_pack","temporal_guard_basis":"raw_time_scope_unlocked","temporal_guard_applied":false,"temporal_guard_outcome":"passed","temporal_guard":{"raw_time_anchor":"2026-04-13","raw_time_scope":"2026-04-13..2026-04-13","resolved_time_anchor":"2026-04-13","resolved_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"effective_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"temporal_guard_input":"2026-04-13..2026-04-13","temporal_alignment_status":"aligned","temporal_resolution_source":"scenario_pack","temporal_guard_basis":"raw_time_scope_unlocked","temporal_guard_applied":false,"temporal_guard_outcome":"passed","primary_period_window":null,"allowed_context_window":null,"controlled_temporal_expansion_enabled":false,"context_expansion_reasons_allowed":["prehistory","carryover","post_period_closure","long_running_contract_context"],"normalized_anchor_drift_detected":false,"reason_codes":["analysis_context_applied"]},"raw_numeric_tokens":["1000","400","2100"],"classified_numeric_tokens":[],"rejected_as_non_accounts":[],"resolved_account_anchors":[],"domain_polarity_guard":{"applied":true,"polarity":"mixed_or_unresolved","outcome":"limited_unresolved_polarity","supplier_score":2,"customer_score":2,"account_scope":[],"raw_numeric_tokens":["1000","400","2100"],"classified_numeric_tokens":[],"rejected_as_non_accounts":[],"resolved_account_anchors":[],"rejected_problem_units":0,"rejected_evidence":0,"critical_contradiction":true,"reason_codes":["unresolved_supplier_customer_polarity","supplier_customer_signals_conflict"]},"claim_anchor_audit":{"claim_type":"prove_settlement_closure_state","settlement_role":"mixed","settlement_role_resolution_reason":["settlement_role_resolved_mixed"],"polarity_resolution_status":"mixed","required_anchors":["period","account_scope","counterparty_scope_or_contract","closure_signal"],"resolved_anchors":{"period":["2026-04-13"],"account_scope":[],"amounts":[],"contract":[],"document_numbers":[],"document_types":[],"counterparty_scope":["supplier","customer"],"advance_signal":[],"closure_signal":[],"vat_signal":[],"chain_signal":[],"close_signal":[],"cost_scope":[],"rbp_signal":[],"writeoff_signal":[],"fixed_asset_signal":[],"amortization_signal":[],"expected_fa_set":[],"actual_fa_set":[]},"missing_anchors":["account_scope","closure_signal"],"claim_anchor_resolution_rate":0.5,"primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"allowed_context_window":{"from":"2025-04-13","to":"2027-04-13","granularity":"month"},"context_expansion_reasons_allowed":["prehistory","carryover","post_period_closure","long_running_contract_context"],"reason_codes":["claim_missing_required_anchors","claim_anchor_resolution_low","unresolved_supplier_customer_polarity"]},"settlement_role":"mixed","settlement_role_resolution_reason":["settlement_role_resolved_mixed"],"polarity_resolution_status":"mixed","targeted_evidence_acquisition":{"claim_type":"prove_settlement_closure_state","required_checks":["payment_document_found","contract_matched","settlement_object_matched","closing_document_found","register_closure_entry_found","posting_link_found"],"check_status":{"payment_document_found":"not_found","contract_matched":"not_found","settlement_object_matched":"not_found","closing_document_found":"not_found","register_closure_entry_found":"not_found","posting_link_found":"not_found"},"targeted_item_hits":0,"targeted_evidence_hits":0,"targeted_evidence_hit_rate":0,"targeted_evidence_source_refs":[],"reason_codes":["targeted_evidence_not_found","targeted_evidence_hit_rate_low"]},"evidence_admissibility_gate":{"candidate_evidence_total":0,"admissible_evidence_count":0,"rejected_evidence_count":0,"rejected_item_count":0,"reject_breakdown":{"wrong_period":0,"wrong_domain":0,"wrong_account_scope":0,"weak_source_mapping":0,"zero_live_match":0,"future_dated_or_out_of_window":0},"category_breakdown":{"hard_evidence":0,"supporting_signal":0,"inadmissible_noise":0},"reason_codes":["no_admissible_evidence_for_grounded_answer"]},"eligibility_time_basis":"raw_time_scope_unlocked","grounded_answer_eligibility_guard":{"eligible":false,"temporal_passed":true,"eligibility_time_basis":"raw_time_scope_unlocked","business_scope_passed":true,"polarity_passed":false,"claim_anchors_passed":true,"claim_anchor_resolution_rate":0.5,"missing_required_anchors":2,"admissible_evidence_count":0,"critical_contradiction":true,"outcome":"limited_or_insufficient_evidence","grounding_mode":"limited_or_insufficient_evidence","reason_codes":["polarity_guard_limited_unresolved_polarity","admissible_evidence_count_zero","targeted_evidence_hit_rate_zero","critical_domain_or_account_contradiction"]},"problem_centric_answer_applied":false,"problem_units_used_count":0,"problem_answer_mode":"stage1_policy_v11","assistant_outcome_class_v1":"BLOCKED_BY_AMBIGUITY","assistant_orchestration_contracts_v1":{"query_frame":{"schema_version":"assistant_query_frame_v1","original_user_question":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","normalized_question":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","route_summary_mode":"none","fragments_total":0,"dropped_intent_segments":[],"analysis_context":{"as_of_date":"2026-04-13","period_from":null,"period_to":null,"source":"scenario_pack","snapshot_mode":"auto"}},"execution_plan":{"schema_version":"assistant_execution_plan_v1","steps":[],"requirements_total":1},"evidence_bundle":{"schema_version":"assistant_evidence_bundle_v1","retrieval_calls_total":0,"retrieval_results_total":0,"retrieval_status_breakdown":{"ok":0,"partial":0,"empty":0,"error":0},"evidence_total":0,"source_refs_total":0,"limitation_total":0,"error_total":0},"coverage":{"schema_version":"assistant_coverage_contract_v1","coverage_report":{"requirements_total":1,"requirements_covered":0,"requirements_uncovered":[],"requirements_partially_covered":[],"clarification_needed_for":["R1"],"out_of_scope_requirements":[]},"grounding":{"status":"no_grounded_answer","route_subject_match":true,"missing_requirements":["R1"],"reasons":["Ни одно требование не получило подтвержденного покрытия.","В текущей выборке не хватает явных подтверждений, почему записи попали в ответ.","Часть контекста вопроса не подтверждена напрямую в найденных данных: counterparty, document, chain","Не удалось однозначно определить сторону расчета (нам должны или мы должны).","Недостаточно подтвержденных данных для уверенного ответа.","Не хватило целевых подтверждений по выбранному сценарию.","Есть противоречие по выбранному домену или контуру счета."],"why_included_summary":[],"selection_reason_summary":[]},"outcome_class":"BLOCKED_BY_AMBIGUITY"}},"answer_contract_stage4_v1":{"schema_version":"stage4_answer_contract_audit_v1","stage4_blocks_expected":["Коротко","Что именно проверено","Что найдено","Что пока не доказано","Что проверить первым/Что могу сделать сейчас"],"stage4_blocks_present":["Коротко","Что именно проверено","Что найдено","Что пока не доказано","Что проверить первым/Что могу сделать сейчас"],"stage4_blocks_missing":[],"legacy_blocks_present":[],"is_stage4_shape":true},"answer_structure_v11":{"schema_version":"answer_structure_v1_1","answer_summary":"Нужны уточнения: без сужения фокуса надежный вывод невозможен.","direct_answer":"Есть признаки проблемы, но без уточнений по периоду и объекту вывод ненадежен.","mechanism_block":{"status":"unresolved","mechanism_notes":[],"limitation_reason_codes":[]},"evidence_block":{"evidence_ids":[],"source_refs":[],"mechanism_notes":[],"coverage_note":"coverage_partial_or_limited"},"uncertainty_block":{"open_uncertainties":["R1","missing_anchor:period","missing_anchor:account","missing_anchor:counterparty"],"limitations":["Ни одно требование не получило подтвержденного покрытия.","В текущей выборке не хватает явных подтверждений, почему записи попали в ответ.","Часть контекста вопроса не подтверждена напрямую в найденных данных: counterparty, document, chain","Не удалось однозначно определить сторону расчета (нам должны или мы должны).","Недостаточно подтвержденных данных для уверенного ответа.","Не хватило целевых подтверждений по выбранному сценарию.","Есть противоречие по выбранному домену или контуру счета."]},"next_step_block":{"recommended_actions":["Дайте недостающие якоря (период/счет/объект), иначе сильный factual вывод невозможен."],"clarification_questions":["Уточните период проверки (например, июль 2020).","Уточните счет или группу счетов (например, 19, 60, 62).","Укажите контрагента или группу контрагентов.","Закройте уточнения для требований: R1."]}},"investigation_state_snapshot":{"schema_version":"investigation_state_v1","session_id":"asst-9qcscEdiYv","status":"active","turn_index":1,"updated_at":"2026-04-14T09:02:58.613Z","question_id":"msg-SfPLbElrBX","question_scope_id":"d:settlements_60_62|s:есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотеч","scope_origin":"explicit_from_message","focus":{"domain":"settlements_60_62","period":null,"primary_accounts":[],"active_query_subject":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы"},"narrowing_status":"unknown","evidence_refs":[],"open_uncertainties":["clarify:R1"],"last_answer_mode":"clarification_required","followup_context":{"previous_question_id":null,"last_user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","referenced_requirement_ids":["R1"],"active_domain":"settlements_60_62","active_requirement_ids":["R1"],"uncovered_requirement_ids":["R1"],"last_problem_unit_id":null,"settlement_next_actions":["Проверьте договор и объект расчетов по платежу.","Сверьте регистр расчетов и привязку платежа к закрывающему документу.","Проверьте зачет аванса или взаимозачет по связке 60/62."],"evidence_summary":[],"question_scope_id":"d:settlements_60_62|s:есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотеч","scope_origin":"explicit_from_message"},"query_mode_hint":"investigation_candidate"},"fallback_type":"clarification","assistant_reply":"Коротко: По этому запросу у меня нет надежного доменного покрытия, поэтому даю мягкий отказ вместо технического шаблона.\n\nЧто именно проверено:\n- Проверен доступный контур 1С и возможность маршрутизации запроса.\n- Надежный доменный путь для текущей формулировки не подтвержден.\n\nЧто найдено:\n- Взаиморасчеты 60/62: найти хвосты, незакрытые оплаты и рисковые связки по контрагентам.\n- НДС 19/68: проверить цепочку документ -> счет-фактура -> регистр -> книга.\n- Закрытие месяца 20/44: проверить распределение затрат и остатки после регламентных операций.\n\nЧто пока не доказано:\n- Запрос не подтвержден в поддерживаемом контуре как надежный бухгалтерский сценарий.\n\nЧто могу сделать сейчас:\n- Взаиморасчеты 60/62 — найти хвосты, незакрытые оплаты и рисковые связки по контрагентам.\n- НДС 19/68 — проверить цепочку документ -> счет-фактура -> регистр -> книга.\n- Закрытие месяца 20/44 — проверить распределение затрат и остатки после регламентных операций.","reply_type":"clarification_required","trace_id":"MJPJ-rKxWt7poz"}} diff --git a/artifacts/runtime_logs/backend_8791_stderr.log b/artifacts/runtime_logs/backend_8791_stderr.log new file mode 100644 index 0000000..122504c --- /dev/null +++ b/artifacts/runtime_logs/backend_8791_stderr.log @@ -0,0 +1 @@ +[trace-completeness] trace_id=LW8OisC5j5TROG schema=v1 issues=missing_parsed_normalized_json diff --git a/artifacts/runtime_logs/backend_8791_stdout.log b/artifacts/runtime_logs/backend_8791_stdout.log new file mode 100644 index 0000000..034c90c --- /dev/null +++ b/artifacts/runtime_logs/backend_8791_stdout.log @@ -0,0 +1,22 @@ +{"timestamp":"2026-04-14T09:15:55.373Z","level":"info","service":"llm_normalizer_backend","message":"Backend started on http://localhost:8791"} +{"timestamp":"2026-04-14T09:16:31.254Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-hgcmuQG_4j","eventType":"assistant_message_address","details":{"session_id":"asst-hgcmuQG_4j","message_id":"msg-bEVSNQIJsh","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"So-0RgxmwpwYTE","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-YMhqhnVPQS"}} +{"timestamp":"2026-04-14T09:16:37.344Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-hgcmuQG_4j","eventType":"assistant_message_address","details":{"session_id":"asst-hgcmuQG_4j","message_id":"msg-KgGyicfBCZ","user_message":"Из каких товаров состоит остаток по 41 счету","effective_address_user_message":"Какие товары составляют остаток на счете 41","address_followup_context_applied":true,"address_followup_context_previous_intent":"inventory_on_hand_as_of_date","address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"oyPGz5uoPO5XwZ","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"из каких товаров состоит остаток по 41 счету","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"continue_previous","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-myxycY0Q0y"}} +{"timestamp":"2026-04-14T09:16:43.428Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-hgcmuQG_4j","eventType":"assistant_message_address","details":{"session_id":"asst-hgcmuQG_4j","message_id":"msg-75zrB4vk9L","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31","effective_address_user_message":"Получить список товаров, находящихся на счете 41 на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"gIC-SoSyzdLmOs","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-TVPVoi8DpZ"}} +{"timestamp":"2026-04-14T09:16:49.549Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-hgcmuQG_4j","eventType":"assistant_message_address","details":{"session_id":"asst-hgcmuQG_4j","message_id":"msg-ZezBrt0KiA","user_message":"Какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","effective_address_user_message":"Получить список номенклатур, формирующих остаток на складе на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"w8Q_XZCzMC8gKJ","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-KWLqlX3fo1"}} +{"timestamp":"2026-04-14T09:16:55.641Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-oTV2aKGDUs","eventType":"assistant_message_address","details":{"session_id":"asst-oTV2aKGDUs","message_id":"msg-yFllYal5Mi","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"Ms4E11ErFEkZ5A","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-tf-LmUU3Rr"}} +{"timestamp":"2026-04-14T09:17:03.535Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-oTV2aKGDUs","eventType":"assistant_message_address","details":{"session_id":"asst-oTV2aKGDUs","message_id":"msg-vC5vpkU6B3","user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"lg6ObFTLCB4hEc","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"от какого поставщика куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный закупочный след по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные закупочные движения на 41.01 по выбранному товару.\n- Важно: без партионности этот контур не подменяет собой лот-level доказательство происхождения текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 24.08.2018.\n- Последняя найденная дата закупочного движения: 24.08.2018.\n- Документов поступления: 1.\n- Операций поступления: 1.\n- Закупочные документы найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Опорные документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-e_XHfxA6ux"}} +{"timestamp":"2026-04-14T09:17:11.709Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-oTV2aKGDUs","eventType":"assistant_message_address","details":{"session_id":"asst-oTV2aKGDUs","message_id":"msg-bRFiAMi9ZE","user_message":"У какого поставщика были куплены товары, которые сейчас лежат на складе Основной склад организации ООО \\Альтернатива Плюс\\","effective_address_user_message":"Определить поставщиков, у которых были приобретены товары, находящиеся на складе 'Основной склад' в компании 'ООО Альтернатива Плюс'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"7cGLyX15XD9Z6g","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"у какого поставщика были куплены товары, которые сейчас лежат на складе основной склад организации ооо \\альтернатива плюс\\","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-VSZEy4iy0-"}} +{"timestamp":"2026-04-14T09:17:18.890Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-oTV2aKGDUs","eventType":"assistant_message_address","details":{"session_id":"asst-oTV2aKGDUs","message_id":"msg-g_rkolsds8","user_message":"По какому поставщику проходит текущий товарный остаток на складе Основной склад","effective_address_user_message":"Получить информацию о поставщике, связанным с текущим товарным остатком на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"Ey9DOV7gKOzbVS","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"по какому поставщику проходит текущий товарный остаток на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-ILJgBF7IkL"}} +{"timestamp":"2026-04-14T09:17:26.878Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-oTV2aKGDUs","eventType":"assistant_message_address","details":{"session_id":"asst-oTV2aKGDUs","message_id":"msg-5C9r4Npvah","user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"Aap8qftkHE33aO","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"когда был куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный закупочный след по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные закупочные движения на 41.01 по выбранному товару.\n- Важно: без партионности этот контур не подменяет собой лот-level доказательство происхождения текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 24.08.2018.\n- Последняя найденная дата закупочного движения: 24.08.2018.\n- Документов поступления: 1.\n- Операций поступления: 1.\n- Закупочные документы найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Опорные документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-pzoEZi14tD"}} +{"timestamp":"2026-04-14T09:17:35.115Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-oTV2aKGDUs","eventType":"assistant_message_address","details":{"session_id":"asst-oTV2aKGDUs","message_id":"msg-bjG4ITQ8R2","user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","effective_address_user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"XHARJQGPgmdxPt","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"по каким документам был куплен товар диван трехместный для остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_documents_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_documents_for_item","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_documents_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_documents_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный список документов поступления по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденные движения поступления товара на 41.01 по доступным бухгалтерским проводкам.\n\nБлок 2. Что учтено\n- Дата верхней границы: 14.04.2026.\n- Контур: движения, где товар поступает на счет 41.01.\n- Документов в выборке: 1.\n- Операций в выборке: 1.\n\nБлок 3. Документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-nRBW9LD27M"}} +{"timestamp":"2026-04-14T09:17:43.238Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-oTV2aKGDUs","eventType":"assistant_message_address","details":{"session_id":"asst-oTV2aKGDUs","message_id":"msg-DiHrRT4uav","user_message":"Какие товары от поставщика Гамма-мебель, ООО сейчас еще лежат на складе Основной склад","effective_address_user_message":"Получить информацию о товарах от поставщика 'Гамма-мебель, ООО', которые находятся на складе 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"4VMo9s9b_fJqeb","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары от поставщика гамма-мебель, ооо сейчас еще лежат на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","counterparty":"Гамма-мебель, ООО',","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":41,"rows_materialized":500,"rows_matched":41,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 13.05.2019.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 11.\n- Закупочных операций в выборке: 41.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 41.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n3. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n4. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 28.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n5. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 199.671,66 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n6. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 62.150,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n7. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 16.880,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 159.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n9. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 23.660,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n10. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 75.075,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-OSJxznRbzs"}} +{"timestamp":"2026-04-14T09:17:51.358Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-oTV2aKGDUs","eventType":"assistant_message_address","details":{"session_id":"asst-oTV2aKGDUs","message_id":"msg-OyJwvNRh6D","user_message":"Какие товары по состоянию на дату 2020-03-31 на складе Основной склад были куплены у поставщика Гамма-мебель, ООО","effective_address_user_message":"Получить список товаров на складе 'Основной склад' по состоянию на 2020-03-31, приобретенных у поставщика 'Гамма-мебель, ООО'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"Z2v_eUEh49iHd_","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары по состоянию на дату 2020-03-31 на складе основной склад были куплены у поставщика гамма-мебель, ооо","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","counterparty":"Гамма-мебель, ООО","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":41,"rows_materialized":500,"rows_matched":41,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 31.03.2020.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 13.05.2019.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 11.\n- Закупочных операций в выборке: 41.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 41.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n3. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n4. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 28.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n5. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 199.671,66 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n6. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 159.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n7. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 23.660,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 62.150,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n9. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 16.880,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n10. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 75.075,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-QeLZYQcz1z"}} +{"timestamp":"2026-04-14T09:17:57.634Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-wg00A-hM40","eventType":"assistant_message_address","details":{"session_id":"asst-wg00A-hM40","message_id":"msg-sDUi3znw9F","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"mUN1OBQRH0nhan","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-C3bY84qc3K"}} +{"timestamp":"2026-04-14T09:18:05.562Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-wg00A-hM40","eventType":"assistant_message_address","details":{"session_id":"asst-wg00A-hM40","message_id":"msg-4ooYQQKSJ_","user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","effective_address_user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"gl_zOku3XWKJDx","address_llm_predecompose_reason":"normalized_fragment_rejected_semantic_guard","address_fallback_rule_hit":null,"address_sanitized_user_message":"относится ли товар шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_aging_by_purchase_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_aging_by_purchase_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_aging_by_purchase_date","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_aging_by_purchase_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":1,"rows_materialized":500,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран exact-срез возраста закупочного следа по Шкаф картотечный 1000*400*2100 до 31.03.2020.\n\nБлок 1. Статус результата\n- Контур: показаны подтвержденные закупочные движения на 41.01 и их временной разброс.\n- Важно: без партионности этот контур не доказывает возраст конкретного лота, а показывает документально наблюдаемый диапазон закупок.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 10.12.2019.\n- Последняя найденная дата закупочного движения: 10.12.2019.\n- Закупочных документов в выборке: 1.\n- Закупочных операций в выборке: 1.\n- Между самой ранней найденной закупкой и датой среза прошло 112 дн.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000111 от 10.12.2019 12:00:01 | дата: 10.12.2019 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-kaiq8BRaIH"}} +{"timestamp":"2026-04-14T09:18:13.590Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-wg00A-hM40","eventType":"assistant_message_address","details":{"session_id":"asst-wg00A-hM40","message_id":"msg-c2gVadiE0H","user_message":"Есть ли на складе Основной склад товары с остатком без понятной привязки к поставщику","effective_address_user_message":"Есть ли на складе Основной склад товары с остатком без понятной привязки к поставщику","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"uU6E0fFzrPPXYV","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли на складе основной склад товары с остатком без понятной привязки к поставщику","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract","deep_investigation_signal_detected"],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад товары","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":487,"rows_materialized":500,"rows_matched":487,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 90.\n- Закупочных операций в выборке: 487.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 464.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-LMjKrVKsjW"}} +{"timestamp":"2026-04-14T09:18:20.797Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-wg00A-hM40","eventType":"assistant_message_address","details":{"session_id":"asst-wg00A-hM40","message_id":"msg-1kyCtFloJk","user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","effective_address_user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"YRKa_hJt5SuCXo","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли среди текущих остатков на складе основной склад позиции, закупленные задолго до 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_aging_by_purchase_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_aging_by_purchase_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_aging_by_purchase_date","extracted_filters":{"sort":"period_desc","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_aging_by_purchase_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран exact-срез возраста закупочного следа по Конструкция трансформер рабочей станции 1300*900*2000 до 31.03.2020.\n\nБлок 1. Статус результата\n- Контур: показаны подтвержденные закупочные движения на 41.01 и их временной разброс.\n- Важно: без партионности этот контур не доказывает возраст конкретного лота, а показывает документально наблюдаемый диапазон закупок.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 25.12.2015.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 111.\n- Закупочных операций в выборке: 500.\n- Между самой ранней найденной закупкой и датой среза прошло 1.558 дн.\n- Поставщики, встречающиеся в наблюдаемом закупочном следе: ПрофТренд,ООО; Группа Компаний Спектр.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000111 от 10.12.2019 12:00:01 | дата: 10.12.2019 | сумма: 712.500,00 ₽ | склад: Основной склад\n3. Комплектация номенклатуры 00000000002 от 09.12.2019 21:00:00 | дата: 09.12.2019 | сумма: 2.206.750,00 ₽ | склад: Основной склад\n4. Комплектация номенклатуры 00000000002 от 09.12.2019 21:00:00 | дата: 09.12.2019 | сумма: 544.050,00 ₽ | склад: Основной склад\n5. Комплектация номенклатуры 00000000002 от 09.12.2019 21:00:00 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад\n6. Комплектация номенклатуры 00000000002 от 09.12.2019 21:00:00 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад\n7. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-CqRSGhk4wG"}} +{"timestamp":"2026-04-14T09:18:27.117Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-1-dZ4jw4tb","eventType":"assistant_message_address","details":{"session_id":"asst-1-dZ4jw4tb","message_id":"msg-0tRd6qTWyg","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31 на складе Основной склад","effective_address_user_message":"Получить список товаров, находящихся на счете 41 на дату 2020-03-31 для склада 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"hRp4RMbc5o2FEr","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31 на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-dXwoj8Wkbi"}} +{"timestamp":"2026-04-14T09:18:34.076Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-1-dZ4jw4tb","eventType":"assistant_message_address","details":{"session_id":"asst-1-dZ4jw4tb","message_id":"msg-dPA024rq6U","user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","effective_address_user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"pwJyah_Sty17t9","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"кому был продан товар шкаф картотечный 1000*400*2100","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_sale_trace_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_sale_trace_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_sale_trace_for_item","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_sale_trace_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный след выбытия по товару товар до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные движения выбытия товара со счета 41.01.\n\nБлок 2. Сводка\n- Первая найденная дата выбытия: 01.04.2020.\n- Последняя найденная дата выбытия: 01.04.2020.\n- Документов выбытия: 1.\n- Операций выбытия: 1.\n- Документы выбытия найдены, но покупатель не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Документы выбытия\n1. Реализация товаров и услуг 00000000001 от 01.04.2020 0:00:00 | дата: 01.04.2020 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-NcSgp-ICcP"}} +{"timestamp":"2026-04-14T09:18:43.311Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-1-dZ4jw4tb","eventType":"assistant_message_address","details":{"session_id":"asst-1-dZ4jw4tb","message_id":"msg-srZQmHQjF1","user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","effective_address_user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"EOpj-Ke4ZxK3BY","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"через какие документы прошел путь товара шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_to_sale_chain","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_to_sale_chain","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_to_sale_chain_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":600,"raw_rows_received":600,"rows_after_account_scope":600,"rows_after_recipe_filter":2,"rows_materialized":600,"rows_matched":2,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собрана документальная цепочка по товару Шкаф картотечный 1000*400*2100 до 14.04.2026.\n\nБлок 1. Статус результата\n- Закупочных движений на 41.01: 1.\n- Движений выбытия со счета 41.01: 1.\n- В текущем контуре найдены обе стороны цепочки: поступление и последующее выбытие.\n\nБлок 2. Закупка\n- Первая дата: 10.12.2019.\n- Последняя дата: 10.12.2019.\n1. Поступление товаров и услуг 00000000111 от 10.12.2019 12:00:01 | дата: 10.12.2019 | сумма: 712.500,00 ₽ | склад: Основной склад\n\nБлок 3. Выбытие\n- Первая дата: 01.04.2020.\n- Последняя дата: 01.04.2020.\n1. Реализация товаров и услуг 00000000001 от 01.04.2020 0:00:00 | дата: 01.04.2020 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-p8akirJxMe"}} +{"timestamp":"2026-04-14T09:18:53.233Z","level":"info","service":"assistant_loop","message":"assistant_address_tool_gate_skip","sessionId":"asst-1-dZ4jw4tb","details":{"session_id":"asst-1-dZ4jw4tb","user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","effective_address_user_message":"Проверить наличие документально подтвержденной цепочки: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотечный 1000*400*2100 -> покупатель департамент капитального ремонта города москвы","assistant_orchestration_contract_v1":{"schema_version":"assistant_orchestration_contract_v1","hard_meta_mode":null,"address_mode":"deep_analysis","address_mode_confidence":"high","address_intent":"inventory_purchase_to_sale_chain","address_intent_confidence":"medium","strong_data_signal_detected":true,"data_retrieval_signal_detected":true,"semantic_contract_valid":true,"semantic_apply_canonical_recommended":true,"semantic_reason_codes":["deep_investigation_signal_detected"],"semantic_route_arbitration":{"supported_address_intent_detected":false,"semantic_deep_investigation_hint_detected":true,"semantic_aggregate_shape_detected":false,"followup_semantic_override_to_deep_allowed":false},"followup_context_detected":false,"unsupported_address_intent_fallback_to_deep":false,"deep_analysis_signal_fallback_to_deep":true,"aggregate_analytics_signal_fallback_to_deep":false,"deep_session_continuation_fallback_to_deep":false,"final_decision":{"run_address_lane":false,"tool_gate_decision":"skip_address_lane","tool_gate_reason":"deep_analysis_signal_fallback_to_deep","living_mode":"deep_analysis","living_reason":"deep_analysis_signal_fallback_to_deep"}},"address_tool_gate_decision":"skip_address_lane","address_tool_gate_reason":"deep_analysis_signal_fallback_to_deep","address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["deep_investigation_signal_detected"]}} +{"timestamp":"2026-04-14T09:19:12.878Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-1-dZ4jw4tb","eventType":"assistant_message","details":{"session_id":"asst-1-dZ4jw4tb","message_id":"msg-_P1QCml-Pu","user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","normalizer_output":null,"execution_plan":[],"resolved_execution_state":[],"routes":[],"retrieval_calls":[],"retrieval_results_raw":[],"retrieval_results_normalized":[],"requirements_extracted":[{"requirement_id":"R1","source_fragment_id":null,"requirement_text":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","subject_tokens":["counterparty","document","chain"],"status":"clarification_needed","route":null}],"requirements_total":1,"requirements_covered":0,"requirements_uncovered":[],"coverage_status":"partial_or_limited","answer_grounding_status":"no_grounded_answer","reply_semantic_type":"clarification_required","why_included_summary":[],"selection_reason_summary":[],"route_subject_match":true,"clarification_target":["R1"],"dropped_intent_segments":[],"question_type_class":"unknown","company_anchors":{"contract_numbers":[],"document_numbers":[],"dates":[],"amounts":[],"accounts":[],"periods":[],"document_types":[],"all":[]},"analysis_context_applied":true,"analysis_context":{"as_of_date":"2026-04-13","period_from":null,"period_to":null,"source":"scenario_pack","snapshot_mode":"auto"},"business_scope_raw":[],"business_scope_resolved":["company_specific_accounting"],"company_grounding_applied":true,"scope_resolution_reason":["settlement_claim_company_scope_recovery"],"company_scope_resolution_reason":["settlement_claim_company_scope_recovery"],"raw_time_anchor":"2026-04-13","raw_time_scope":"2026-04-13..2026-04-13","resolved_time_anchor":"2026-04-13","resolved_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"effective_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"temporal_guard_input":"2026-04-13..2026-04-13","temporal_alignment_status":"aligned","temporal_resolution_source":"scenario_pack","temporal_guard_basis":"raw_time_scope_unlocked","temporal_guard_applied":false,"temporal_guard_outcome":"passed","temporal_guard":{"raw_time_anchor":"2026-04-13","raw_time_scope":"2026-04-13..2026-04-13","resolved_time_anchor":"2026-04-13","resolved_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"effective_primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"temporal_guard_input":"2026-04-13..2026-04-13","temporal_alignment_status":"aligned","temporal_resolution_source":"scenario_pack","temporal_guard_basis":"raw_time_scope_unlocked","temporal_guard_applied":false,"temporal_guard_outcome":"passed","primary_period_window":null,"allowed_context_window":null,"controlled_temporal_expansion_enabled":false,"context_expansion_reasons_allowed":["prehistory","carryover","post_period_closure","long_running_contract_context"],"normalized_anchor_drift_detected":false,"reason_codes":["analysis_context_applied"]},"raw_numeric_tokens":["1000","400","2100"],"classified_numeric_tokens":[],"rejected_as_non_accounts":[],"resolved_account_anchors":[],"domain_polarity_guard":{"applied":true,"polarity":"mixed_or_unresolved","outcome":"limited_unresolved_polarity","supplier_score":2,"customer_score":2,"account_scope":[],"raw_numeric_tokens":["1000","400","2100"],"classified_numeric_tokens":[],"rejected_as_non_accounts":[],"resolved_account_anchors":[],"rejected_problem_units":0,"rejected_evidence":0,"critical_contradiction":true,"reason_codes":["unresolved_supplier_customer_polarity","supplier_customer_signals_conflict"]},"claim_anchor_audit":{"claim_type":"prove_settlement_closure_state","settlement_role":"mixed","settlement_role_resolution_reason":["settlement_role_resolved_mixed"],"polarity_resolution_status":"mixed","required_anchors":["period","account_scope","counterparty_scope_or_contract","closure_signal"],"resolved_anchors":{"period":["2026-04-13"],"account_scope":[],"amounts":[],"contract":[],"document_numbers":[],"document_types":[],"counterparty_scope":["supplier","customer"],"advance_signal":[],"closure_signal":[],"vat_signal":[],"chain_signal":[],"close_signal":[],"cost_scope":[],"rbp_signal":[],"writeoff_signal":[],"fixed_asset_signal":[],"amortization_signal":[],"expected_fa_set":[],"actual_fa_set":[]},"missing_anchors":["account_scope","closure_signal"],"claim_anchor_resolution_rate":0.5,"primary_period":{"from":"2026-04-13","to":"2026-04-13","granularity":"day"},"allowed_context_window":{"from":"2025-04-13","to":"2027-04-13","granularity":"month"},"context_expansion_reasons_allowed":["prehistory","carryover","post_period_closure","long_running_contract_context"],"reason_codes":["claim_missing_required_anchors","claim_anchor_resolution_low","unresolved_supplier_customer_polarity"]},"settlement_role":"mixed","settlement_role_resolution_reason":["settlement_role_resolved_mixed"],"polarity_resolution_status":"mixed","targeted_evidence_acquisition":{"claim_type":"prove_settlement_closure_state","required_checks":["payment_document_found","contract_matched","settlement_object_matched","closing_document_found","register_closure_entry_found","posting_link_found"],"check_status":{"payment_document_found":"not_found","contract_matched":"not_found","settlement_object_matched":"not_found","closing_document_found":"not_found","register_closure_entry_found":"not_found","posting_link_found":"not_found"},"targeted_item_hits":0,"targeted_evidence_hits":0,"targeted_evidence_hit_rate":0,"targeted_evidence_source_refs":[],"reason_codes":["targeted_evidence_not_found","targeted_evidence_hit_rate_low"]},"evidence_admissibility_gate":{"candidate_evidence_total":0,"admissible_evidence_count":0,"rejected_evidence_count":0,"rejected_item_count":0,"reject_breakdown":{"wrong_period":0,"wrong_domain":0,"wrong_account_scope":0,"weak_source_mapping":0,"zero_live_match":0,"future_dated_or_out_of_window":0},"category_breakdown":{"hard_evidence":0,"supporting_signal":0,"inadmissible_noise":0},"reason_codes":["no_admissible_evidence_for_grounded_answer"]},"eligibility_time_basis":"raw_time_scope_unlocked","grounded_answer_eligibility_guard":{"eligible":false,"temporal_passed":true,"eligibility_time_basis":"raw_time_scope_unlocked","business_scope_passed":true,"polarity_passed":false,"claim_anchors_passed":true,"claim_anchor_resolution_rate":0.5,"missing_required_anchors":2,"admissible_evidence_count":0,"critical_contradiction":true,"outcome":"limited_or_insufficient_evidence","grounding_mode":"limited_or_insufficient_evidence","reason_codes":["polarity_guard_limited_unresolved_polarity","admissible_evidence_count_zero","targeted_evidence_hit_rate_zero","critical_domain_or_account_contradiction"]},"problem_centric_answer_applied":false,"problem_units_used_count":0,"problem_answer_mode":"stage1_policy_v11","assistant_outcome_class_v1":"BLOCKED_BY_AMBIGUITY","assistant_orchestration_contracts_v1":{"query_frame":{"schema_version":"assistant_query_frame_v1","original_user_question":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","normalized_question":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","route_summary_mode":"none","fragments_total":0,"dropped_intent_segments":[],"analysis_context":{"as_of_date":"2026-04-13","period_from":null,"period_to":null,"source":"scenario_pack","snapshot_mode":"auto"}},"execution_plan":{"schema_version":"assistant_execution_plan_v1","steps":[],"requirements_total":1},"evidence_bundle":{"schema_version":"assistant_evidence_bundle_v1","retrieval_calls_total":0,"retrieval_results_total":0,"retrieval_status_breakdown":{"ok":0,"partial":0,"empty":0,"error":0},"evidence_total":0,"source_refs_total":0,"limitation_total":0,"error_total":0},"coverage":{"schema_version":"assistant_coverage_contract_v1","coverage_report":{"requirements_total":1,"requirements_covered":0,"requirements_uncovered":[],"requirements_partially_covered":[],"clarification_needed_for":["R1"],"out_of_scope_requirements":[]},"grounding":{"status":"no_grounded_answer","route_subject_match":true,"missing_requirements":["R1"],"reasons":["Ни одно требование не получило подтвержденного покрытия.","В текущей выборке не хватает явных подтверждений, почему записи попали в ответ.","Часть контекста вопроса не подтверждена напрямую в найденных данных: counterparty, document, chain","Не удалось однозначно определить сторону расчета (нам должны или мы должны).","Недостаточно подтвержденных данных для уверенного ответа.","Не хватило целевых подтверждений по выбранному сценарию.","Есть противоречие по выбранному домену или контуру счета."],"why_included_summary":[],"selection_reason_summary":[]},"outcome_class":"BLOCKED_BY_AMBIGUITY"}},"answer_contract_stage4_v1":{"schema_version":"stage4_answer_contract_audit_v1","stage4_blocks_expected":["Коротко","Что именно проверено","Что найдено","Что пока не доказано","Что проверить первым/Что могу сделать сейчас"],"stage4_blocks_present":["Коротко","Что именно проверено","Что найдено","Что пока не доказано","Что проверить первым/Что могу сделать сейчас"],"stage4_blocks_missing":[],"legacy_blocks_present":[],"is_stage4_shape":true},"answer_structure_v11":{"schema_version":"answer_structure_v1_1","answer_summary":"Нужны уточнения: без сужения фокуса надежный вывод невозможен.","direct_answer":"Есть признаки проблемы, но без уточнений по периоду и объекту вывод ненадежен.","mechanism_block":{"status":"unresolved","mechanism_notes":[],"limitation_reason_codes":[]},"evidence_block":{"evidence_ids":[],"source_refs":[],"mechanism_notes":[],"coverage_note":"coverage_partial_or_limited"},"uncertainty_block":{"open_uncertainties":["R1","missing_anchor:period","missing_anchor:account","missing_anchor:counterparty"],"limitations":["Ни одно требование не получило подтвержденного покрытия.","В текущей выборке не хватает явных подтверждений, почему записи попали в ответ.","Часть контекста вопроса не подтверждена напрямую в найденных данных: counterparty, document, chain","Не удалось однозначно определить сторону расчета (нам должны или мы должны).","Недостаточно подтвержденных данных для уверенного ответа.","Не хватило целевых подтверждений по выбранному сценарию.","Есть противоречие по выбранному домену или контуру счета."]},"next_step_block":{"recommended_actions":["Дайте недостающие якоря (период/счет/объект), иначе сильный factual вывод невозможен."],"clarification_questions":["Уточните период проверки (например, июль 2020).","Уточните счет или группу счетов (например, 19, 60, 62).","Укажите контрагента или группу контрагентов.","Закройте уточнения для требований: R1."]}},"investigation_state_snapshot":{"schema_version":"investigation_state_v1","session_id":"asst-1-dZ4jw4tb","status":"active","turn_index":1,"updated_at":"2026-04-14T09:19:12.873Z","question_id":"msg-gDAEWdbBoI","question_scope_id":"d:settlements_60_62|s:есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотеч","scope_origin":"explicit_from_message","focus":{"domain":"settlements_60_62","period":null,"primary_accounts":[],"active_query_subject":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы"},"narrowing_status":"unknown","evidence_refs":[],"open_uncertainties":["clarify:R1"],"last_answer_mode":"clarification_required","followup_context":{"previous_question_id":null,"last_user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","referenced_requirement_ids":["R1"],"active_domain":"settlements_60_62","active_requirement_ids":["R1"],"uncovered_requirement_ids":["R1"],"last_problem_unit_id":null,"settlement_next_actions":["Проверьте договор и объект расчетов по платежу.","Сверьте регистр расчетов и привязку платежа к закрывающему документу.","Проверьте зачет аванса или взаимозачет по связке 60/62."],"evidence_summary":[],"question_scope_id":"d:settlements_60_62|s:есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотеч","scope_origin":"explicit_from_message"},"query_mode_hint":"investigation_candidate"},"fallback_type":"clarification","assistant_reply":"Коротко: По этому запросу у меня нет надежного доменного покрытия, поэтому даю мягкий отказ вместо технического шаблона.\n\nЧто именно проверено:\n- Проверен доступный контур 1С и возможность маршрутизации запроса.\n- Надежный доменный путь для текущей формулировки не подтвержден.\n\nЧто найдено:\n- Взаиморасчеты 60/62: найти хвосты, незакрытые оплаты и рисковые связки по контрагентам.\n- НДС 19/68: проверить цепочку документ -> счет-фактура -> регистр -> книга.\n- Закрытие месяца 20/44: проверить распределение затрат и остатки после регламентных операций.\n\nЧто пока не доказано:\n- Запрос не подтвержден в поддерживаемом контуре как надежный бухгалтерский сценарий.\n\nЧто могу сделать сейчас:\n- Взаиморасчеты 60/62 — найти хвосты, незакрытые оплаты и рисковые связки по контрагентам.\n- НДС 19/68 — проверить цепочку документ -> счет-фактура -> регистр -> книга.\n- Закрытие месяца 20/44 — проверить распределение затрат и остатки после регламентных операций.","reply_type":"clarification_required","trace_id":"LW8OisC5j5TROG"}} diff --git a/artifacts/runtime_logs/backend_8792_stderr.log b/artifacts/runtime_logs/backend_8792_stderr.log new file mode 100644 index 0000000..e69de29 diff --git a/artifacts/runtime_logs/backend_8792_stdout.log b/artifacts/runtime_logs/backend_8792_stdout.log new file mode 100644 index 0000000..fcf804b --- /dev/null +++ b/artifacts/runtime_logs/backend_8792_stdout.log @@ -0,0 +1,21 @@ +{"timestamp":"2026-04-14T09:27:04.625Z","level":"info","service":"llm_normalizer_backend","message":"Backend started on http://localhost:8792"} +{"timestamp":"2026-04-14T09:27:36.054Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Mvy8EyoPdf","eventType":"assistant_message_address","details":{"session_id":"asst-Mvy8EyoPdf","message_id":"msg-mix-Fqr2Wa","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"hla8E5fSH6moxh","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-08-gZjuiIi"}} +{"timestamp":"2026-04-14T09:27:42.143Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Mvy8EyoPdf","eventType":"assistant_message_address","details":{"session_id":"asst-Mvy8EyoPdf","message_id":"msg-uQxE__0aze","user_message":"Из каких товаров состоит остаток по 41 счету","effective_address_user_message":"Из каких товаров состоит остаток по 41 счету","address_followup_context_applied":true,"address_followup_context_previous_intent":"inventory_on_hand_as_of_date","address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"rf-ajmAm9A9giP","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"из каких товаров состоит остаток по 41 счету","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"continue_previous","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-870eBxMJgx"}} +{"timestamp":"2026-04-14T09:27:48.264Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Mvy8EyoPdf","eventType":"assistant_message_address","details":{"session_id":"asst-Mvy8EyoPdf","message_id":"msg-gP5V2exVQ6","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31","effective_address_user_message":"Получить список товаров, находящихся на счете 41 на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"Kj3PseMoRWlMB0","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-2DV7cx1_rW"}} +{"timestamp":"2026-04-14T09:27:54.295Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-Mvy8EyoPdf","eventType":"assistant_message_address","details":{"session_id":"asst-Mvy8EyoPdf","message_id":"msg--Pc88DFjIv","user_message":"Какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","effective_address_user_message":"Получить список номенклатур, формирующих остаток на складе на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"YKSrU5fIxqx7r3","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-BGlMw_XwUL"}} +{"timestamp":"2026-04-14T09:28:00.441Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-H7HBEUnbQN","eventType":"assistant_message_address","details":{"session_id":"asst-H7HBEUnbQN","message_id":"msg-_6ZpdDnuwa","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"EjLiLKob-IgtVA","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-XDnMMMT6-X"}} +{"timestamp":"2026-04-14T09:28:08.662Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-H7HBEUnbQN","eventType":"assistant_message_address","details":{"session_id":"asst-H7HBEUnbQN","message_id":"msg-QriEfuI1Yt","user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"OyqpJhsECwJxoH","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"от какого поставщика куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный закупочный след по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные закупочные движения на 41.01 по выбранному товару.\n- Важно: без партионности этот контур не подменяет собой лот-level доказательство происхождения текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 24.08.2018.\n- Последняя найденная дата закупочного движения: 24.08.2018.\n- Документов поступления: 1.\n- Операций поступления: 1.\n- Закупочные документы найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Опорные документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-EI61skH9Za"}} +{"timestamp":"2026-04-14T09:28:16.949Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-H7HBEUnbQN","eventType":"assistant_message_address","details":{"session_id":"asst-H7HBEUnbQN","message_id":"msg-4QIQ-UCWdu","user_message":"У какого поставщика были куплены товары, которые сейчас лежат на складе Основной склад организации ООО \\Альтернатива Плюс\\","effective_address_user_message":"Определить поставщиков, у которых были приобретены товары, находящиеся на складе 'Основной склад' в компании 'ООО Альтернатива Плюс'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"lMTf-Gg7JDPs9_","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"у какого поставщика были куплены товары, которые сейчас лежат на складе основной склад организации ооо \\альтернатива плюс\\","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-xOfoYtdJA8"}} +{"timestamp":"2026-04-14T09:28:24.191Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-H7HBEUnbQN","eventType":"assistant_message_address","details":{"session_id":"asst-H7HBEUnbQN","message_id":"msg-CZ650qEFhB","user_message":"По какому поставщику проходит текущий товарный остаток на складе Основной склад","effective_address_user_message":"Получить информацию о поставщике, связанным с текущим товарным остатком на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"YViDSCNzgej2Vd","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"по какому поставщику проходит текущий товарный остаток на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-LesMDjm48e"}} +{"timestamp":"2026-04-14T09:28:32.588Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-H7HBEUnbQN","eventType":"assistant_message_address","details":{"session_id":"asst-H7HBEUnbQN","message_id":"msg-k1fY3HLDPb","user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"DEmsIP8QiGEF0T","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"когда был куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный закупочный след по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные закупочные движения на 41.01 по выбранному товару.\n- Важно: без партионности этот контур не подменяет собой лот-level доказательство происхождения текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 24.08.2018.\n- Последняя найденная дата закупочного движения: 24.08.2018.\n- Документов поступления: 1.\n- Операций поступления: 1.\n- Закупочные документы найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Опорные документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-XBXYMi4R1F"}} +{"timestamp":"2026-04-14T09:28:40.788Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-H7HBEUnbQN","eventType":"assistant_message_address","details":{"session_id":"asst-H7HBEUnbQN","message_id":"msg-Q-IM2Bj5fa","user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","effective_address_user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"CJInyizoc55cZi","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"по каким документам был куплен товар диван трехместный для остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_documents_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_documents_for_item","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_documents_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_documents_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный список документов поступления по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденные движения поступления товара на 41.01 по доступным бухгалтерским проводкам.\n\nБлок 2. Что учтено\n- Дата верхней границы: 14.04.2026.\n- Контур: движения, где товар поступает на счет 41.01.\n- Документов в выборке: 1.\n- Операций в выборке: 1.\n\nБлок 3. Документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-9h0sXB557D"}} +{"timestamp":"2026-04-14T09:28:49.129Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-H7HBEUnbQN","eventType":"assistant_message_address","details":{"session_id":"asst-H7HBEUnbQN","message_id":"msg-2BPNpxK10N","user_message":"Какие товары от поставщика Гамма-мебель, ООО сейчас еще лежат на складе Основной склад","effective_address_user_message":"Получить информацию о товарах от поставщика 'Гамма-мебель, ООО', которые находятся на складе 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"HDyz7UYDTh8VaH","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары от поставщика гамма-мебель, ооо сейчас еще лежат на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","counterparty":"Гамма-мебель, ООО',","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":41,"rows_materialized":500,"rows_matched":41,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 13.05.2019.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 11.\n- Закупочных операций в выборке: 41.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 41.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n3. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n4. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 28.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n5. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 199.671,66 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n6. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 62.150,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n7. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 16.880,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 159.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n9. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 23.660,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n10. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 75.075,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-MljoSB4ZLS"}} +{"timestamp":"2026-04-14T09:28:57.456Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-H7HBEUnbQN","eventType":"assistant_message_address","details":{"session_id":"asst-H7HBEUnbQN","message_id":"msg-DGdNcfTpz9","user_message":"Какие товары по состоянию на дату 2020-03-31 на складе Основной склад были куплены у поставщика Гамма-мебель, ООО","effective_address_user_message":"Список товаров на складе 'Основной склад' по состоянию на 2020-03-31, приобретенных у поставщика 'Гамма-мебель, ООО'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"ERA8hCQloqqslu","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары по состоянию на дату 2020-03-31 на складе основной склад были куплены у поставщика гамма-мебель, ооо","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","counterparty":"Гамма-мебель, ООО","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":41,"rows_materialized":500,"rows_matched":41,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 31.03.2020.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 13.05.2019.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 11.\n- Закупочных операций в выборке: 41.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 41.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n3. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n4. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 28.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n5. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 199.671,66 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n6. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 159.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n7. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 23.660,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 62.150,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n9. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 16.880,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n10. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 75.075,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-5P3to2zUar"}} +{"timestamp":"2026-04-14T09:29:03.735Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-cyqB2PiFhg","eventType":"assistant_message_address","details":{"session_id":"asst-cyqB2PiFhg","message_id":"msg-bHfB3LnZ8l","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"qDkTL3QbIZYSyh","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-NIEbpaW5fj"}} +{"timestamp":"2026-04-14T09:29:11.763Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-cyqB2PiFhg","eventType":"assistant_message_address","details":{"session_id":"asst-cyqB2PiFhg","message_id":"msg-cJCvxj-dO1","user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","effective_address_user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"zXyIvv_Yf5abjL","address_llm_predecompose_reason":"normalized_fragment_rejected_semantic_guard","address_fallback_rule_hit":null,"address_sanitized_user_message":"относится ли товар шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_aging_by_purchase_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_aging_by_purchase_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_aging_by_purchase_date","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_aging_by_purchase_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":1,"rows_materialized":500,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран exact-срез возраста закупочного следа по Шкаф картотечный 1000*400*2100 до 31.03.2020.\n\nБлок 1. Статус результата\n- Контур: показаны подтвержденные закупочные движения на 41.01 и их временной разброс.\n- Важно: без партионности этот контур не доказывает возраст конкретного лота, а показывает документально наблюдаемый диапазон закупок.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 10.12.2019.\n- Последняя найденная дата закупочного движения: 10.12.2019.\n- Закупочных документов в выборке: 1.\n- Закупочных операций в выборке: 1.\n- Между самой ранней найденной закупкой и датой среза прошло 112 дн.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000111 от 10.12.2019 12:00:01 | дата: 10.12.2019 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-2C1ZkbXwgN"}} +{"timestamp":"2026-04-14T09:29:18.844Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-cyqB2PiFhg","eventType":"assistant_message_address","details":{"session_id":"asst-cyqB2PiFhg","message_id":"msg-6te1PJLP_c","user_message":"Есть ли на складе Основной склад товары с остатком без понятной привязки к поставщику","effective_address_user_message":"Проверить наличие товаров на Основном складе с остатками, у которых нет ясной привязки к поставщику.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"AoaF6vA4AMeC9x","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли на складе основной склад товары с остатком без понятной привязки к поставщику","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract","deep_investigation_signal_detected"],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-e9i2xTLHPb"}} +{"timestamp":"2026-04-14T09:29:26.963Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-cyqB2PiFhg","eventType":"assistant_message_address","details":{"session_id":"asst-cyqB2PiFhg","message_id":"msg-wEPHVO1rBC","user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","effective_address_user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"_U7tgds9tb2Fet","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли среди текущих остатков на складе основной склад позиции, закупленные задолго до 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_aging_by_purchase_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_aging_by_purchase_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_aging_by_purchase_date","extracted_filters":{"sort":"period_desc","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_aging_by_purchase_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран exact-срез возраста закупочного следа по Конструкция трансформер рабочей станции 1300*900*2000 до 31.03.2020.\n\nБлок 1. Статус результата\n- Контур: показаны подтвержденные закупочные движения на 41.01 и их временной разброс.\n- Важно: без партионности этот контур не доказывает возраст конкретного лота, а показывает документально наблюдаемый диапазон закупок.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 25.12.2015.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 111.\n- Закупочных операций в выборке: 500.\n- Между самой ранней найденной закупкой и датой среза прошло 1.558 дн.\n- Поставщики, встречающиеся в наблюдаемом закупочном следе: ПрофТренд,ООО; Группа Компаний Спектр.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000111 от 10.12.2019 12:00:01 | дата: 10.12.2019 | сумма: 712.500,00 ₽ | склад: Основной склад\n3. Комплектация номенклатуры 00000000002 от 09.12.2019 21:00:00 | дата: 09.12.2019 | сумма: 2.206.750,00 ₽ | склад: Основной склад\n4. Комплектация номенклатуры 00000000002 от 09.12.2019 21:00:00 | дата: 09.12.2019 | сумма: 544.050,00 ₽ | склад: Основной склад\n5. Комплектация номенклатуры 00000000002 от 09.12.2019 21:00:00 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад\n6. Комплектация номенклатуры 00000000002 от 09.12.2019 21:00:00 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад\n7. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-09esZyx9i-"}} +{"timestamp":"2026-04-14T09:29:33.231Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-_YuuxJOp0f","eventType":"assistant_message_address","details":{"session_id":"asst-_YuuxJOp0f","message_id":"msg-ScUMrRDBhK","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31 на складе Основной склад","effective_address_user_message":"Получить список товаров, находящихся на 41 счете по состоянию на 2020-03-31 для склада 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"2oOOKGEqKnqxgh","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31 на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-yCyBWIuTIZ"}} +{"timestamp":"2026-04-14T09:29:41.174Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-_YuuxJOp0f","eventType":"assistant_message_address","details":{"session_id":"asst-_YuuxJOp0f","message_id":"msg-339J23OQiT","user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","effective_address_user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"b0Gdg5suFSQnx0","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"кому был продан товар шкаф картотечный 1000*400*2100","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_sale_trace_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_sale_trace_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_sale_trace_for_item","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_sale_trace_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный след выбытия по товару товар до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные движения выбытия товара со счета 41.01.\n\nБлок 2. Сводка\n- Первая найденная дата выбытия: 01.04.2020.\n- Последняя найденная дата выбытия: 01.04.2020.\n- Документов выбытия: 1.\n- Операций выбытия: 1.\n- Документы выбытия найдены, но покупатель не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Документы выбытия\n1. Реализация товаров и услуг 00000000001 от 01.04.2020 0:00:00 | дата: 01.04.2020 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-tjQYFk1T3s"}} +{"timestamp":"2026-04-14T09:29:50.398Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-_YuuxJOp0f","eventType":"assistant_message_address","details":{"session_id":"asst-_YuuxJOp0f","message_id":"msg-Rp4-v2IQ39","user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","effective_address_user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"Zf7sA1yXPiGl0W","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"через какие документы прошел путь товара шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_to_sale_chain","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_to_sale_chain","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_to_sale_chain_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":600,"raw_rows_received":600,"rows_after_account_scope":600,"rows_after_recipe_filter":2,"rows_materialized":600,"rows_matched":2,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собрана документальная цепочка по товару Шкаф картотечный 1000*400*2100 до 14.04.2026.\n\nБлок 1. Статус результата\n- Закупочных движений на 41.01: 1.\n- Движений выбытия со счета 41.01: 1.\n- В текущем контуре найдены обе стороны цепочки: поступление и последующее выбытие.\n\nБлок 2. Закупка\n- Первая дата: 10.12.2019.\n- Последняя дата: 10.12.2019.\n1. Поступление товаров и услуг 00000000111 от 10.12.2019 12:00:01 | дата: 10.12.2019 | сумма: 712.500,00 ₽ | склад: Основной склад\n\nБлок 3. Выбытие\n- Первая дата: 01.04.2020.\n- Последняя дата: 01.04.2020.\n1. Реализация товаров и услуг 00000000001 от 01.04.2020 0:00:00 | дата: 01.04.2020 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-PBhPIiTsVs"}} +{"timestamp":"2026-04-14T09:30:02.755Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-_YuuxJOp0f","eventType":"assistant_message_address","details":{"session_id":"asst-_YuuxJOp0f","message_id":"msg-n7BaH0-aeo","user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","effective_address_user_message":"Проверить наличие документально подтвержденной цепочки: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"_dl7lM-t0mweM3","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотечный 1000*400*2100 -> покупатель департамент капитального ремонта города москвы","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_to_sale_chain","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":"empty_match","address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["deep_investigation_signal_detected"],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_purchase_to_sale_chain","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_to_sale_chain_v1","mcp_call_status_legacy":"materialized_but_not_matched","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"materialized_but_not_anchor_matched","match_failure_reason":"item_anchor_not_matched_in_materialized_rows","mcp_call_status":"materialized_but_not_anchor_matched","rows_fetched":600,"raw_rows_received":600,"rows_after_account_scope":600,"rows_after_recipe_filter":0,"rows_materialized":600,"rows_matched":0,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":"empty_match","response_type":"LIMITED_WITH_REASON","limitations":["no_rows_for_anchor_after_materialization"],"assistant_reply":"По текущим условиям в доступном срезе данных совпадений не нашлось.\n\nпо указанному якорю и фильтрам в выборке данных нет строк.\n\nСигнал запроса: проверка фактического состояния по данным.\n\nКонтекст запроса: срез на 2026-04-14.\n\nЧто могу сделать сейчас: показать документальную цепочку по товару: поступление на 41.01 и последующее выбытие; показать документы/платежи по контрагенту или договору; показать незакрытые договоры или хвосты на дату.","reply_type":"partial_coverage","trace_id":"address-3g4Yw06fGi"}} diff --git a/artifacts/runtime_logs/backend_8793_stderr.log b/artifacts/runtime_logs/backend_8793_stderr.log new file mode 100644 index 0000000..e69de29 diff --git a/artifacts/runtime_logs/backend_8793_stdout.log b/artifacts/runtime_logs/backend_8793_stdout.log new file mode 100644 index 0000000..9c57109 --- /dev/null +++ b/artifacts/runtime_logs/backend_8793_stdout.log @@ -0,0 +1,21 @@ +{"timestamp":"2026-04-14T09:46:25.725Z","level":"info","service":"llm_normalizer_backend","message":"Backend started on http://localhost:8793"} +{"timestamp":"2026-04-14T09:47:00.532Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-WPbwZ9-8Db","eventType":"assistant_message_address","details":{"session_id":"asst-WPbwZ9-8Db","message_id":"msg-XODOxvV3rN","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"cgj5-P2zePXajc","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-d8dxDVQR3m"}} +{"timestamp":"2026-04-14T09:47:06.563Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-WPbwZ9-8Db","eventType":"assistant_message_address","details":{"session_id":"asst-WPbwZ9-8Db","message_id":"msg-2HeAVpPBIh","user_message":"Из каких товаров состоит остаток по 41 счету","effective_address_user_message":"Из каких товаров состоит остаток по 41 счету","address_followup_context_applied":true,"address_followup_context_previous_intent":"inventory_on_hand_as_of_date","address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"jEoFsF_cJORUNy","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"из каких товаров состоит остаток по 41 счету","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"continue_previous","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-A5-81VRSCi"}} +{"timestamp":"2026-04-14T09:47:12.640Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-WPbwZ9-8Db","eventType":"assistant_message_address","details":{"session_id":"asst-WPbwZ9-8Db","message_id":"msg-yE2XuyZ3d8","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31","effective_address_user_message":"Получить список товаров, находящихся на счете 41 на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"oXT6ABLf_Ryhf8","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-091mkII6l9"}} +{"timestamp":"2026-04-14T09:47:18.809Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-WPbwZ9-8Db","eventType":"assistant_message_address","details":{"session_id":"asst-WPbwZ9-8Db","message_id":"msg-NRCCvhe7yO","user_message":"Какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","effective_address_user_message":"Получить список номенклатур, формирующих остаток на складе на дату 2020-03-31.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"OE0QVr1wVJqv2c","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие конкретно номенклатуры формируют остаток по складу на дату 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"management_profile","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"AGGREGATE_LOOKUP","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-1yp41gHchO"}} +{"timestamp":"2026-04-14T09:47:24.850Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-u8wRlutWcL","eventType":"assistant_message_address","details":{"session_id":"asst-u8wRlutWcL","message_id":"msg-pfCO9kvdQl","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"NcXLurTDRzvrNL","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-B2Ropq9QW7"}} +{"timestamp":"2026-04-14T09:47:32.885Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-u8wRlutWcL","eventType":"assistant_message_address","details":{"session_id":"asst-u8wRlutWcL","message_id":"msg-AOiE06SOWe","user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"uflBCaMUGMFIce","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"от какого поставщика куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный закупочный след по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные закупочные движения на 41.01 по выбранному товару.\n- Важно: без партионности этот контур не подменяет собой лот-level доказательство происхождения текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 24.08.2018.\n- Последняя найденная дата закупочного движения: 24.08.2018.\n- Документов поступления: 1.\n- Операций поступления: 1.\n- Закупочные документы найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Опорные документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-C1wlrd8hsi"}} +{"timestamp":"2026-04-14T09:47:41.145Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-u8wRlutWcL","eventType":"assistant_message_address","details":{"session_id":"asst-u8wRlutWcL","message_id":"msg-CGIfUvCfVh","user_message":"У какого поставщика были куплены товары, которые сейчас лежат на складе Основной склад организации ООО \\Альтернатива Плюс\\","effective_address_user_message":"Определить поставщиков, у которых были приобретены товары, находящиеся на складе 'Основной склад' в компании 'ООО Альтернатива Плюс'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"RoVQ2Hw78LV_KI","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"у какого поставщика были куплены товары, которые сейчас лежат на складе основной склад организации ооо \\альтернатива плюс\\","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-3RreQlAiCq"}} +{"timestamp":"2026-04-14T09:47:48.449Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-u8wRlutWcL","eventType":"assistant_message_address","details":{"session_id":"asst-u8wRlutWcL","message_id":"msg-8tY3GMSSjc","user_message":"По какому поставщику проходит текущий товарный остаток на складе Основной склад","effective_address_user_message":"Получить информацию о поставщике, связанным с текущим товарным остатком на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"xdZiNgtDIOZgRn","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"по какому поставщику проходит текущий товарный остаток на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-SAjpz5xEwq"}} +{"timestamp":"2026-04-14T09:47:56.730Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-u8wRlutWcL","eventType":"assistant_message_address","details":{"session_id":"asst-u8wRlutWcL","message_id":"msg-L_JfR3fl_L","user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","effective_address_user_message":"Когда был куплен товар Диван трехместный из текущего остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"eHVRt6OxcC8ngd","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"когда был куплен товар диван трехместный из текущего остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_provenance_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_provenance_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_purchase_provenance_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_provenance_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный закупочный след по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные закупочные движения на 41.01 по выбранному товару.\n- Важно: без партионности этот контур не подменяет собой лот-level доказательство происхождения текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 24.08.2018.\n- Последняя найденная дата закупочного движения: 24.08.2018.\n- Документов поступления: 1.\n- Операций поступления: 1.\n- Закупочные документы найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Опорные документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-7QNufyeK1I"}} +{"timestamp":"2026-04-14T09:48:04.842Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-u8wRlutWcL","eventType":"assistant_message_address","details":{"session_id":"asst-u8wRlutWcL","message_id":"msg-14qWugmXQU","user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","effective_address_user_message":"По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"8sBJYM5hRy8rNn","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"по каким документам был куплен товар диван трехместный для остатка на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_documents_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_documents_for_item","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_documents_for_item","extracted_filters":{"sort":"period_desc","item":"Диван трехместный","warehouse":"Основной склад","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_documents_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный список документов поступления по товару Диван трехместный до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденные движения поступления товара на 41.01 по доступным бухгалтерским проводкам.\n\nБлок 2. Что учтено\n- Дата верхней границы: 14.04.2026.\n- Контур: движения, где товар поступает на счет 41.01.\n- Документов в выборке: 1.\n- Операций в выборке: 1.\n\nБлок 3. Документы\n1. Авансовый отчет 00000000004 от 24.08.2018 12:00:04 | дата: 24.08.2018 | сумма: 34.490,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-UT6tWuPdME"}} +{"timestamp":"2026-04-14T09:48:13.146Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-u8wRlutWcL","eventType":"assistant_message_address","details":{"session_id":"asst-u8wRlutWcL","message_id":"msg-HaIUkxQUeJ","user_message":"Какие товары от поставщика Гамма-мебель, ООО сейчас еще лежат на складе Основной склад","effective_address_user_message":"Получить информацию о товарах от поставщика 'Гамма-мебель, ООО', которые находятся на складе 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"KGkvsbgMQih9Yg","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары от поставщика гамма-мебель, ооо сейчас еще лежат на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","counterparty":"Гамма-мебель, ООО',","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":41,"rows_materialized":500,"rows_matched":41,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 13.05.2019.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 11.\n- Закупочных операций в выборке: 41.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 41.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n3. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n4. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 28.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n5. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 199.671,66 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n6. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 62.150,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n7. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 16.880,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 159.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n9. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 23.660,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n10. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 75.075,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-5jdTS4zcuc"}} +{"timestamp":"2026-04-14T09:48:21.560Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-u8wRlutWcL","eventType":"assistant_message_address","details":{"session_id":"asst-u8wRlutWcL","message_id":"msg-PuyKtlxes8","user_message":"Какие товары по состоянию на дату 2020-03-31 на складе Основной склад были куплены у поставщика Гамма-мебель, ООО","effective_address_user_message":"Список товаров на складе 'Основной склад' по состоянию на 2020-03-31, приобретенных у поставщика 'Гамма-мебель, ООО'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"wT_lOqFR2wZP44","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары по состоянию на дату 2020-03-31 на складе основной склад были куплены у поставщика гамма-мебель, ооо","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","warehouse":"Основной склад","counterparty":"Гамма-мебель, ООО","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"counterparty","resolver_confidence":"medium","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":41,"rows_materialized":500,"rows_matched":41,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 31.03.2020.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 13.05.2019.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 11.\n- Закупочных операций в выборке: 41.\n- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре.\n- Операций без явно материализованного поставщика: 41.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n3. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n4. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 28.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n5. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 199.671,66 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n6. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 159.705,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n7. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 23.660,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 62.150,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n9. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 16.880,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n10. Поступление товаров и услуг 00000000102 от 01.10.2019 10:00:05 | дата: 01.10.2019 | сумма: 75.075,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-3eT9QwgxXl"}} +{"timestamp":"2026-04-14T09:48:27.726Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-0gP9nl5o2J","eventType":"assistant_message_address","details":{"session_id":"asst-0gP9nl5o2J","message_id":"msg-dUsS3gQsp8","user_message":"Какие товары сейчас лежат на складе","effective_address_user_message":"Какие товары сейчас лежат на складе","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"pcISerB0tYjYjm","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары сейчас лежат на складе","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":true,"address_retry_reason":"limited_result_retry_with_raw_message","address_retry_initial_limited_category":"empty_match","address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":11,"raw_rows_received":11,"rows_after_account_scope":11,"rows_after_recipe_filter":11,"rows_materialized":11,"rows_matched":11,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 14.04.2026.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 11.\n- Позиции с ненулевым остатком: 11.\n- Уникальных товаров: 11.\n- Уникальных складов: 1.\n- Суммарное количество: 34,000.\n- Суммарная стоимость: 716.418,33 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n2. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n3. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n4. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n5. Зеркало для инвалидов поворотное травмобезопасное | склад: Основной склад | количество: 1,000 | стоимость: 7.250,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n6. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n7. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n8. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n9. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n10. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z\n11. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2026-04-14T23:59:59Z","reply_type":"factual","trace_id":"address-hlRGBo20A-"}} +{"timestamp":"2026-04-14T09:48:35.946Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-0gP9nl5o2J","eventType":"assistant_message_address","details":{"session_id":"asst-0gP9nl5o2J","message_id":"msg-WpQtzZSliT","user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","effective_address_user_message":"Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"0BSN_WVEfyhMCQ","address_llm_predecompose_reason":"normalized_fragment_rejected_semantic_guard","address_fallback_rule_hit":null,"address_sanitized_user_message":"относится ли товар шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_aging_by_purchase_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_aging_by_purchase_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":false,"address_semantic_contract_quality":"low","address_semantic_apply_canonical_recommended":false,"address_semantic_reason_codes":["unsupported_low_confidence_contract"],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_aging_by_purchase_date","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_aging_by_purchase_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":1,"rows_materialized":500,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран exact-срез возраста закупочного следа по Шкаф картотечный 1000*400*2100 до 31.03.2020.\n\nБлок 1. Статус результата\n- Контур: показаны подтвержденные закупочные движения на 41.01 и их временной разброс.\n- Важно: без партионности этот контур не доказывает возраст конкретного лота, а показывает документально наблюдаемый диапазон закупок.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 10.12.2019.\n- Последняя найденная дата закупочного движения: 10.12.2019.\n- Закупочных документов в выборке: 1.\n- Закупочных операций в выборке: 1.\n- Между самой ранней найденной закупкой и датой среза прошло 112 дн.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000111 от 10.12.2019 12:00:01 | дата: 10.12.2019 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-lVMknGucHW"}} +{"timestamp":"2026-04-14T09:48:44.201Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-0gP9nl5o2J","eventType":"assistant_message_address","details":{"session_id":"asst-0gP9nl5o2J","message_id":"msg-gi-L6qVsK5","user_message":"Есть ли на складе Основной склад товары с остатком без понятной привязки к поставщику","effective_address_user_message":"Проверить наличие товаров на Основном складе с остатками, у которых нет ясной привязки к поставщику.","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"_Uts2WIFxDr77_","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли на складе основной склад товары с остатком без понятной привязки к поставщику","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_supplier_stock_overlap_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_supplier_stock_overlap_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"medium","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["unsupported_low_confidence_contract","deep_investigation_signal_detected"],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_supplier_stock_overlap_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_supplier_stock_overlap_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран exact-срез supplier overlap для складского остатка до 14.04.2026.\n\nБлок 1. Статус результата\n- Контур: подтвержденные закупочные движения на 41.01, связанные со складом Основной склад.\n- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 06.06.2017.\n- Последняя найденная дата закупочного движения: 09.03.2021.\n- Закупочных документов в выборке: 97.\n- Закупочных операций в выборке: 500.\n- Найденные поставщики в наблюдаемом контуре: ПрофТренд,ООО; Группа Компаний Спектр.\n- Операций без явно материализованного поставщика: 477.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00 | дата: 09.03.2021 | сумма: 442.075,00 ₽ | склад: Основной склад\n2. Поступление товаров и услуг 00000000030 от 20.11.2020 12:00:00 | дата: 20.11.2020 | сумма: 7.250,00 ₽ | склад: Основной склад\n3. Поступление товаров и услуг 00000000031 от 09.11.2020 12:00:01 | дата: 09.11.2020 | сумма: 2.229.840,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n4. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 74.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n5. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 34.200,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n6. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 42.400,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n7. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 57.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n8. Поступление товаров и услуг 00000000029 от 13.07.2020 12:00:02 | дата: 13.07.2020 | сумма: 7.600,00 ₽ | склад: Основной склад | организация: ИП Тучкова\n9. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 4.692,50 ₽ | склад: Основной склад | организация: ИП Тучкова\n10. Поступление товаров и услуг 00000000020 от 22.06.2020 0:00:00 | дата: 22.06.2020 | сумма: 30.860,00 ₽ | склад: Основной склад | организация: ИП Тучкова","reply_type":"factual","trace_id":"address-xBHad9ogSv"}} +{"timestamp":"2026-04-14T09:48:52.501Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-0gP9nl5o2J","eventType":"assistant_message_address","details":{"session_id":"asst-0gP9nl5o2J","message_id":"msg-QT9gutgDsw","user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","effective_address_user_message":"Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"YgZu_WKwdpyRQ-","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли среди текущих остатков на складе основной склад позиции, закупленные задолго до 2020-03-31","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_aging_by_purchase_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_aging_by_purchase_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_aging_by_purchase_date","extracted_filters":{"sort":"period_desc","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_aging_by_purchase_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":500,"raw_rows_received":500,"rows_after_account_scope":500,"rows_after_recipe_filter":500,"rows_materialized":500,"rows_matched":500,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран exact-срез возраста закупочного следа по Конструкция трансформер рабочей станции 1300*900*2000 до 31.03.2020.\n\nБлок 1. Статус результата\n- Контур: показаны подтвержденные закупочные движения на 41.01 и их временной разброс.\n- Важно: без партионности этот контур не доказывает возраст конкретного лота, а показывает документально наблюдаемый диапазон закупок.\n\nБлок 2. Сводка\n- Первая найденная дата закупочного движения: 25.12.2015.\n- Последняя найденная дата закупочного движения: 20.12.2019.\n- Закупочных документов в выборке: 111.\n- Закупочных операций в выборке: 500.\n- Между самой ранней найденной закупкой и датой среза прошло 1.558 дн.\n- Поставщики, встречающиеся в наблюдаемом закупочном следе: ПрофТренд,ООО; Группа Компаний Спектр.\n\nБлок 3. Опорные документы\n1. Поступление товаров и услуг 00000000104 от 20.12.2019 0:00:00 | дата: 20.12.2019 | сумма: 498.472,50 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n2. Поступление товаров и услуг 00000000111 от 10.12.2019 12:00:01 | дата: 10.12.2019 | сумма: 712.500,00 ₽ | склад: Основной склад\n3. Комплектация номенклатуры 00000000002 от 09.12.2019 21:00:00 | дата: 09.12.2019 | сумма: 2.206.750,00 ₽ | склад: Основной склад\n4. Комплектация номенклатуры 00000000002 от 09.12.2019 21:00:00 | дата: 09.12.2019 | сумма: 544.050,00 ₽ | склад: Основной склад\n5. Комплектация номенклатуры 00000000002 от 09.12.2019 21:00:00 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад\n6. Комплектация номенклатуры 00000000002 от 09.12.2019 21:00:00 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад\n7. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 131.200,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО\n8. Поступление товаров и услуг 00000000120 от 09.12.2019 12:00:01 | дата: 09.12.2019 | сумма: 1.564.810,00 ₽ | склад: Основной склад | организация: Гамма-мебель, ООО","reply_type":"factual","trace_id":"address-ie2fPKrfx_"}} +{"timestamp":"2026-04-14T09:48:58.747Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-u0xQ4V3IvZ","eventType":"assistant_message_address","details":{"session_id":"asst-u0xQ4V3IvZ","message_id":"msg-3MZtiCZGsC","user_message":"Какие товары числятся на 41 счете на дату 2020-03-31 на складе Основной склад","effective_address_user_message":"Получить список товаров, находящихся на 41 счете по состоянию на 2020-03-31 для склада 'Основной склад'","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"29aKb3gD7ei-ZL","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары числятся на 41 счете на дату 2020-03-31 на складе основной склад","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","account":"41","as_of_date":"2020-03-31"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":"41","account_token_normalized":"41","account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 31.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 31.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-31T23:59:59Z","reply_type":"factual","trace_id":"address-G0CfmP20W4"}} +{"timestamp":"2026-04-14T09:49:05.691Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-u0xQ4V3IvZ","eventType":"assistant_message_address","details":{"session_id":"asst-u0xQ4V3IvZ","message_id":"msg-UbGhZVDQFY","user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","effective_address_user_message":"Кому был продан товар Шкаф картотечный 1000*400*2100","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"RtuHg7H2OVbDXY","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_drop","address_fallback_rule_hit":null,"address_sanitized_user_message":"кому был продан товар шкаф картотечный 1000*400*2100","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_sale_trace_for_item","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_sale_trace_for_item","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_sale_trace_for_item","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_sale_trace_for_item_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":400,"raw_rows_received":400,"rows_after_account_scope":400,"rows_after_recipe_filter":1,"rows_materialized":400,"rows_matched":1,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собран подтвержденный след выбытия по товару товар до 14.04.2026.\n\nБлок 1. Статус результата\n- Результат: показаны подтвержденные движения выбытия товара со счета 41.01.\n\nБлок 2. Сводка\n- Первая найденная дата выбытия: 01.04.2020.\n- Последняя найденная дата выбытия: 01.04.2020.\n- Документов выбытия: 1.\n- Операций выбытия: 1.\n- Документы выбытия найдены, но покупатель не материализован отдельным полем в текущем exact-контуре.\n\nБлок 3. Документы выбытия\n1. Реализация товаров и услуг 00000000001 от 01.04.2020 0:00:00 | дата: 01.04.2020 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address-DhYa1VSezy"}} +{"timestamp":"2026-04-14T09:49:15.010Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-u0xQ4V3IvZ","eventType":"assistant_message_address","details":{"session_id":"asst-u0xQ4V3IvZ","message_id":"msg-bhL8VQ2EPk","user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","effective_address_user_message":"Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":false,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"DP16r2Fds8TfMK","address_llm_predecompose_reason":"normalized_fragment_rejected_intent_conflict","address_fallback_rule_hit":null,"address_sanitized_user_message":"через какие документы прошел путь товара шкаф картотечный 1000*400*2100: закупка -> склад -> продажа","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_to_sale_chain","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"list_lookup","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"DOCUMENT_LIST","detected_intent":"inventory_purchase_to_sale_chain","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_to_sale_chain_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":600,"raw_rows_received":600,"rows_after_account_scope":600,"rows_after_recipe_filter":2,"rows_materialized":600,"rows_matched":2,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собрана документальная цепочка по товару Шкаф картотечный 1000*400*2100 до 14.04.2026.\n\nБлок 1. Статус результата\n- Закупочных движений на 41.01: 1.\n- Движений выбытия со счета 41.01: 1.\n- В текущем контуре найдены обе стороны цепочки: поступление и последующее выбытие.\n\nБлок 2. Закупка\n- Первая дата: 10.12.2019.\n- Последняя дата: 10.12.2019.\n1. Поступление товаров и услуг 00000000111 от 10.12.2019 12:00:01 | дата: 10.12.2019 | сумма: 712.500,00 ₽ | склад: Основной склад\n\nБлок 3. Выбытие\n- Первая дата: 01.04.2020.\n- Последняя дата: 01.04.2020.\n1. Реализация товаров и услуг 00000000001 от 01.04.2020 0:00:00 | дата: 01.04.2020 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address--MVZRhL-vK"}} +{"timestamp":"2026-04-14T09:49:26.245Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"asst-u0xQ4V3IvZ","eventType":"assistant_message_address","details":{"session_id":"asst-u0xQ4V3IvZ","message_id":"msg-_-KCaOUrnU","user_message":"Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","effective_address_user_message":"Проверить наличие документально подтвержденной цепочки: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"Z8449OqjjhchwS","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"есть ли документально подтвержденная цепочка: поставщик гамма-мебель, ооо -> товар шкаф картотечный 1000*400*2100 -> покупатель департамент капитального ремонта города москвы","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_intent_resolver_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_purchase_to_sale_chain","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_purchase_to_sale_chain","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":["deep_investigation_signal_detected"],"detected_mode":"address_query","query_shape":"VERIFY_FACTUAL","detected_intent":"inventory_purchase_to_sale_chain","extracted_filters":{"sort":"period_desc","item":"Шкаф картотечный 1000*400*2100","as_of_date":"2026-04-14"},"selected_recipe":"address_inventory_purchase_to_sale_chain_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":600,"raw_rows_received":600,"rows_after_account_scope":600,"rows_after_recipe_filter":2,"rows_materialized":600,"rows_matched":2,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_SUMMARY","limitations":["as_of_date_defaulted_today"],"assistant_reply":"Собрана документальная цепочка по товару Шкаф картотечный 1000*400*2100 до 14.04.2026.\n\nБлок 1. Статус результата\n- Закупочных движений на 41.01: 1.\n- Движений выбытия со счета 41.01: 1.\n- В текущем контуре найдены обе стороны цепочки: поступление и последующее выбытие.\n\nБлок 2. Закупка\n- Первая дата: 10.12.2019.\n- Последняя дата: 10.12.2019.\n1. Поступление товаров и услуг 00000000111 от 10.12.2019 12:00:01 | дата: 10.12.2019 | сумма: 712.500,00 ₽ | склад: Основной склад\n\nБлок 3. Выбытие\n- Первая дата: 01.04.2020.\n- Последняя дата: 01.04.2020.\n1. Реализация товаров и услуг 00000000001 от 01.04.2020 0:00:00 | дата: 01.04.2020 | сумма: 712.500,00 ₽ | склад: Основной склад","reply_type":"factual","trace_id":"address--DiVezXHsK"}} diff --git a/artifacts/runtime_logs/backend_8794_stderr.log b/artifacts/runtime_logs/backend_8794_stderr.log new file mode 100644 index 0000000..e69de29 diff --git a/artifacts/runtime_logs/backend_8794_stdout.log b/artifacts/runtime_logs/backend_8794_stdout.log new file mode 100644 index 0000000..d92b2b3 --- /dev/null +++ b/artifacts/runtime_logs/backend_8794_stdout.log @@ -0,0 +1,2 @@ +{"timestamp":"2026-04-14T09:59:37.945Z","level":"info","service":"llm_normalizer_backend","message":"Backend started on http://localhost:8794"} +{"timestamp":"2026-04-14T10:00:04.993Z","level":"info","service":"assistant_loop","message":"assistant_message_processed","sessionId":"assistant-stage1-_8fWTau36z-AUTO-001","eventType":"assistant_message_address","details":{"session_id":"assistant-stage1-_8fWTau36z-AUTO-001","message_id":"msg-96mZvZxAq1","user_message":"Какие товары лежат на складе на 15 марта 2020","effective_address_user_message":"Какие товары находятся на складе по состоянию на 15 марта 2020 года?","address_followup_context_applied":false,"address_followup_context_previous_intent":null,"address_followup_context_previous_anchor":null,"address_llm_predecompose_attempted":true,"address_llm_predecompose_applied":true,"address_llm_predecompose_provider":"local","address_llm_predecompose_trace_id":"1JCoEzwbK4mXVR","address_llm_predecompose_reason":"normalized_fragment_applied","address_fallback_rule_hit":null,"address_sanitized_user_message":"какие товары лежат на складе на 15 марта 2020","address_tool_gate_decision":"run_address_lane","address_tool_gate_reason":"address_mode_classifier_detected","address_dialog_continuation_decision":"new_topic","address_dialog_continuation_target_intent":"inventory_on_hand_as_of_date","address_retry_attempted":false,"address_retry_reason":null,"address_retry_initial_limited_category":null,"address_retry_result_category":null,"address_llm_predecompose_contract_intent":"inventory_on_hand_as_of_date","address_llm_predecompose_contract_aggregation_profile":"unknown","address_llm_predecompose_contract_period_scope":"as_of","address_semantic_contract_valid":true,"address_semantic_contract_quality":"high","address_semantic_apply_canonical_recommended":true,"address_semantic_reason_codes":[],"detected_mode":"address_query","query_shape":"UNKNOWN","detected_intent":"inventory_on_hand_as_of_date","extracted_filters":{"sort":"period_desc","as_of_date":"2020-03-15"},"selected_recipe":"address_inventory_on_hand_as_of_date_v1","mcp_call_status_legacy":"matched_non_empty","account_scope_mode":"strict","account_scope_fallback_applied":false,"anchor_type":"unknown","resolver_confidence":"low","match_failure_stage":"none","match_failure_reason":null,"mcp_call_status":"matched_non_empty","rows_fetched":12,"raw_rows_received":12,"rows_after_account_scope":12,"rows_after_recipe_filter":12,"rows_materialized":12,"rows_matched":12,"materialization_drop_reason":"none","account_token_raw":null,"account_token_normalized":null,"account_scope_fields_checked":["account_dt","account_kt","registrator","analytics"],"account_scope_match_strategy":"account_code_regex_plus_alias_map_v1","account_scope_drop_reason":"not_applicable","runtime_readiness":"LIVE_QUERYABLE_WITH_LIMITS","limited_reason_category":null,"response_type":"FACTUAL_LIST","limitations":["period_derived_from_month_phrase","period_window_cleared_for_as_of_intent"],"assistant_reply":"Собран подтвержденный срез товаров на складах на 15.03.2020.\n\nБлок 1. Статус результата\n- Результат: подтвержденный список товарных остатков на дату.\n\nБлок 2. Что учтено\n- Дата среза: 15.03.2020.\n- Контур: остатки по счету 41.01 «Товары на складах».\n- Базовая единица детализации: одна строка = товар, склад и организация на дату.\n\nБлок 3. Сводка\n- Строк в выборке: 12.\n- Позиции с ненулевым остатком: 12.\n- Уникальных товаров: 12.\n- Уникальных складов: 1.\n- Суммарное количество: 138,000.\n- Суммарная стоимость: 1.665.049,68 ₽.\n\nБлок 4. Подтвержденные позиции\n1. Подсветка | склад: Основной склад | количество: 90,000 | стоимость: 243.381,35 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-15T23:59:59Z\n2. Модуль прямоугольый 1400*110*750 | склад: Основной склад | количество: 22,000 | стоимость: 148.261,67 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-15T23:59:59Z\n3. Шкаф картотечный 1000*400*2100 | склад: Основной склад | количество: 15,000 | стоимость: 712.500,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-15T23:59:59Z\n4. Конструкция трансформер рабочей станции 1300*900*2000 | склад: Основной склад | количество: 3,000 | стоимость: 498.472,50 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-15T23:59:59Z\n5. Диван трехместный | склад: Основной склад | количество: 1,000 | стоимость: 34.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-15T23:59:59Z\n6. Кресло орион | склад: Основной склад | количество: 1,000 | стоимость: 13.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-15T23:59:59Z\n7. Пуф арий | склад: Основной склад | количество: 1,000 | стоимость: 6.490,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-15T23:59:59Z\n8. Столешница 600*3050*26 дуб ниагара | склад: Основной склад | количество: 1,000 | стоимость: 3.724,17 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-15T23:59:59Z\n9. Столешница 600*3050*26 альмандин | склад: Основной склад | количество: 1,000 | стоимость: 3.075,00 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-15T23:59:59Z\n10. Четки Пост (84*117) | склад: Основной склад | количество: 1,000 | стоимость: 833,33 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-15T23:59:59Z\n11. Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-15T23:59:59Z\n12. Кромка с клеем 33 дуб ниагара 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\Альтернатива Плюс\\ | дата строки: 2020-03-15T23:59:59Z","reply_type":"factual","trace_id":"address-R_HTUGl8N9"}} diff --git a/artifacts/runtime_logs/backend_8795_stdout.log b/artifacts/runtime_logs/backend_8795_stdout.log new file mode 100644 index 0000000000000000000000000000000000000000..5fd9848ce3a937c6e3bfcd0a7e94776e137c69a2 GIT binary patch literal 2960 zcmchZ+iwz45XR?$ClmjNeZyNR;H52IVnvK5TBFv)M3f+4MY#!hL8E`V`upbe$boLv zhsJCc_UxH6^Udv>{rTgxow6I2*??&kxj5yLjMr?%xc_GLk)SI8KHf~ z&L!KiEkCtexK+4WxKXGT%7q$OGTSO#*E6dtR&|;4ye;{aVY|8JMbWOhrB&-w`+&97 ztIW=Mgo^eV1Wjz!`Q5YI{I?EQ!T-L!_BaV^6N}O`Cjvt}Xc5n`9k3HI$#)_A+x6Z4 z_a$Tzl@QkPYK{*FUK%Z*W9xPx#+N-cznmmu4BGK^i|Ufd&E`D5fkz;-qRRy9ML!Yi zdtL8K_epP;2ozoQrFu?Xk+HW+CEg}F_lWybqSx>^w?Wb1U{exC9hO}05wXS-W+Q`RQMN=7FHMHiTRNalJP4&I%vb5sA zbUx#3K8pknZgJ`;2d}eN)1}0+E$@mhc2#3yo*vyX`JMZwBY4I8Hg6}s>hQcoC^i;r zUbM^nSII-3XAj}ex9FB{CA;R?mWKcRx#w6o%E_9BvedwrFi-Yuf6b4SUAMeiw{z=7Y%z9wnieHzkL7yb{eQ>K zE~vUbi6avPmeYhuS^a2Nty~{wBs{CEUVf7^|#;ZVfCISU@>>< z75PetQBsdiJ$sVhpkB*pt|SsO@;<|3_59#aYs&tqw$)i05NKYeG86FW8(6#P9R22) XgiBvV@*pz7N4lrVstPuJNlWGzNm<*y literal 0 HcmV?d00001 diff --git a/artifacts/runtime_logs/backend_stderr.log b/artifacts/runtime_logs/backend_stderr.log index e69de29..fd90d96 100644 --- a/artifacts/runtime_logs/backend_stderr.log +++ b/artifacts/runtime_logs/backend_stderr.log @@ -0,0 +1,26 @@ +node:events:497 + throw er; // Unhandled 'error' event + ^ + +Error: listen EADDRINUSE: address already in use :::8787 + at Server.setupListenHandle [as _listen2] (node:net:1940:16) + at listenInCluster (node:net:1997:12) + at Server.listen (node:net:2102:7) + at Function.listen (X:\1C\NDC_1C\llm_normalizer\backend\node_modules\express\lib\application.js:635:24) + at Object. (X:\1C\NDC_1C\llm_normalizer\backend\dist\server.js:74:9) + at Module._compile (node:internal/modules/cjs/loader:1706:14) + at Object..js (node:internal/modules/cjs/loader:1839:10) + at Module.load (node:internal/modules/cjs/loader:1441:32) + at Function._load (node:internal/modules/cjs/loader:1263:12) + at TracingChannel.traceSync (node:diagnostics_channel:322:14) +Emitted 'error' event on Server instance at: + at emitErrorNT (node:net:1976:8) + at process.processTicksAndRejections (node:internal/process/task_queues:90:21) { + code: 'EADDRINUSE', + errno: -4091, + syscall: 'listen', + address: '::', + port: 8787 +} + +Node.js v22.20.0 diff --git a/artifacts/runtime_logs/backend_stdout.log b/artifacts/runtime_logs/backend_stdout.log index 68a03b2..e69de29 100644 --- a/artifacts/runtime_logs/backend_stdout.log +++ b/artifacts/runtime_logs/backend_stdout.log @@ -1 +0,0 @@ -{"timestamp":"2026-04-14T04:26:37.615Z","level":"info","service":"llm_normalizer_backend","message":"Backend started on http://localhost:8787"} diff --git a/designconfig.ts b/designconfig.ts index ec72507..4c0ae44 100644 --- a/designconfig.ts +++ b/designconfig.ts @@ -4,6 +4,10 @@ export const designConfig = { mainSurfaceRgb: "25, 25, 25", horizontalSurfaceRgb: "30, 30, 30", focusSurfaceRgb: "35, 35, 35", + assistantChipRgb: "18, 18, 18", + assistantChipHoverRgb: "44, 44, 44", + assistantChipSelectedRgb: "167, 59, 255", + assistantChipSelectedTextRgb: "240, 240, 240", activeRgb: "167, 59, 255", activeTextRgb: "240, 240, 240", textMainRgb: "240, 240, 240", diff --git a/docs/TECH/address_route_expectations_v1.json b/docs/TECH/address_route_expectations_v1.json index d28a9f0..cb2191d 100644 --- a/docs/TECH/address_route_expectations_v1.json +++ b/docs/TECH/address_route_expectations_v1.json @@ -1,6 +1,6 @@ { "schema_version": "address_route_expectations_v1", - "updated_at": "2026-04-13T00:15:00.000Z", + "updated_at": "2026-04-14T09:30:00.000Z", "entries": [ { "intent": "payables_confirmed_as_of_date", @@ -26,6 +26,36 @@ "expected_requested_result_modes": ["confirmed_balance"], "expected_result_modes": ["confirmed_balance"] }, + { + "intent": "inventory_purchase_provenance_for_item", + "expected_selected_recipes": ["address_inventory_purchase_provenance_for_item_v1"], + "expected_requested_result_modes": ["confirmed_balance"], + "expected_result_modes": ["confirmed_balance"] + }, + { + "intent": "inventory_purchase_documents_for_item", + "expected_selected_recipes": ["address_inventory_purchase_documents_for_item_v1"], + "expected_requested_result_modes": ["confirmed_balance"], + "expected_result_modes": ["confirmed_balance"] + }, + { + "intent": "inventory_sale_trace_for_item", + "expected_selected_recipes": ["address_inventory_sale_trace_for_item_v1"], + "expected_requested_result_modes": ["confirmed_balance"], + "expected_result_modes": ["confirmed_balance"] + }, + { + "intent": "inventory_purchase_to_sale_chain", + "expected_selected_recipes": ["address_inventory_purchase_to_sale_chain_v1"], + "expected_requested_result_modes": ["confirmed_balance"], + "expected_result_modes": ["confirmed_balance"] + }, + { + "intent": "inventory_aging_by_purchase_date", + "expected_selected_recipes": ["address_inventory_aging_by_purchase_date_v1"], + "expected_requested_result_modes": ["confirmed_balance"], + "expected_result_modes": ["confirmed_balance"] + }, { "intent": "vat_payable_forecast", "expected_selected_recipes": ["address_vat_payable_forecast_v1"] diff --git a/llm_normalizer/backend/dist/services/addressCapabilityPolicy.js b/llm_normalizer/backend/dist/services/addressCapabilityPolicy.js index ceb615c..7554cb9 100644 --- a/llm_normalizer/backend/dist/services/addressCapabilityPolicy.js +++ b/llm_normalizer/backend/dist/services/addressCapabilityPolicy.js @@ -138,13 +138,33 @@ function resolveCapabilityEnabled(intent) { } if (intent === "inventory_purchase_provenance_for_item" || intent === "inventory_purchase_documents_for_item" || - intent === "inventory_supplier_stock_overlap_as_of_date" || intent === "inventory_sale_trace_for_item" || - intent === "inventory_purchase_to_sale_chain" || - intent === "inventory_aging_by_purchase_date") { + intent === "inventory_purchase_to_sale_chain") { + if (intent === "inventory_purchase_to_sale_chain") { + return { + enabled: true, + reason: "inventory_purchase_to_sale_chain_route_enabled" + }; + } return { - enabled: false, - reason: "inventory_provenance_route_not_implemented" + enabled: config_1.FEATURE_ASSISTANT_ROUTE_BALANCE_EXACT_V1, + reason: config_1.FEATURE_ASSISTANT_ROUTE_BALANCE_EXACT_V1 + ? "inventory_trace_route_enabled" + : "inventory_trace_route_disabled_by_flag" + }; + } + if (intent === "inventory_supplier_stock_overlap_as_of_date") { + return { + enabled: config_1.FEATURE_ASSISTANT_ROUTE_BALANCE_EXACT_V1, + reason: config_1.FEATURE_ASSISTANT_ROUTE_BALANCE_EXACT_V1 + ? "inventory_supplier_stock_overlap_route_enabled" + : "inventory_supplier_stock_overlap_route_disabled_by_flag" + }; + } + if (intent === "inventory_aging_by_purchase_date") { + return { + enabled: true, + reason: "inventory_aging_route_enabled" }; } if (intent === "list_payables_counterparties") { diff --git a/llm_normalizer/backend/dist/services/addressFilterExtractor.js b/llm_normalizer/backend/dist/services/addressFilterExtractor.js index ce8195c..eb1ddb7 100644 --- a/llm_normalizer/backend/dist/services/addressFilterExtractor.js +++ b/llm_normalizer/backend/dist/services/addressFilterExtractor.js @@ -61,6 +61,10 @@ const COUNTERPARTY_TOKEN_NOISE = new Set([ "могу", "можем", "нет", + "был", + "были", + "куплен", + "куплены", "покажи", "показать", "скажи", @@ -796,6 +800,198 @@ function extractLeadingCounterpartyTokenHeuristic(text) { function hasExplicitAccountCue(text) { return /(?:сч[её]т|счет|account|acct)/iu.test(String(text ?? "")); } +function isInventoryTraceIntent(intent) { + return (intent === "inventory_purchase_provenance_for_item" || + intent === "inventory_purchase_documents_for_item" || + intent === "inventory_supplier_stock_overlap_as_of_date" || + intent === "inventory_sale_trace_for_item" || + intent === "inventory_purchase_to_sale_chain" || + intent === "inventory_aging_by_purchase_date"); +} +function isInventoryItemAnchoredIntent(intent) { + return (intent === "inventory_purchase_provenance_for_item" || + intent === "inventory_purchase_documents_for_item" || + intent === "inventory_aging_by_purchase_date" || + intent === "inventory_sale_trace_for_item" || + intent === "inventory_purchase_to_sale_chain"); +} +function usesRecipeDefaultLimit(intent) { + return (intent === "inventory_on_hand_as_of_date" || + intent === "inventory_purchase_provenance_for_item" || + intent === "inventory_purchase_documents_for_item" || + intent === "inventory_supplier_stock_overlap_as_of_date" || + intent === "inventory_sale_trace_for_item" || + intent === "inventory_purchase_to_sale_chain" || + intent === "inventory_aging_by_purchase_date"); +} +function isLowQualityInventoryItemAnchorValue(rawValue) { + const value = cleanupAnchorValue(rawValue) + .trim() + .toLowerCase() + .replace(/ё/g, "е"); + if (!value || value.length < 3) { + return true; + } + if (/^(?:товар(?:ы|а|у|ом)?|номенклатура|позиция|остаток|остатки|склад|складе|складу|поставщик|покупатель|документ|документы)$/iu.test(value)) { + return true; + } + const lowQualityTokens = new Set([ + "сейчас", + "лежат", + "лежит", + "лежали", + "куплен", + "куплена", + "куплены", + "продан", + "продана", + "проданы", + "документам", + "документами", + "документы", + "поставщика", + "поставщику", + "покупателю", + "остаток", + "остатки", + "склад", + "складе", + "складу" + ]); + const meaningfulTokens = value + .split(/[^a-zа-я0-9]+/iu) + .map((token) => token.trim()) + .filter(Boolean) + .filter((token) => !lowQualityTokens.has(token)); + return meaningfulTokens.length === 0; +} +function cleanupInventoryItemAnchorValue(value) { + return String(value ?? "") + .replace(/^['"«»“”„`’‘]+|['"«»“”„`’‘]+$/gu, "") + .replace(/\s+/g, " ") + .trim(); +} +function trimInventoryItemAnchorTail(rawValue) { + let value = cleanupInventoryItemAnchorValue(rawValue); + const tailPatterns = [ + /\s+для\s+остатка(?:\s+на\s+складе.*)?$/iu, + /\s+из\s+текущ(?:его|их)\s+остат(?:ка|ков).*$/iu, + /\s+из\s+остат(?:ка|ков).*$/iu, + /\s+в\s+остатке.*$/iu, + /\s+на\s+складе.*$/iu, + /\s*:\s*закупк.*$/iu + ]; + for (const pattern of tailPatterns) { + value = value.replace(pattern, ""); + } + return cleanupInventoryItemAnchorValue(value); +} +function extractSelectedObjectQuotedValue(text) { + const patterns = [ + /(?:по\s+выбранному\s+объекту|for\s+selected\s+object)\s*[«"]([^»"\r\n]+)[»"]/iu, + /(?:по\s+выбранному\s+объекту|for\s+selected\s+object)\s*:\s*[«"]([^»"\r\n]+)[»"]/iu + ]; + for (const pattern of patterns) { + const match = String(text ?? "").match(pattern); + const candidate = cleanupInventoryItemAnchorValue(String(match?.[1] ?? "")); + if (candidate) { + return candidate; + } + } + return undefined; +} +function extractInventoryItemFromSelectedObject(text) { + const selectedObject = extractSelectedObjectQuotedValue(text); + if (!selectedObject) { + return undefined; + } + const firstLine = selectedObject + .replace(/\r\n?/g, "\n") + .split("\n") + .map((line) => cleanupInventoryItemAnchorValue(line)) + .find(Boolean); + const withoutNumberPrefix = cleanupInventoryItemAnchorValue(String(firstLine ?? "").replace(/^\d+\.\s*/, "")); + const primarySegment = cleanupInventoryItemAnchorValue(withoutNumberPrefix.split("|")[0] ?? withoutNumberPrefix); + const candidate = cleanupInventoryItemAnchorValue(primarySegment); + if (!candidate || isLowQualityInventoryItemAnchorValue(candidate)) { + return undefined; + } + return candidate; +} +function extractInventoryItemAnchor(text) { + const selectedObjectItem = extractInventoryItemFromSelectedObject(text); + if (selectedObjectItem) { + return selectedObjectItem; + } + const patterns = [ + /(?:товар(?:а|у|ом|ы)?|номенклатур(?:а|у|ы)|позици(?:я|ю|и)|item|product|sku)\s*[«"']([^«»"'?\r\n]+)[»"'](?=$|[\s,.;:!?])/iu, + /(?:товар(?:а|у|ом|ы)?|номенклатур(?:а|у|ы)|позици(?:я|ю|и)|item|product|sku)\s+([^\r\n,.;:!?]+?)(?=\s+(?:на|по|у|от|из|для|и|когда|через|сейчас|еще|ещё|котор|которые|который|покупателю|поставщика|поставщику|за|в)\b|[:?]|$)/iu + ]; + for (const pattern of patterns) { + const match = String(text ?? "").match(pattern); + const candidate = trimInventoryItemArrowSuffix(trimInventoryItemChainTail(trimInventoryItemAnchorTail(String(match?.[1] ?? "")))); + if (!candidate || isLowQualityInventoryItemAnchorValue(candidate)) { + continue; + } + return candidate; + } + return undefined; +} +function trimInventoryItemChainTail(rawValue) { + return cleanupInventoryItemAnchorValue(cleanupInventoryItemAnchorValue(rawValue) + .replace(/\s*(?:->|=>|→)\s*(?:покупател\w*|buyer\b).*$/iu, "") + .replace(/\s*(?:->|=>|→)\s*(?:поставщик\w*|supplier\b).*$/iu, "")); +} +function trimInventoryItemArrowSuffix(rawValue) { + return cleanupAnchorValue(cleanupAnchorValue(rawValue).replace(/\s*(?:->|=>|→).+$/u, "")); +} +function isTemporalWarehousePhrase(candidate) { + const normalized = cleanupAnchorValue(candidate) + .toLowerCase() + .replace(/ё/g, "е") + .trim(); + return /^(?:в|на)\s+(?:январ(?:е|ь)|феврал(?:е|ь)|март(?:е)?|апрел(?:е|ь)|ма(?:й|е)|июн(?:е|ь)|июл(?:е|ь)|август(?:е)?|сентябр(?:е|ь)|октябр(?:е|ь)|ноябр(?:е|ь)|декабр(?:е|ь))(?:\s+\d{4}(?:\s+г(?:\.|ода)?)?)?$/iu.test(normalized); +} +function extractInventoryWarehouseAnchor(text) { + const patterns = [ + /(?:на|по)\s+склад(?:е|у|ом)?\s+[«"']?([^\r\n,.;:!?]+?)(?:[»"']|(?=\s+(?:на|по|за|с|в)\b|[?]|$))/iu, + /склад(?:е|у|ом)?\s+[«"']?([^\r\n,.;:!?]+?)(?:[»"']|(?=\s+(?:на|по|за|с|в)\b|[?]|$))/iu + ]; + for (const pattern of patterns) { + const match = String(text ?? "").match(pattern); + const candidate = cleanupAnchorValue(cleanupAnchorValue(String(match?.[1] ?? "")).replace(/\s+(?:организац\w*|компани\w*|котор(?:ый|ые|ых)|на\s+дату|по\s+состоянию\s+на\s+дату).*$/iu, "")); + const normalizedCandidate = candidate + .toLowerCase() + .replace(/ё/g, "е") + .trim(); + if (!candidate || + candidate.includes("->") || + candidate.includes("=>") || + normalizedCandidate.startsWith("по состоянию") || + isTemporalWarehousePhrase(candidate) || + /^(?:сейчас|на|дату|дате|остаток|остатки)$/iu.test(candidate)) { + continue; + } + return candidate; + } + return undefined; +} +function extractInventorySupplierAnchor(text) { + const match = String(text ?? "").match(/(?:от\s+поставщика|у\s+поставщика|поставщика|поставщику)\s+([^\r\n?]+?)(?=$|[?])/iu); + if (!match?.[1]) { + return undefined; + } + const candidate = cleanupAnchorValue(cleanupAnchorValue(String(match[1])).replace(/\s+(?:сейчас|на\s+склад(?:е|у|ом)?|на\s+дату|по\s+состоянию\s+на\s+дату|котор(?:ый|ые|ых)|куплен(?:ы|а|о)?|были|был|лежат|лежит|еще|ещё|организац\w*|компани\w*).*$/iu, "")); + if (!candidate || + isLowQualityCounterpartyAnchorValue(candidate) || + /^(?:были|был|куплен|куплены|которые|который|которых|сейчас|лежат|лежит)\b/iu.test(candidate)) { + return undefined; + } + return candidate; +} +function asksForInventorySupplierIdentity(text) { + return /(?:^|[\s,.;:!?])(?:у|от)\s+какого\s+поставщика\b/iu.test(String(text ?? "")); +} function extractAccountTokenHeuristic(text) { const source = String(text ?? ""); const dotted = source.match(/(?:^|[^\d])(\d{2}[.,]\d{1,2})(?!\d)/u); @@ -820,6 +1016,12 @@ function requiredFiltersByIntent(intent) { if (intent === "inventory_on_hand_as_of_date") { return ["as_of_date"]; } + if (intent === "inventory_purchase_provenance_for_item" || + intent === "inventory_purchase_documents_for_item" || + intent === "inventory_sale_trace_for_item" || + intent === "inventory_purchase_to_sale_chain") { + return ["item"]; + } if (intent === "payables_confirmed_as_of_date") { return ["as_of_date"]; } @@ -847,6 +1049,12 @@ function requiredFiltersByIntent(intent) { } function usesAsOfPrimaryWindow(intent) { return (intent === "inventory_on_hand_as_of_date" || + intent === "inventory_purchase_provenance_for_item" || + intent === "inventory_purchase_documents_for_item" || + intent === "inventory_supplier_stock_overlap_as_of_date" || + intent === "inventory_sale_trace_for_item" || + intent === "inventory_purchase_to_sale_chain" || + intent === "inventory_aging_by_purchase_date" || intent === "open_items_by_counterparty_or_contract" || intent === "list_open_contracts" || intent === "open_contracts_confirmed_as_of_date" || @@ -869,7 +1077,7 @@ function extractAddressFilters(userMessage, intent) { const filters = { sort: "period_desc" }; - if (!isManagementProfileIntent) { + if (!isManagementProfileIntent && !usesRecipeDefaultLimit(intent)) { if (intent !== "open_contracts_confirmed_as_of_date") { filters.limit = 20; } @@ -895,11 +1103,29 @@ function extractAddressFilters(userMessage, intent) { filters.limit = Math.min(200, Math.trunc(parsed)); } } - const counterpartyMatch = text.match(COUNTERPARTY_PATTERN); - if (counterpartyMatch) { + if (isInventoryItemAnchoredIntent(intent)) { + const itemAnchor = extractInventoryItemAnchor(text); + if (itemAnchor) { + filters.item = itemAnchor; + } + } + const warehouseAnchor = extractInventoryWarehouseAnchor(text); + if (warehouseAnchor) { + filters.warehouse = warehouseAnchor; + } + if (intent === "inventory_supplier_stock_overlap_as_of_date") { + const supplierAnchor = asksForInventorySupplierIdentity(text) ? undefined : extractInventorySupplierAnchor(text); + if (supplierAnchor) { + filters.counterparty = supplierAnchor; + } + } + const allowGenericCounterpartyAnchor = !isInventoryTraceIntent(intent); + const counterpartyMatch = allowGenericCounterpartyAnchor ? text.match(COUNTERPARTY_PATTERN) : null; + if (counterpartyMatch && !filters.counterparty) { filters.counterparty = cleanupAnchorValue(String(counterpartyMatch[1])); } if (!filters.counterparty && + allowGenericCounterpartyAnchor && (intent === "list_documents_by_counterparty" || intent === "bank_operations_by_counterparty" || intent === "list_contracts_by_counterparty")) { @@ -910,6 +1136,7 @@ function extractAddressFilters(userMessage, intent) { } } if (!filters.counterparty && + allowGenericCounterpartyAnchor && (intent === "list_documents_by_counterparty" || intent === "bank_operations_by_counterparty" || intent === "list_contracts_by_counterparty")) { @@ -920,6 +1147,7 @@ function extractAddressFilters(userMessage, intent) { } } if (!filters.counterparty && + allowGenericCounterpartyAnchor && (intent === "list_documents_by_counterparty" || intent === "bank_operations_by_counterparty" || intent === "list_contracts_by_counterparty")) { @@ -1028,6 +1256,12 @@ function extractAddressFilters(userMessage, intent) { if ((intent === "account_balance_snapshot" || intent === "documents_forming_balance" || intent === "inventory_on_hand_as_of_date" || + intent === "inventory_purchase_provenance_for_item" || + intent === "inventory_purchase_documents_for_item" || + intent === "inventory_supplier_stock_overlap_as_of_date" || + intent === "inventory_sale_trace_for_item" || + intent === "inventory_purchase_to_sale_chain" || + intent === "inventory_aging_by_purchase_date" || intent === "payables_confirmed_as_of_date" || intent === "receivables_confirmed_as_of_date" || intent === "vat_payable_confirmed_as_of_date") && @@ -1062,6 +1296,10 @@ function extractAddressFilters(userMessage, intent) { delete filters.contract; warnings.push("contract_anchor_dropped_low_quality"); } + if (filters.item && isLowQualityInventoryItemAnchorValue(filters.item)) { + delete filters.item; + warnings.push("item_anchor_dropped_low_quality"); + } const required = requiredFiltersByIntent(intent); const missingRequiredFilters = required.filter((key) => { const value = filters[key]; diff --git a/llm_normalizer/backend/dist/services/addressIntentResolver.js b/llm_normalizer/backend/dist/services/addressIntentResolver.js index b655407..c655ab5 100644 --- a/llm_normalizer/backend/dist/services/addressIntentResolver.js +++ b/llm_normalizer/backend/dist/services/addressIntentResolver.js @@ -1302,20 +1302,34 @@ function hasGenericAddressLookupSignal(text) { function hasAccountNumberAnchor(text) { return /(?:account|сч[её]т|счет)\D{0,12}\d{2}(?:[.,]\d{1,2})?/i.test(text); } +function hasInventoryAccount41Anchor(text) { + return /(?:сч[её]т(?:а|е|у)?|счет(?:а|е|у)?)\D{0,12}41(?:[.,]0?1)?/iu.test(text) || /41(?:[.,]0?1)?\D{0,12}(?:сч[её]т(?:а|е|у)?|счет(?:а|е|у)?)/iu.test(text); +} +function hasInventoryAsOfCue(text) { + return /(?:сейчас|текущ|на\s+дату|по\s+состоянию|срез|на\s+конец|date|as\s+of|current|now|today)/iu.test(text); +} function hasInventoryOnHandSignal(text) { + const hasColloquialStockSnapshotCue = /(?:что|ч[её])\s+(?:у\s+нас\s+)?на\s+склад(?:е|у|ом)(?=$|[\s,.;:!?])/iu.test(text); + const hasAccount41Anchor = hasInventoryAccount41Anchor(text); const hasStockLexeme = /(?:склад(?:е|у|ом|ы|ов)?|warehouse|stock(?:room)?|inventory|on[\s-]?hand)/iu.test(text); - if (!hasStockLexeme) { + if (!hasStockLexeme && !hasAccount41Anchor) { return false; } if (hasInventoryProvenanceSignalV2(text) || hasInventoryPurchaseDocumentsSignalV2(text) || - hasInventorySaleTraceSignalV2(text)) { + hasInventorySaleTraceSignalV2(text) || + hasInventoryAgingSignal(text) || + hasInventoryPurchaseToSaleChainSignal(text)) { return false; } const hasGoodsLexeme = /(?:товар(?:ы|ов|ом|а|ные)?|номенклатур|материал(?:ы|ов|а|ам)?|item(?:s)?|sku|product(?:s)?)/iu.test(text); const hasBalanceLexeme = /(?:леж(?:ит|ат)|есть|числ(?:ит(?:ся|сь)|ятся)|остат(?:ок|ки)|срез|на\s+дат|по\s+состоянию|на\s+конец|today|now|current|as\s+of)/iu.test(text); const hasRequestCue = /(?:покажи|показать|выведи|дай|какие|что|какой|сколько|show|list|which|what)/iu.test(text); - return (hasGoodsLexeme || hasBalanceLexeme) && (hasRequestCue || hasBalanceLexeme); + if (hasAccount41Anchor && (hasGoodsLexeme || hasBalanceLexeme || hasRequestCue || hasInventoryAsOfCue(text))) { + return true; + } + return (hasGoodsLexeme || hasBalanceLexeme || hasColloquialStockSnapshotCue) && + (hasRequestCue || hasBalanceLexeme || hasColloquialStockSnapshotCue); } function hasInventoryProvenanceSignal(text) { return /(?:поставщик|закупк|РїСЂРѕРёСЃС…РѕР¶Рґ|откуда|РєРѕРіРґР° был куплен|активная закупк|purchase provenance|purchase date|supplier provenance|stock overlap)/iu.test(text); @@ -1332,6 +1346,11 @@ function hasInventoryProvenanceSignalV2(text) { const hasPurchaseCue = /(?:куплен(?:ы|а)?|закупк|происхождени|откуда|когда\s+был\s+куплен|когда\s+куплен|дата\s+закупк|purchase\s+provenance|purchase\s+date)/iu.test(text); return hasItemCue && hasSupplierCue && hasPurchaseCue; } +function hasInventoryPurchaseDateSignal(text) { + const hasItemCue = /(?:товар|номенклатур|sku|item|product)/iu.test(text); + const hasPurchaseDateCue = /(?:когда\s+был\s+куплен|когда\s+куплен|дата\s+закупк|purchase\s+date)/iu.test(text); + return hasItemCue && hasPurchaseDateCue; +} function hasInventoryPurchaseDocumentsSignalV2(text) { const hasItemCue = /(?:товар|номенклатур|sku|item|product)/iu.test(text); const hasPurchaseDocCue = /(?:по\s+каким\s+документам\s+был\s+куплен|по\s+каким\s+документам\s+куплен|какими\s+документами\s+был\s+куплен|документ(?:ам|ы)\s+закупк|purchase\s+documents|documents\s+of\s+purchase|through\s+which\s+documents)/iu.test(text); @@ -1343,19 +1362,30 @@ function hasInventorySaleTraceSignalV2(text) { return hasItemCue && hasTraceCue; } function hasInventorySupplierStockOverlapSignal(text) { + const hasDirectSingleItemSupplierQuestion = /(?:от\s+какого\s+поставщика\s+куплен\s+(?:товар|номенклатур(?:а|у|ы)|позици(?:я|ю|и))|от\s+кого\s+куплен\s+(?:товар|номенклатур(?:а|у|ы)|позици(?:я|ю|и)))/iu.test(text); + if (hasDirectSingleItemSupplierQuestion) { + return false; + } const hasSupplierCue = /(?:поставщик|supplier|vendor|от\s+поставщика|у\s+поставщика)/iu.test(text); - const hasStockCue = /(?:товар|номенклатур|склад|остат(?:ок|ки)|лежат|на\s+дату|по\s+состоянию\s+на\s+дату|current\s+stock|stock\s+overlap|что\s+сейчас\s+лежит)/iu.test(text); + const hasStockCue = /(?:склад|остат(?:ок|ке|ков)|лежат|лежит|сейчас\s+еще|сейчас\s+ещ[её]|на\s+дату|по\s+состоянию\s+на\s+дату|current\s+stock|stock\s+overlap|что\s+сейчас\s+лежит)/iu.test(text); return hasSupplierCue && hasStockCue; } function hasInventoryAgingSignal(text) { - return /(?:стар(?:ые|ым|ых)\s+закупк|закупал(?:ись|ся)\s+очень\s+давно|очень\s+давно|давно\s+куплен|когда\s+куплен|возраст\s+остатк|aged?\s+stock|old\s+purchase|aging\s+by\s+purchase\s+date|very\s+old\s+stock)/iu.test(text); + const hasResidueCue = /(?:остат(?:ок|ки)|в\s+остатке|среди\s+текущих\s+остатков|на\s+складе|stock\s+residue|stock\s+balance)/iu.test(text); + const hasAgingCue = /(?:стар(?:ые|ым|ых)\s+закупк|стары(?:м|х)\s+закупк(?:ам|и|ах)|относит(?:ся|ся\s+ли)?\s+.*\s+к\s+старым\s+закупк|закупал(?:ись|ся)\s+очень\s+давно|очень\s+давно|давно\s+куплен|давно\s+приобретен|куплен\s+задолго\s+до(?:\s+даты)?|закуплен(?:ы|а)?\s+давно|приобретен\s+давно|задолго\s+до(?:\s+даты)?|возраст\s+остатк|возраст\s+закупк|aged?\s+stock|old\s+purchase|old\s+purchases|old\s+stock|bought\s+long\s+ago|purchased\s+long\s+ago|aging\s+by\s+purchase\s+date|very\s+old\s+stock|very\s+old\s+purchase|old\s+procurement|older\s+purchases|aged\s+items|old\s+goods)/iu.test(text); + return hasAgingCue || (hasResidueCue && /(?:давно\s+куплен|давно\s+приобретен|задолго\s+до)/iu.test(text)); } function hasInventoryPurchaseToSaleChainSignal(text) { - const hasSupplierCue = /(?:поставщик|supplier|vendor|от\s+кого\s+куплен)/iu.test(text); - const hasBuyerCue = /(?:покупател|buyer|customer|client|кому\s+был\s+продан)/iu.test(text); const hasItemCue = /(?:товар|номенклатур|sku|item|product)/iu.test(text); - const hasPurchaseSaleCue = /(?:куплен(?:ы)?|закупк|позже\s+продан(?:ы)?|продан(?:ы)?|purchase|sale|цепочк[аи]\s+движен)/iu.test(text); - return (hasSupplierCue && hasBuyerCue && hasItemCue && hasPurchaseSaleCue) || /(?:purchase[\s-]?to[\s-]?sale\s+chain|закупка\s*->\s*склад\s*->\s*продажа)/iu.test(text); + const hasChainCue = /(?:закупк.*склад.*продаж|purchase[\s-]?to[\s-]?sale|purchase\s*->\s*(?:warehouse|stock)\s*->\s*sale|закупка\s*->\s*склад\s*->\s*продажа|цепочк[аи]\s+движен|документально\s+подтвержденн\w+\s+цепочк|supplier\s*->\s*item\s*->\s*(?:buyer|customer)|supplier\s+to\s+buyer|supplier\s+to\s+item\s+to\s+buyer)/iu.test(text) || text.includes("->"); + return hasItemCue && hasChainCue; +} +function hasInventorySupplierToBuyerChainSignal(text) { + const hasSupplierCue = /(?:поставщик|supplier|vendor)/iu.test(text); + const hasBuyerCue = /(?:покупател|buyer|customer|client)/iu.test(text); + const hasItemCue = /(?:товар|номенклатур|sku|item|product)/iu.test(text); + const hasChainCue = /(?:документально\s+подтвержденн\w+\s+цепочк|supplier\s*->\s*item\s*->\s*buyer|supplier\s*->\s*item\s*->\s*customer|supplier\s*->\s*buyer|supplier\s+to\s+buyer|supplier\s+to\s+buyer\s+chain|supplier\s+to\s+item\s+to\s+buyer|поставщик\s*->\s*товар\s*->\s*покупател|поставщик\s*->\s*товар\s*->\s*клиент|поставщик\s*->\s*товар\s*->\s*покупатель|поставщик\s+к\s+покупател|поставщик\s+к\s+клиент|поставщик\s+к\s+товару\s+и\s+покупателю)/iu.test(text) || text.includes("->"); + return hasSupplierCue && hasBuyerCue && hasItemCue && hasChainCue; } function resolveAddressIntent(userMessage) { const text = String(userMessage ?? "").trim().toLowerCase(); @@ -1459,25 +1489,25 @@ function resolveAddressIntent(userMessage) { reasons: ["documents_by_account_drilldown_signal_detected"] }; } - if (hasInventoryProvenanceSignalV2(text)) { + if (/(?:старым\s+закупк(?:ам|и|ах)|относится\s+ли\s+.*\s+к\s+старым\s+закупк(?:ам|и|ах)|очень\s+давно|давно\s+куплен|давно\s+приобретен|old\s+stock|old\s+purchase|aging\s+by\s+purchase\s+date)/iu.test(text)) { return { - intent: "inventory_purchase_provenance_for_item", - confidence: "medium", - reasons: ["inventory_provenance_signal_detected"] + intent: "inventory_aging_by_purchase_date", + confidence: "high", + reasons: ["inventory_aging_signal_detected_strong"] }; } - if (hasInventoryPurchaseDocumentsSignalV2(text)) { + if (hasInventoryAccount41Anchor(text) && hasInventoryAsOfCue(text)) { return { - intent: "inventory_purchase_documents_for_item", - confidence: "medium", - reasons: ["inventory_purchase_documents_signal_detected"] + intent: "inventory_on_hand_as_of_date", + confidence: "high", + reasons: ["inventory_account_41_as_of_date_signal_detected"] }; } - if (hasInventoryPurchaseToSaleChainSignal(text)) { + if (/(?:без\s+понятн(?:ой|ого)\s+привязк(?:и|а)\s+к\s+поставщик|без\s+привязк(?:и|а)\s+к\s+поставщик|unresolved\s+supplier\s+link)/iu.test(text)) { return { - intent: "inventory_purchase_to_sale_chain", + intent: "inventory_supplier_stock_overlap_as_of_date", confidence: "medium", - reasons: ["inventory_purchase_to_sale_chain_signal_detected"] + reasons: ["inventory_unresolved_provenance_signal_detected"] }; } if (hasInventorySupplierStockOverlapSignal(text)) { @@ -1487,6 +1517,23 @@ function resolveAddressIntent(userMessage) { reasons: ["inventory_supplier_stock_overlap_signal_detected"] }; } + if (/(?:supplier\s*->\s*buyer|supplier\s+to\s+buyer|supplier\s+to\s+buyer\s+chain|поставщик\s+к\s+покупателю|поставщик\s*->\s*товар\s*->\s*покупател|документально\s+подтвержденн\w+\s+цепочк)/iu.test(text) && + /(?:поставщик|supplier|vendor)/iu.test(text) && + /(?:покупател|buyer|customer|client)/iu.test(text) && + /(?:товар|номенклатур|sku|item|product)/iu.test(text)) { + return { + intent: "inventory_purchase_to_sale_chain", + confidence: "high", + reasons: ["inventory_supplier_to_buyer_chain_signal_detected_strong"] + }; + } + if (hasInventoryPurchaseToSaleChainSignal(text)) { + return { + intent: "inventory_purchase_to_sale_chain", + confidence: "medium", + reasons: ["inventory_purchase_to_sale_chain_signal_detected"] + }; + } if (hasInventoryAgingSignal(text)) { return { intent: "inventory_aging_by_purchase_date", @@ -1494,6 +1541,27 @@ function resolveAddressIntent(userMessage) { reasons: ["inventory_aging_signal_detected"] }; } + if (hasInventoryProvenanceSignalV2(text)) { + return { + intent: "inventory_purchase_provenance_for_item", + confidence: "medium", + reasons: ["inventory_provenance_signal_detected"] + }; + } + if (hasInventoryPurchaseDateSignal(text)) { + return { + intent: "inventory_purchase_provenance_for_item", + confidence: "medium", + reasons: ["inventory_purchase_date_signal_detected"] + }; + } + if (hasInventoryPurchaseDocumentsSignalV2(text)) { + return { + intent: "inventory_purchase_documents_for_item", + confidence: "medium", + reasons: ["inventory_purchase_documents_signal_detected"] + }; + } if (hasInventorySaleTraceSignalV2(text)) { return { intent: "inventory_sale_trace_for_item", @@ -1501,6 +1569,13 @@ function resolveAddressIntent(userMessage) { reasons: ["inventory_sale_trace_signal_detected"] }; } + if (hasInventorySupplierToBuyerChainSignal(text)) { + return { + intent: "inventory_purchase_to_sale_chain", + confidence: "medium", + reasons: ["inventory_supplier_to_buyer_chain_signal_detected"] + }; + } if (hasInventoryOnHandSignal(text)) { return { intent: "inventory_on_hand_as_of_date", diff --git a/llm_normalizer/backend/dist/services/addressQueryService.js b/llm_normalizer/backend/dist/services/addressQueryService.js index 5fb6f49..a9a85f7 100644 --- a/llm_normalizer/backend/dist/services/addressQueryService.js +++ b/llm_normalizer/backend/dist/services/addressQueryService.js @@ -1058,6 +1058,22 @@ function applyAddressFilters(rows, filters) { mismatchReason = "organization_anchor_not_matched_in_materialized_rows"; } } + if (filters.item && String(filters.item).trim()) { + const needle = String(filters.item); + const before = filtered.length; + filtered = filtered.filter((row) => matchesAnchorText(rowSearchableText(row), needle)); + if (before > 0 && filtered.length === 0 && mismatchReason === null) { + mismatchReason = "item_anchor_not_matched_in_materialized_rows"; + } + } + if (filters.warehouse && String(filters.warehouse).trim()) { + const needle = String(filters.warehouse); + const before = filtered.length; + filtered = filtered.filter((row) => matchesAnchorText(rowSearchableText(row), needle)); + if (before > 0 && filtered.length === 0 && mismatchReason === null) { + mismatchReason = "warehouse_anchor_not_matched_in_materialized_rows"; + } + } if (filters.document_ref && String(filters.document_ref).trim()) { const needle = String(filters.document_ref); const before = filtered.length; @@ -1124,6 +1140,10 @@ function isConfirmedBalanceIntent(intent) { return (intent === "account_balance_snapshot" || intent === "documents_forming_balance" || intent === "inventory_on_hand_as_of_date" || + intent === "inventory_purchase_provenance_for_item" || + intent === "inventory_purchase_documents_for_item" || + intent === "inventory_sale_trace_for_item" || + intent === "inventory_purchase_to_sale_chain" || intent === "open_contracts_confirmed_as_of_date" || intent === "payables_confirmed_as_of_date" || intent === "receivables_confirmed_as_of_date" || @@ -1453,7 +1473,21 @@ function canAutoBroadenPeriodWindow(intent, filters) { return (intent === "list_documents_by_counterparty" || intent === "bank_operations_by_counterparty" || intent === "list_documents_by_contract" || - intent === "bank_operations_by_contract"); + intent === "bank_operations_by_contract" || + intent === "inventory_purchase_provenance_for_item" || + intent === "inventory_purchase_documents_for_item" || + intent === "inventory_supplier_stock_overlap_as_of_date" || + intent === "inventory_sale_trace_for_item" || + intent === "inventory_purchase_to_sale_chain" || + intent === "inventory_aging_by_purchase_date"); +} +function shouldBoostAutoBroadenedLimit(intent) { + return (intent === "inventory_purchase_provenance_for_item" || + intent === "inventory_purchase_documents_for_item" || + intent === "inventory_supplier_stock_overlap_as_of_date" || + intent === "inventory_sale_trace_for_item" || + intent === "inventory_purchase_to_sale_chain" || + intent === "inventory_aging_by_purchase_date"); } function invertSort(sort) { return sort === "period_asc" ? "period_desc" : "period_asc"; @@ -1723,6 +1757,12 @@ function normalizeMissingAnchorLabel(anchor) { if (anchor === "organization") { return "организация"; } + if (anchor === "item") { + return "товар"; + } + if (anchor === "warehouse") { + return "склад"; + } if (anchor === "period" || anchor === "period_from" || anchor === "period_to" || anchor === "as_of_date") { return "период/дата"; } @@ -1797,6 +1837,18 @@ function buildLimitedOffers(input) { else if (input.intent === "inventory_on_hand_as_of_date") { offers.push("показать подтвержденный срез товаров на складах на дату по остатку счета 41.01"); } + else if (input.intent === "inventory_purchase_provenance_for_item") { + offers.push("показать подтвержденные закупочные движения по товару на 41.01 с датами и документами"); + } + else if (input.intent === "inventory_purchase_documents_for_item") { + offers.push("показать документы поступления по товару на 41.01"); + } + else if (input.intent === "inventory_sale_trace_for_item") { + offers.push("показать подтвержденные движения выбытия товара со счета 41.01"); + } + else if (input.intent === "inventory_purchase_to_sale_chain") { + offers.push("показать документальную цепочку по товару: поступление на 41.01 и последующее выбытие"); + } else if (input.intent === "open_contracts_confirmed_as_of_date") { offers.push("показать подтвержденный реестр договоров с открытыми взаиморасчетами на дату по 60/62/76"); } @@ -2752,6 +2804,11 @@ class AddressQueryService { const autoBroadenedFilters = { ...filters.extracted_filters }; delete autoBroadenedFilters.period_from; delete autoBroadenedFilters.period_to; + if (shouldBoostAutoBroadenedLimit(intent.intent)) { + autoBroadenedFilters.limit = Math.max(ADDRESS_ANCHOR_RECOVERY_LIMIT, typeof autoBroadenedFilters.limit === "number" && Number.isFinite(autoBroadenedFilters.limit) + ? Math.max(1, Math.trunc(autoBroadenedFilters.limit)) + : 0); + } const broadenedSelection = (0, addressRecipeCatalog_1.selectAddressRecipe)(intent.intent, autoBroadenedFilters); if (broadenedSelection.selected_recipe && broadenedSelection.missing_required_filters.length === 0) { const broadenedPlan = (0, addressRecipeCatalog_1.buildAddressRecipePlan)(broadenedSelection.selected_recipe, autoBroadenedFilters); diff --git a/llm_normalizer/backend/dist/services/addressRecipeCatalog.js b/llm_normalizer/backend/dist/services/addressRecipeCatalog.js index dd63bbc..73d23be 100644 --- a/llm_normalizer/backend/dist/services/addressRecipeCatalog.js +++ b/llm_normalizer/backend/dist/services/addressRecipeCatalog.js @@ -17,7 +17,26 @@ const MOVEMENTS_QUERY_TEMPLATE = ` ПРЕДСТАВЛЕНИЕ(Движения.СубконтоКт2) КАК СубконтоКт2, ПРЕДСТАВЛЕНИЕ(Движения.СубконтоКт3) КАК СубконтоКт3 ИЗ - РегистрБухгалтерии.Хозрасчетный КАК Движения + РегистрБухгалтерии.Хозрасчетный.ДвиженияССубконто КАК Движения +__WHERE_CLAUSE__ +УПОРЯДОЧИТЬ ПО + Движения.Период __ORDER_DIRECTION__ +`; +const INVENTORY_MOVEMENTS_QUERY_TEMPLATE = ` +ВЫБРАТЬ ПЕРВЫЕ __LIMIT__ + Движения.Период КАК Период, + ПРЕДСТАВЛЕНИЕ(Движения.Регистратор) КАК Регистратор, + ПРЕДСТАВЛЕНИЕ(Движения.СчетДт) КАК СчетДт, + ПРЕДСТАВЛЕНИЕ(Движения.СчетКт) КАК СчетКт, + Движения.Сумма КАК Сумма, + ПРЕДСТАВЛЕНИЕ(Движения.СубконтоДт1) КАК СубконтоДт1, + ПРЕДСТАВЛЕНИЕ(Движения.СубконтоДт2) КАК СубконтоДт2, + ПРЕДСТАВЛЕНИЕ(Движения.СубконтоДт3) КАК СубконтоДт3, + ПРЕДСТАВЛЕНИЕ(Движения.СубконтоКт1) КАК СубконтоКт1, + ПРЕДСТАВЛЕНИЕ(Движения.СубконтоКт2) КАК СубконтоКт2, + ПРЕДСТАВЛЕНИЕ(Движения.СубконтоКт3) КАК СубконтоКт3 +ИЗ + РегистрБухгалтерии.Хозрасчетный.ДвиженияССубконто КАК Движения __WHERE_CLAUSE__ УПОРЯДОЧИТЬ ПО Движения.Период __ORDER_DIRECTION__ @@ -686,6 +705,72 @@ const BASE_RECIPES = [ account_scope_mode: "strict", query_template: "inventory_on_hand_as_of_balance_profile" }, + { + recipe_id: "address_inventory_purchase_provenance_for_item_v1", + intent: "inventory_purchase_provenance_for_item", + purpose: "Trace purchase-side 41.01 movements for one inventory item and summarize supplier/date provenance evidence", + required_filters: ["item"], + optional_filters: ["as_of_date", "period_from", "period_to", "organization", "warehouse", "limit", "sort"], + default_limit: 400, + account_scope: ["41.01"], + account_scope_mode: "strict", + query_template: "inventory_purchase_provenance_profile" + }, + { + recipe_id: "address_inventory_purchase_documents_for_item_v1", + intent: "inventory_purchase_documents_for_item", + purpose: "Trace purchase-side 41.01 movements for one inventory item and list source purchase documents", + required_filters: ["item"], + optional_filters: ["as_of_date", "period_from", "period_to", "organization", "warehouse", "limit", "sort"], + default_limit: 400, + account_scope: ["41.01"], + account_scope_mode: "strict", + query_template: "inventory_purchase_documents_profile" + }, + { + recipe_id: "address_inventory_supplier_stock_overlap_as_of_date_v1", + intent: "inventory_supplier_stock_overlap_as_of_date", + purpose: "Trace purchase-side 41.01 movements and summarize supplier overlap with current or dated stock slice", + required_filters: [], + optional_filters: ["as_of_date", "period_from", "period_to", "organization", "warehouse", "counterparty", "limit", "sort"], + default_limit: 500, + account_scope: ["41.01"], + account_scope_mode: "strict", + query_template: "inventory_supplier_stock_overlap_profile" + }, + { + recipe_id: "address_inventory_sale_trace_for_item_v1", + intent: "inventory_sale_trace_for_item", + purpose: "Trace sale-side 41.01 movements for one inventory item and summarize sale evidence", + required_filters: ["item"], + optional_filters: ["as_of_date", "period_from", "period_to", "organization", "warehouse", "limit", "sort"], + default_limit: 400, + account_scope: ["41.01"], + account_scope_mode: "strict", + query_template: "inventory_sale_trace_profile" + }, + { + recipe_id: "address_inventory_purchase_to_sale_chain_v1", + intent: "inventory_purchase_to_sale_chain", + purpose: "Trace both purchase and sale side 41.01 movements for one inventory item and summarize the document chain", + required_filters: ["item"], + optional_filters: ["as_of_date", "period_from", "period_to", "organization", "warehouse", "limit", "sort"], + default_limit: 600, + account_scope: ["41.01"], + account_scope_mode: "strict", + query_template: "inventory_purchase_to_sale_chain_profile" + }, + { + recipe_id: "address_inventory_aging_by_purchase_date_v1", + intent: "inventory_aging_by_purchase_date", + purpose: "Trace purchase-side 41.01 movements and summarize age of stock residue by purchase dates", + required_filters: [], + optional_filters: ["item", "as_of_date", "period_from", "period_to", "organization", "warehouse", "limit", "sort"], + default_limit: 500, + account_scope: ["41.01"], + account_scope_mode: "strict", + query_template: "inventory_aging_by_purchase_date_profile" + }, { recipe_id: "address_open_contracts_confirmed_as_of_date_v1", intent: "open_contracts_confirmed_as_of_date", @@ -981,6 +1066,19 @@ function buildAccountPrefixPredicate(fieldPath, prefixes) { const clauses = normalizedPrefixes.map((prefix) => `ПОДСТРОКА(ЕСТЬNULL(${fieldPath}.Код, ""), 1, ${prefix.length}) = "${prefix}"`); return clauses.length === 1 ? clauses[0] : `(${clauses.join(" ИЛИ ")})`; } +function buildInventoryMovementQuery(filters, resolvedLimit, side) { + const debitPredicate = buildAccountPrefixPredicate("Движения.СчетДт", ["41.01"]); + const creditPredicate = buildAccountPrefixPredicate("Движения.СчетКт", ["41.01"]); + const inventoryCondition = side === "dt" + ? debitPredicate + : side === "kt" + ? creditPredicate + : `(${debitPredicate} ИЛИ ${creditPredicate})`; + return INVENTORY_MOVEMENTS_QUERY_TEMPLATE + .replace("__LIMIT__", String(resolvedLimit)) + .replace("__WHERE_CLAUSE__", buildWhereClause(filters, "Движения.Период", [inventoryCondition])) + .replaceAll("__ORDER_DIRECTION__", resolveOrderDirection(filters.sort)); +} function shouldBoostLimitForAllTimeCounterparty(filters) { const hasAnchor = (typeof filters.counterparty === "string" && filters.counterparty.trim().length > 0) || (typeof filters.contract === "string" && filters.contract.trim().length > 0); @@ -1004,6 +1102,12 @@ function maxLimitForIntent(intent) { intent === "vat_payable_forecast" || intent === "vat_liability_confirmed_for_tax_period" || intent === "inventory_on_hand_as_of_date" || + intent === "inventory_purchase_provenance_for_item" || + intent === "inventory_purchase_documents_for_item" || + intent === "inventory_supplier_stock_overlap_as_of_date" || + intent === "inventory_sale_trace_for_item" || + intent === "inventory_purchase_to_sale_chain" || + intent === "inventory_aging_by_purchase_date" || intent === "open_contracts_confirmed_as_of_date" || intent === "list_contracts_by_counterparty" || intent === "list_documents_by_counterparty" || @@ -1150,73 +1254,85 @@ function buildAddressRecipePlan(recipe, filters) { .replaceAll("__INVENTORY_ACCOUNTS_MATCH__", buildAccountPrefixPredicate("Остатки.Счет", ["41.01"])) .replaceAll("__ORDER_DIRECTION__", resolveOrderDirection(filters.sort)); })() - : recipe.query_template === "contracts_by_counterparty_profile" - ? CONTRACTS_BY_COUNTERPARTY_QUERY_TEMPLATE.replaceAll("__LIMIT__", String(resolvedLimit)) - : recipe.query_template === "open_contracts_confirmed_as_of_balance_profile" - ? (() => { - const asOfExpr = (typeof filters.as_of_date === "string" && filters.as_of_date.trim().length > 0 - ? toDateTimeExpr(filters.as_of_date, true) - : null) ?? - (typeof filters.period_to === "string" && filters.period_to.trim().length > 0 - ? toDateTimeExpr(filters.period_to, true) - : null) ?? - (typeof filters.period_from === "string" && filters.period_from.trim().length > 0 - ? toDateTimeExpr(filters.period_from, true) - : null) ?? - "ТЕКУЩАЯДАТА()"; - return OPEN_CONTRACTS_CONFIRMED_AS_OF_QUERY_TEMPLATE - .replaceAll("__LIMIT__", String(resolvedLimit)) - .replaceAll("__AS_OF_EXPR__", asOfExpr) - .replaceAll("__OPEN_CONTRACT_ACCOUNTS_MATCH__", buildAccountPrefixPredicate("Остатки.Счет", ["60", "62", "76"])) - .replaceAll("__ORDER_DIRECTION__", resolveOrderDirection(filters.sort)); - })() - : recipe.query_template === "payables_confirmed_as_of_balance_profile" - ? (() => { - const asOfExpr = (typeof filters.as_of_date === "string" && filters.as_of_date.trim().length > 0 - ? toDateTimeExpr(filters.as_of_date, true) - : null) ?? - (typeof filters.period_to === "string" && filters.period_to.trim().length > 0 - ? toDateTimeExpr(filters.period_to, true) - : null) ?? - (typeof filters.period_from === "string" && filters.period_from.trim().length > 0 - ? toDateTimeExpr(filters.period_from, true) - : null) ?? - "ТЕКУЩАЯДАТА()"; - return PAYABLES_CONFIRMED_AS_OF_QUERY_TEMPLATE - .replaceAll("__LIMIT__", String(resolvedLimit)) - .replaceAll("__AS_OF_EXPR__", asOfExpr) - .replaceAll("__PAYABLE_ACCOUNTS_MATCH__", buildAccountPrefixPredicate("Остатки.Счет", ["60", "76"])) - .replaceAll("__ORDER_DIRECTION__", resolveOrderDirection(filters.sort)); - })() - : recipe.query_template === "receivables_confirmed_as_of_balance_profile" - ? (() => { - const asOfExpr = (typeof filters.as_of_date === "string" && filters.as_of_date.trim().length > 0 - ? toDateTimeExpr(filters.as_of_date, true) - : null) ?? - (typeof filters.period_to === "string" && filters.period_to.trim().length > 0 - ? toDateTimeExpr(filters.period_to, true) - : null) ?? - (typeof filters.period_from === "string" && filters.period_from.trim().length > 0 - ? toDateTimeExpr(filters.period_from, true) - : null) ?? - "ТЕКУЩАЯДАТА()"; - return RECEIVABLES_CONFIRMED_AS_OF_QUERY_TEMPLATE - .replaceAll("__LIMIT__", String(resolvedLimit)) - .replaceAll("__AS_OF_EXPR__", asOfExpr) - .replaceAll("__RECEIVABLE_ACCOUNTS_MATCH__", buildAccountPrefixPredicate("Остатки.Счет", ["62", "76"])) - .replaceAll("__ORDER_DIRECTION__", resolveOrderDirection(filters.sort)); - })() - : MOVEMENTS_QUERY_TEMPLATE - .replace("__LIMIT__", String(resolvedLimit)) - .replace("__WHERE_CLAUSE__", (() => { - const extraConditions = []; - const accountCondition = buildMovementAccountCondition(filters); - if (accountCondition) { - extraConditions.push(accountCondition); - } - return buildWhereClause(filters, "Движения.Период", extraConditions); - })()) - .replaceAll("__ORDER_DIRECTION__", resolveOrderDirection(filters.sort)); + : recipe.query_template === "inventory_purchase_provenance_profile" + ? buildInventoryMovementQuery(filters, resolvedLimit, "dt") + : recipe.query_template === "inventory_purchase_documents_profile" + ? buildInventoryMovementQuery(filters, resolvedLimit, "dt") + : recipe.query_template === "inventory_supplier_stock_overlap_profile" + ? buildInventoryMovementQuery(filters, resolvedLimit, "dt") + : recipe.query_template === "inventory_sale_trace_profile" + ? buildInventoryMovementQuery(filters, resolvedLimit, "kt") + : recipe.query_template === "inventory_purchase_to_sale_chain_profile" + ? buildInventoryMovementQuery(filters, resolvedLimit, "either") + : recipe.query_template === "inventory_aging_by_purchase_date_profile" + ? buildInventoryMovementQuery(filters, resolvedLimit, "dt") + : recipe.query_template === "contracts_by_counterparty_profile" + ? CONTRACTS_BY_COUNTERPARTY_QUERY_TEMPLATE.replaceAll("__LIMIT__", String(resolvedLimit)) + : recipe.query_template === "open_contracts_confirmed_as_of_balance_profile" + ? (() => { + const asOfExpr = (typeof filters.as_of_date === "string" && filters.as_of_date.trim().length > 0 + ? toDateTimeExpr(filters.as_of_date, true) + : null) ?? + (typeof filters.period_to === "string" && filters.period_to.trim().length > 0 + ? toDateTimeExpr(filters.period_to, true) + : null) ?? + (typeof filters.period_from === "string" && filters.period_from.trim().length > 0 + ? toDateTimeExpr(filters.period_from, true) + : null) ?? + "ТЕКУЩАЯДАТА()"; + return OPEN_CONTRACTS_CONFIRMED_AS_OF_QUERY_TEMPLATE + .replaceAll("__LIMIT__", String(resolvedLimit)) + .replaceAll("__AS_OF_EXPR__", asOfExpr) + .replaceAll("__OPEN_CONTRACT_ACCOUNTS_MATCH__", buildAccountPrefixPredicate("Остатки.Счет", ["60", "62", "76"])) + .replaceAll("__ORDER_DIRECTION__", resolveOrderDirection(filters.sort)); + })() + : recipe.query_template === "payables_confirmed_as_of_balance_profile" + ? (() => { + const asOfExpr = (typeof filters.as_of_date === "string" && filters.as_of_date.trim().length > 0 + ? toDateTimeExpr(filters.as_of_date, true) + : null) ?? + (typeof filters.period_to === "string" && filters.period_to.trim().length > 0 + ? toDateTimeExpr(filters.period_to, true) + : null) ?? + (typeof filters.period_from === "string" && filters.period_from.trim().length > 0 + ? toDateTimeExpr(filters.period_from, true) + : null) ?? + "ТЕКУЩАЯДАТА()"; + return PAYABLES_CONFIRMED_AS_OF_QUERY_TEMPLATE + .replaceAll("__LIMIT__", String(resolvedLimit)) + .replaceAll("__AS_OF_EXPR__", asOfExpr) + .replaceAll("__PAYABLE_ACCOUNTS_MATCH__", buildAccountPrefixPredicate("Остатки.Счет", ["60", "76"])) + .replaceAll("__ORDER_DIRECTION__", resolveOrderDirection(filters.sort)); + })() + : recipe.query_template === "receivables_confirmed_as_of_balance_profile" + ? (() => { + const asOfExpr = (typeof filters.as_of_date === "string" && filters.as_of_date.trim().length > 0 + ? toDateTimeExpr(filters.as_of_date, true) + : null) ?? + (typeof filters.period_to === "string" && filters.period_to.trim().length > 0 + ? toDateTimeExpr(filters.period_to, true) + : null) ?? + (typeof filters.period_from === "string" && filters.period_from.trim().length > 0 + ? toDateTimeExpr(filters.period_from, true) + : null) ?? + "ТЕКУЩАЯДАТА()"; + return RECEIVABLES_CONFIRMED_AS_OF_QUERY_TEMPLATE + .replaceAll("__LIMIT__", String(resolvedLimit)) + .replaceAll("__AS_OF_EXPR__", asOfExpr) + .replaceAll("__RECEIVABLE_ACCOUNTS_MATCH__", buildAccountPrefixPredicate("Остатки.Счет", ["62", "76"])) + .replaceAll("__ORDER_DIRECTION__", resolveOrderDirection(filters.sort)); + })() + : MOVEMENTS_QUERY_TEMPLATE + .replace("__LIMIT__", String(resolvedLimit)) + .replace("__WHERE_CLAUSE__", (() => { + const extraConditions = []; + const accountCondition = buildMovementAccountCondition(filters); + if (accountCondition) { + extraConditions.push(accountCondition); + } + return buildWhereClause(filters, "Движения.Период", extraConditions); + })()) + .replaceAll("__ORDER_DIRECTION__", resolveOrderDirection(filters.sort)); return { recipe, query, diff --git a/llm_normalizer/backend/dist/services/address_runtime/composeStage.js b/llm_normalizer/backend/dist/services/address_runtime/composeStage.js index e7c1c6f..fc9d9ee 100644 --- a/llm_normalizer/backend/dist/services/address_runtime/composeStage.js +++ b/llm_normalizer/backend/dist/services/address_runtime/composeStage.js @@ -689,6 +689,130 @@ function buildInventoryOnHandAggregate(rows, asOfDate) { return left.item.localeCompare(right.item, "ru"); }); } +function inventoryTraceDateLabel(value) { + return value ? formatDateRu(value) : "дата не указана"; +} +function hasInventoryAccountPrefix(value, prefix) { + const normalized = String(value ?? "") + .trim() + .replace(",", "."); + return normalized === prefix || normalized.startsWith(`${prefix}.`) || normalized.startsWith(prefix); +} +function isInventoryPurchaseMovement(row) { + return hasInventoryAccountPrefix(row.account_dt, "41.01"); +} +function isInventorySaleMovement(row) { + return hasInventoryAccountPrefix(row.account_kt, "41.01"); +} +function looksLikeInventoryTraceDocumentToken(value) { + const normalized = String(value ?? "").trim(); + if (!normalized) { + return false; + } + return (/(?:№|contract|invoice|payment|order|накладн|акт|счет|сч[её]т|поступлен|реализац|договор)/iu.test(normalized) || + /(?:[a-zа-яё].*\d|\d.*[a-zа-яё])/iu.test(normalized)); +} +function looksLikeInventoryPartyToken(value) { + const normalized = String(value ?? "").trim(); + if (!normalized || normalized.length < 3) { + return false; + } + if (/^(?:0|<пусто>|пустая ссылка)$/iu.test(normalized)) { + return false; + } + if (/^\d{4}-\d{2}-\d{2}/.test(normalized)) { + return false; + } + if (/(?:склад|warehouse)/iu.test(normalized)) { + return false; + } + if (looksLikeInventoryTraceDocumentToken(normalized)) { + return false; + } + if (/(?:ооо|ао|пао|зао|ип|llc|ltd|inc|corp|компани|организац|департамент|комитет|министерств|служб|управлен|торговый\s+дом)/iu.test(normalized)) { + return true; + } + const letterChars = (normalized.match(/[A-Za-zА-Яа-яЁё]/g) ?? []).length; + if (letterChars < 3) { + return false; + } + const words = normalized.split(/\s+/u).filter(Boolean); + if (words.length >= 2) { + return true; + } + return normalized === normalized.toUpperCase() && normalized.length >= 4; +} +function extractInventoryCounterpartyCandidates(row) { + const itemToken = normalizeEntityToken(extractInventoryItemName(row)); + const warehouseToken = normalizeEntityToken(extractInventoryWarehouseName(row)); + const organizationToken = normalizeEntityToken(extractInventoryOrganizationName(row)); + const candidates = []; + for (const token of row.analytics) { + const normalized = String(token ?? "").trim(); + if (!normalized || !looksLikeInventoryPartyToken(normalized)) { + continue; + } + const comparable = normalizeEntityToken(normalized); + if (!comparable || comparable === itemToken || comparable === warehouseToken || comparable === organizationToken) { + continue; + } + candidates.push(normalized); + } + return uniqueStrings(candidates); +} +function summarizeInventoryTraceRows(rows) { + const items = uniqueStrings(rows + .map((row) => extractInventoryItemName(row)) + .filter((item) => Boolean(item))); + const warehouses = uniqueStrings(rows + .map((row) => extractInventoryWarehouseName(row)) + .filter((item) => Boolean(item))); + const organizations = uniqueStrings(rows + .map((row) => extractInventoryOrganizationName(row)) + .filter((item) => Boolean(item))); + const counterparties = uniqueStrings(rows.flatMap((row) => extractInventoryCounterpartyCandidates(row))); + const documents = uniqueStrings(rows + .map((row) => String(row.registrator ?? "").trim()) + .filter((item) => item.length > 0 && item !== "(без названия)")); + const periods = rows + .map((row) => String(row.period ?? "").trim()) + .filter((item) => item.length > 0) + .sort((left, right) => left.localeCompare(right, "ru")); + const totalAmount = rows.reduce((sum, row) => sum + (typeof row.amount === "number" && Number.isFinite(row.amount) ? row.amount : 0), 0); + return { + item: items[0] ?? null, + warehouses, + organizations, + counterparties, + documents, + firstPeriod: periods[0] ?? null, + lastPeriod: periods.length > 0 ? periods[periods.length - 1] : null, + totalAmount + }; +} +function formatInventoryTraceRows(rows, limit = 10) { + return rows.slice(0, limit).map((row, index) => { + const parties = extractInventoryCounterpartyCandidates(row); + const warehouse = extractInventoryWarehouseName(row); + const organization = extractInventoryOrganizationName(row); + const amount = typeof row.amount === "number" && Number.isFinite(row.amount) ? formatMoneyRub(row.amount) : "сумма не указана"; + const parts = [ + `${index + 1}. ${row.registrator}`, + `дата: ${inventoryTraceDateLabel(row.period)}`, + `сумма: ${amount}` + ]; + if (warehouse) { + parts.push(`склад: ${warehouse}`); + } + if (organization) { + parts.push(`организация: ${organization}`); + } + if (parties.length > 0) { + parts.push(`контрагент: ${parties[0]}`); + } + return parts.join(" | "); + }); +} function liabilityCategoryLabel(category) { if (category === "supplier_or_contractor") { return "поставщики/подрядчики"; @@ -2873,6 +2997,257 @@ function composeFactualReply(intent, rows, options = {}) { } }; } + if (intent === "inventory_purchase_documents_for_item") { + const asOfDate = resolvePayablesAsOfDate(options); + const purchaseRows = rows.filter((row) => isInventoryPurchaseMovement(row)); + const summary = summarizeInventoryTraceRows(purchaseRows); + const itemLabel = summary.item ?? "товар не определен"; + const lines = [ + `Собран подтвержденный список документов поступления по товару ${itemLabel} до ${formatDateRu(asOfDate)}.`, + "", + "Блок 1. Статус результата", + "- Результат: подтвержденные движения поступления товара на 41.01 по доступным бухгалтерским проводкам.", + "", + "Блок 2. Что учтено", + `- Дата верхней границы: ${formatDateRu(asOfDate)}.`, + "- Контур: движения, где товар поступает на счет 41.01.", + `- Документов в выборке: ${formatNumberWithDots(summary.documents.length)}.`, + `- Операций в выборке: ${formatNumberWithDots(purchaseRows.length)}.` + ]; + if (summary.counterparties.length > 0) { + lines.push(`- Найденные контрагенты в закупочных движениях: ${summary.counterparties.slice(0, 3).join("; ")}.`); + } + lines.push("", "Блок 3. Документы"); + if (purchaseRows.length > 0) { + lines.push(...formatInventoryTraceRows(purchaseRows, 12)); + } + else { + lines.push("- По выбранному товару не найдено проводок поступления на 41.01 в доступном контуре."); + } + return { + responseType: purchaseRows.length > 0 ? "FACTUAL_LIST" : "FACTUAL_SUMMARY", + text: joinLines(lines), + semantics: { + result_mode: "confirmed_balance", + evidence_strength: purchaseRows.length > 0 ? "strong" : "medium", + balance_confirmed: purchaseRows.length > 0 + } + }; + } + if (intent === "inventory_purchase_provenance_for_item") { + const asOfDate = resolvePayablesAsOfDate(options); + const purchaseRows = rows.filter((row) => isInventoryPurchaseMovement(row)); + const summary = summarizeInventoryTraceRows(purchaseRows); + const itemLabel = summary.item ?? "товар не определен"; + const lines = [ + `Собран подтвержденный закупочный след по товару ${itemLabel} до ${formatDateRu(asOfDate)}.`, + "", + "Блок 1. Статус результата", + "- Результат: показаны подтвержденные закупочные движения на 41.01 по выбранному товару.", + "- Важно: без партионности этот контур не подменяет собой лот-level доказательство происхождения текущего остатка.", + "", + "Блок 2. Сводка", + `- Первая найденная дата закупочного движения: ${inventoryTraceDateLabel(summary.firstPeriod)}.`, + `- Последняя найденная дата закупочного движения: ${inventoryTraceDateLabel(summary.lastPeriod)}.`, + `- Документов поступления: ${formatNumberWithDots(summary.documents.length)}.`, + `- Операций поступления: ${formatNumberWithDots(purchaseRows.length)}.` + ]; + if (summary.counterparties.length === 1) { + lines.push(`- По доступным закупочным движениям товар связан с поставщиком: ${summary.counterparties[0]}.`); + } + else if (summary.counterparties.length > 1) { + lines.push(`- По доступным закупочным движениям найдено несколько поставщиков: ${summary.counterparties.slice(0, 4).join("; ")}.`); + } + else if (purchaseRows.length > 0) { + lines.push("- Закупочные документы найдены, но поставщик не материализован отдельным полем в текущем exact-контуре."); + } + if (summary.documents.length > 0) { + lines.push("", "Блок 3. Опорные документы", ...formatInventoryTraceRows(purchaseRows, 8)); + } + return { + responseType: purchaseRows.length > 0 ? "FACTUAL_SUMMARY" : "FACTUAL_SUMMARY", + text: joinLines(lines), + semantics: { + result_mode: "confirmed_balance", + evidence_strength: purchaseRows.length > 0 ? (summary.counterparties.length === 1 ? "strong" : "medium") : "medium", + balance_confirmed: purchaseRows.length > 0 + } + }; + } + if (intent === "inventory_supplier_stock_overlap_as_of_date") { + const asOfDate = resolvePayablesAsOfDate(options); + const purchaseRows = rows.filter((row) => isInventoryPurchaseMovement(row)); + const summary = summarizeInventoryTraceRows(purchaseRows); + const unresolvedRows = purchaseRows.filter((row) => extractInventoryCounterpartyCandidates(row).length === 0); + const warehouseLabel = summary.warehouses[0] ?? "не указанного склада"; + const lines = [ + `Собран exact-срез supplier overlap для складского остатка до ${formatDateRu(asOfDate)}.`, + "", + "Блок 1. Статус результата", + `- Контур: подтвержденные закупочные движения на 41.01, связанные со складом ${warehouseLabel}.`, + "- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.", + "", + "Блок 2. Сводка", + `- Первая найденная дата закупочного движения: ${inventoryTraceDateLabel(summary.firstPeriod)}.`, + `- Последняя найденная дата закупочного движения: ${inventoryTraceDateLabel(summary.lastPeriod)}.`, + `- Закупочных документов в выборке: ${formatNumberWithDots(summary.documents.length)}.`, + `- Закупочных операций в выборке: ${formatNumberWithDots(purchaseRows.length)}.` + ]; + if (summary.counterparties.length > 0) { + lines.push(`- Найденные поставщики в наблюдаемом контуре: ${summary.counterparties.slice(0, 6).join("; ")}.`); + } + else if (purchaseRows.length > 0) { + lines.push("- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре."); + } + else { + lines.push("- В доступном exact-контуре не найдено закупочных движений по 41.01 для выбранного складского среза."); + } + if (unresolvedRows.length > 0) { + lines.push(`- Операций без явно материализованного поставщика: ${formatNumberWithDots(unresolvedRows.length)}.`); + } + if (purchaseRows.length > 0) { + lines.push("", "Блок 3. Опорные документы", ...formatInventoryTraceRows(purchaseRows, 10)); + } + return { + responseType: "FACTUAL_SUMMARY", + text: joinLines(lines), + semantics: { + result_mode: "confirmed_balance", + evidence_strength: purchaseRows.length > 0 ? (summary.counterparties.length > 0 ? "strong" : "medium") : "medium", + balance_confirmed: purchaseRows.length > 0 + } + }; + } + if (intent === "inventory_aging_by_purchase_date") { + const asOfDate = resolvePayablesAsOfDate(options); + const purchaseRows = rows.filter((row) => isInventoryPurchaseMovement(row)); + const summary = summarizeInventoryTraceRows(purchaseRows); + const firstPeriodTime = summary.firstPeriod ? Date.parse(summary.firstPeriod) : Number.NaN; + const asOfTime = Date.parse(`${asOfDate}T23:59:59.000Z`); + const ageDays = Number.isFinite(firstPeriodTime) && Number.isFinite(asOfTime) && firstPeriodTime <= asOfTime + ? Math.floor((asOfTime - firstPeriodTime) / 86_400_000) + : null; + const itemLabel = summary.item ?? "выбранному складскому остатку"; + const lines = [ + `Собран exact-срез возраста закупочного следа по ${itemLabel} до ${formatDateRu(asOfDate)}.`, + "", + "Блок 1. Статус результата", + "- Контур: показаны подтвержденные закупочные движения на 41.01 и их временной разброс.", + "- Важно: без партионности этот контур не доказывает возраст конкретного лота, а показывает документально наблюдаемый диапазон закупок.", + "", + "Блок 2. Сводка", + `- Первая найденная дата закупочного движения: ${inventoryTraceDateLabel(summary.firstPeriod)}.`, + `- Последняя найденная дата закупочного движения: ${inventoryTraceDateLabel(summary.lastPeriod)}.`, + `- Закупочных документов в выборке: ${formatNumberWithDots(summary.documents.length)}.`, + `- Закупочных операций в выборке: ${formatNumberWithDots(purchaseRows.length)}.` + ]; + if (ageDays !== null) { + lines.push(`- Между самой ранней найденной закупкой и датой среза прошло ${formatNumberWithDots(ageDays)} дн.`); + } + if (summary.counterparties.length > 0) { + lines.push(`- Поставщики, встречающиеся в наблюдаемом закупочном следе: ${summary.counterparties.slice(0, 4).join("; ")}.`); + } + if (purchaseRows.length > 0) { + lines.push("", "Блок 3. Опорные документы", ...formatInventoryTraceRows(purchaseRows, 8)); + } + else { + lines.push("", "Блок 3. Опорные документы", "- В доступном exact-контуре не найдено закупочных движений по 41.01 для выбранного среза."); + } + return { + responseType: "FACTUAL_SUMMARY", + text: joinLines(lines), + semantics: { + result_mode: "confirmed_balance", + evidence_strength: purchaseRows.length > 0 ? "strong" : "medium", + balance_confirmed: purchaseRows.length > 0 + } + }; + } + if (intent === "inventory_sale_trace_for_item") { + const asOfDate = resolvePayablesAsOfDate(options); + const saleRows = rows.filter((row) => isInventorySaleMovement(row)); + const summary = summarizeInventoryTraceRows(saleRows); + const itemLabel = summary.item ?? "товар не определен"; + const lines = [ + `Собран подтвержденный след выбытия по товару ${itemLabel} до ${formatDateRu(asOfDate)}.`, + "", + "Блок 1. Статус результата", + "- Результат: показаны подтвержденные движения выбытия товара со счета 41.01.", + "", + "Блок 2. Сводка", + `- Первая найденная дата выбытия: ${inventoryTraceDateLabel(summary.firstPeriod)}.`, + `- Последняя найденная дата выбытия: ${inventoryTraceDateLabel(summary.lastPeriod)}.`, + `- Документов выбытия: ${formatNumberWithDots(summary.documents.length)}.`, + `- Операций выбытия: ${formatNumberWithDots(saleRows.length)}.` + ]; + if (summary.counterparties.length === 1) { + lines.push(`- По доступным движениям товар отгружался покупателю: ${summary.counterparties[0]}.`); + } + else if (summary.counterparties.length > 1) { + lines.push(`- По доступным движениям найдено несколько покупателей: ${summary.counterparties.slice(0, 4).join("; ")}.`); + } + else if (saleRows.length > 0) { + lines.push("- Документы выбытия найдены, но покупатель не материализован отдельным полем в текущем exact-контуре."); + } + lines.push("", "Блок 3. Документы выбытия"); + if (saleRows.length > 0) { + lines.push(...formatInventoryTraceRows(saleRows, 12)); + } + else { + lines.push("- По выбранному товару не найдено проводок выбытия со счета 41.01 в доступном контуре."); + } + return { + responseType: saleRows.length > 0 ? "FACTUAL_LIST" : "FACTUAL_SUMMARY", + text: joinLines(lines), + semantics: { + result_mode: "confirmed_balance", + evidence_strength: saleRows.length > 0 ? (summary.counterparties.length > 0 ? "strong" : "medium") : "medium", + balance_confirmed: saleRows.length > 0 + } + }; + } + if (intent === "inventory_purchase_to_sale_chain") { + const asOfDate = resolvePayablesAsOfDate(options); + const purchaseRows = rows.filter((row) => isInventoryPurchaseMovement(row)); + const saleRows = rows.filter((row) => isInventorySaleMovement(row)); + const purchaseSummary = summarizeInventoryTraceRows(purchaseRows); + const saleSummary = summarizeInventoryTraceRows(saleRows); + const itemLabel = purchaseSummary.item ?? saleSummary.item ?? "товар не определен"; + const lines = [ + `Собрана документальная цепочка по товару ${itemLabel} до ${formatDateRu(asOfDate)}.`, + "", + "Блок 1. Статус результата", + `- Закупочных движений на 41.01: ${formatNumberWithDots(purchaseRows.length)}.`, + `- Движений выбытия со счета 41.01: ${formatNumberWithDots(saleRows.length)}.` + ]; + if (purchaseRows.length > 0 && saleRows.length > 0) { + lines.push("- В текущем контуре найдены обе стороны цепочки: поступление и последующее выбытие."); + } + else if (purchaseRows.length > 0) { + lines.push("- Найдена только закупочная часть цепочки; выбытие в текущем exact-контуре не подтверждено."); + } + else if (saleRows.length > 0) { + lines.push("- Найдена только часть выбытия; закупочная часть цепочки в текущем exact-контуре не подтверждена."); + } + else { + lines.push("- Для выбранного товара не найдено движений по 41.01, из которых можно собрать цепочку."); + } + if (purchaseRows.length > 0) { + lines.push("", "Блок 2. Закупка", `- Первая дата: ${inventoryTraceDateLabel(purchaseSummary.firstPeriod)}.`, `- Последняя дата: ${inventoryTraceDateLabel(purchaseSummary.lastPeriod)}.`, ...formatInventoryTraceRows(purchaseRows, 6)); + } + if (saleRows.length > 0) { + lines.push("", "Блок 3. Выбытие", `- Первая дата: ${inventoryTraceDateLabel(saleSummary.firstPeriod)}.`, `- Последняя дата: ${inventoryTraceDateLabel(saleSummary.lastPeriod)}.`, ...formatInventoryTraceRows(saleRows, 6)); + } + return { + responseType: purchaseRows.length > 0 || saleRows.length > 0 ? "FACTUAL_SUMMARY" : "FACTUAL_SUMMARY", + text: joinLines(lines), + semantics: { + result_mode: "confirmed_balance", + evidence_strength: purchaseRows.length > 0 && saleRows.length > 0 ? "strong" : purchaseRows.length > 0 || saleRows.length > 0 ? "medium" : "weak", + balance_confirmed: purchaseRows.length > 0 || saleRows.length > 0 + } + }; + } if (intent === "open_contracts_confirmed_as_of_date") { const asOfDate = resolvePayablesAsOfDate(options); const confirmedContracts = buildOpenContractConfirmedBalanceAggregate(rows, asOfDate); diff --git a/llm_normalizer/backend/dist/services/address_runtime/decomposeStage.js b/llm_normalizer/backend/dist/services/address_runtime/decomposeStage.js index 8e7e535..7c280e6 100644 --- a/llm_normalizer/backend/dist/services/address_runtime/decomposeStage.js +++ b/llm_normalizer/backend/dist/services/address_runtime/decomposeStage.js @@ -390,6 +390,12 @@ function mergeFollowupFilters(current, intent, userMessage, followupContext) { intent === "list_open_contracts" || intent === "open_contracts_confirmed_as_of_date" || intent === "inventory_on_hand_as_of_date" || + intent === "inventory_purchase_provenance_for_item" || + intent === "inventory_purchase_documents_for_item" || + intent === "inventory_supplier_stock_overlap_as_of_date" || + intent === "inventory_sale_trace_for_item" || + intent === "inventory_purchase_to_sale_chain" || + intent === "inventory_aging_by_purchase_date" || intent === "payables_confirmed_as_of_date" || intent === "receivables_confirmed_as_of_date" || intent === "vat_payable_confirmed_as_of_date") { @@ -420,6 +426,19 @@ function mergeFollowupFilters(current, intent, userMessage, followupContext) { reasons.push("as_of_date_from_followup_context"); } } + if (!sameDateRequested && + (intent === "inventory_sale_trace_for_item" || intent === "inventory_purchase_to_sale_chain") && + !hasExplicitPeriodLiteral(userMessage) && + !hasExplicitCurrentDateHint(userMessage)) { + const inheritedAsOfDate = previousAsOfDate ?? previousPeriodTo ?? previousPeriodFrom; + const currentAsOfDate = toNonEmptyString(merged.as_of_date); + const todayIso = new Date().toISOString().slice(0, 10); + const currentLooksDefaultedToToday = currentAsOfDate === todayIso; + if (inheritedAsOfDate && (!currentAsOfDate || currentLooksDefaultedToToday) && currentAsOfDate !== inheritedAsOfDate) { + merged.as_of_date = inheritedAsOfDate; + reasons.push("as_of_date_from_followup_context"); + } + } if (!sameDateRequested && hasFollowupSignalForConfirmed && !hasExplicitPeriodLiteral(userMessage) && @@ -460,6 +479,12 @@ function mergeFollowupFilters(current, intent, userMessage, followupContext) { intent === "documents_forming_balance" || intent === "open_contracts_confirmed_as_of_date" || intent === "inventory_on_hand_as_of_date" || + intent === "inventory_purchase_provenance_for_item" || + intent === "inventory_purchase_documents_for_item" || + intent === "inventory_supplier_stock_overlap_as_of_date" || + intent === "inventory_sale_trace_for_item" || + intent === "inventory_purchase_to_sale_chain" || + intent === "inventory_aging_by_purchase_date" || intent === "payables_confirmed_as_of_date" || intent === "receivables_confirmed_as_of_date" || intent === "vat_payable_confirmed_as_of_date"; diff --git a/llm_normalizer/backend/dist/services/assistantService.js b/llm_normalizer/backend/dist/services/assistantService.js index 99a5b80..d237203 100644 --- a/llm_normalizer/backend/dist/services/assistantService.js +++ b/llm_normalizer/backend/dist/services/assistantService.js @@ -3856,12 +3856,27 @@ const ADDRESS_INTENTS_KEEP_ADDRESS_LANE = new Set([ "list_documents_by_counterparty", "bank_operations_by_counterparty", "list_contracts_by_counterparty", + "inventory_purchase_provenance_for_item", + "inventory_purchase_documents_for_item", + "inventory_supplier_stock_overlap_as_of_date", + "inventory_sale_trace_for_item", + "inventory_purchase_to_sale_chain", + "inventory_aging_by_purchase_date", "contract_usage_overview", "contract_usage_and_value", "vat_payable_forecast", "vat_liability_confirmed_for_tax_period", "vat_payable_confirmed_as_of_date" ]); +const ADDRESS_INTENTS_ALLOW_STRICT_DEEP_INVESTIGATION_BYPASS = new Set([ + "inventory_purchase_provenance_for_item", + "inventory_purchase_documents_for_item", + "inventory_sale_trace_for_item", + "inventory_purchase_to_sale_chain" +]); +function shouldBypassStrictDeepInvestigationCueForAddressIntent(intent) { + return Boolean(intent && ADDRESS_INTENTS_ALLOW_STRICT_DEEP_INVESTIGATION_BYPASS.has(intent)); +} function resolveAssistantOrchestrationDecision(input) { const rawUserMessage = String(input?.rawUserMessage ?? input?.userMessage ?? ""); const effectiveAddressUserMessage = String(input?.effectiveAddressUserMessage ?? rawUserMessage); @@ -3915,11 +3930,13 @@ function resolveAssistantOrchestrationDecision(input) { hasStrictDeepInvestigationCue(repairedRawUserMessage) || hasStrictDeepInvestigationCue(effectiveAddressUserMessage) || hasStrictDeepInvestigationCue(repairedEffectiveAddressUserMessage); + const strictDeepInvestigationBypassAllowed = shouldBypassStrictDeepInvestigationCueForAddressIntent(intentResolution.intent) || + shouldBypassStrictDeepInvestigationCueForAddressIntent(llmContractIntent); const keepAddressLaneByIntent = semanticApplyCanonicalRecommended && Boolean((intentResolution.intent && ADDRESS_INTENTS_KEEP_ADDRESS_LANE.has(intentResolution.intent)) || (llmContractIntent && ADDRESS_INTENTS_KEEP_ADDRESS_LANE.has(llmContractIntent)) || openContractsAddressSignal) && - !strictDeepInvestigationCueDetected; + (!strictDeepInvestigationCueDetected || strictDeepInvestigationBypassAllowed); const strongDataSignal = hasStrongDataIntentSignal(rawUserMessage) || hasStrongDataIntentSignal(repairedRawUserMessage) || hasStrongDataIntentSignal(effectiveAddressUserMessage) || @@ -4065,7 +4082,7 @@ function resolveAssistantOrchestrationDecision(input) { hasShortDebtMirrorFollowupSignal(effectiveAddressUserMessage) || hasShortDebtMirrorFollowupSignal(repairedRawUserMessage) || hasShortDebtMirrorFollowupSignal(repairedEffectiveAddressUserMessage)); - const supportedAddressIntentDetected = !strictDeepInvestigationCueDetected && + const supportedAddressIntentDetected = (!strictDeepInvestigationCueDetected || strictDeepInvestigationBypassAllowed) && Boolean((intentResolution.intent && ADDRESS_INTENTS_KEEP_ADDRESS_LANE.has(intentResolution.intent)) || (llmContractIntent && ADDRESS_INTENTS_KEEP_ADDRESS_LANE.has(llmContractIntent)) || openContractsAddressSignal); @@ -4217,6 +4234,7 @@ function resolveAssistantOrchestrationDecision(input) { semantic_reason_codes: semanticReasonCodes, semantic_route_arbitration: { supported_address_intent_detected: supportedAddressIntentDetected, + strict_deep_investigation_bypass_allowed: strictDeepInvestigationBypassAllowed, semantic_deep_investigation_hint_detected: semanticDeepInvestigationHintDetected, semantic_aggregate_shape_detected: semanticAggregateShapeDetected, followup_semantic_override_to_deep_allowed: followupSemanticOverrideToDeepAllowed diff --git a/llm_normalizer/backend/src/services/addressCapabilityPolicy.ts b/llm_normalizer/backend/src/services/addressCapabilityPolicy.ts index e539713..a286848 100644 --- a/llm_normalizer/backend/src/services/addressCapabilityPolicy.ts +++ b/llm_normalizer/backend/src/services/addressCapabilityPolicy.ts @@ -165,14 +165,34 @@ function resolveCapabilityEnabled(intent: AddressIntent): { enabled: boolean; re if ( intent === "inventory_purchase_provenance_for_item" || intent === "inventory_purchase_documents_for_item" || - intent === "inventory_supplier_stock_overlap_as_of_date" || intent === "inventory_sale_trace_for_item" || - intent === "inventory_purchase_to_sale_chain" || - intent === "inventory_aging_by_purchase_date" + intent === "inventory_purchase_to_sale_chain" ) { + if (intent === "inventory_purchase_to_sale_chain") { + return { + enabled: true, + reason: "inventory_purchase_to_sale_chain_route_enabled" + }; + } return { - enabled: false, - reason: "inventory_provenance_route_not_implemented" + enabled: FEATURE_ASSISTANT_ROUTE_BALANCE_EXACT_V1, + reason: FEATURE_ASSISTANT_ROUTE_BALANCE_EXACT_V1 + ? "inventory_trace_route_enabled" + : "inventory_trace_route_disabled_by_flag" + }; + } + if (intent === "inventory_supplier_stock_overlap_as_of_date") { + return { + enabled: FEATURE_ASSISTANT_ROUTE_BALANCE_EXACT_V1, + reason: FEATURE_ASSISTANT_ROUTE_BALANCE_EXACT_V1 + ? "inventory_supplier_stock_overlap_route_enabled" + : "inventory_supplier_stock_overlap_route_disabled_by_flag" + }; + } + if (intent === "inventory_aging_by_purchase_date") { + return { + enabled: true, + reason: "inventory_aging_route_enabled" }; } if (intent === "list_payables_counterparties") { diff --git a/llm_normalizer/backend/src/services/addressFilterExtractor.ts b/llm_normalizer/backend/src/services/addressFilterExtractor.ts index 595140f..625b227 100644 --- a/llm_normalizer/backend/src/services/addressFilterExtractor.ts +++ b/llm_normalizer/backend/src/services/addressFilterExtractor.ts @@ -1,4 +1,4 @@ -import type { AddressFilterExtraction, AddressFilterSet, AddressIntent } from "../types/addressQuery"; +import type { AddressFilterExtraction, AddressFilterSet, AddressIntent } from "../types/addressQuery"; import iconv from "iconv-lite"; const ACCOUNT_PATTERN = /(?:сч[её]т|счет|account)[^0-9]{0,12}(\d{2}(?:[.,]\d{1,2})?)/i; @@ -72,6 +72,10 @@ const COUNTERPARTY_TOKEN_NOISE = new Set([ "могу", "можем", "нет", + "был", + "были", + "куплен", + "куплены", "покажи", "показать", "скажи", @@ -906,6 +910,243 @@ function hasExplicitAccountCue(text: string): boolean { return /(?:сч[её]т|счет|account|acct)/iu.test(String(text ?? "")); } +function isInventoryTraceIntent(intent: AddressIntent): boolean { + return ( + intent === "inventory_purchase_provenance_for_item" || + intent === "inventory_purchase_documents_for_item" || + intent === "inventory_supplier_stock_overlap_as_of_date" || + intent === "inventory_sale_trace_for_item" || + intent === "inventory_purchase_to_sale_chain" || + intent === "inventory_aging_by_purchase_date" + ); +} + +function isInventoryItemAnchoredIntent(intent: AddressIntent): boolean { + return ( + intent === "inventory_purchase_provenance_for_item" || + intent === "inventory_purchase_documents_for_item" || + intent === "inventory_aging_by_purchase_date" || + intent === "inventory_sale_trace_for_item" || + intent === "inventory_purchase_to_sale_chain" + ); +} + +function usesRecipeDefaultLimit(intent: AddressIntent): boolean { + return ( + intent === "inventory_on_hand_as_of_date" || + intent === "inventory_purchase_provenance_for_item" || + intent === "inventory_purchase_documents_for_item" || + intent === "inventory_supplier_stock_overlap_as_of_date" || + intent === "inventory_sale_trace_for_item" || + intent === "inventory_purchase_to_sale_chain" || + intent === "inventory_aging_by_purchase_date" + ); +} + +function isLowQualityInventoryItemAnchorValue(rawValue: string): boolean { + const value = cleanupAnchorValue(rawValue) + .trim() + .toLowerCase() + .replace(/ё/g, "е"); + if (!value || value.length < 3) { + return true; + } + if ( + /^(?:товар(?:ы|а|у|ом)?|номенклатура|позиция|остаток|остатки|склад|складе|складу|поставщик|покупатель|документ|документы)$/iu.test( + value + ) + ) { + return true; + } + const lowQualityTokens = new Set([ + "сейчас", + "лежат", + "лежит", + "лежали", + "куплен", + "куплена", + "куплены", + "продан", + "продана", + "проданы", + "документам", + "документами", + "документы", + "поставщика", + "поставщику", + "покупателю", + "остаток", + "остатки", + "склад", + "складе", + "складу" + ]); + const meaningfulTokens = value + .split(/[^a-zа-я0-9]+/iu) + .map((token) => token.trim()) + .filter(Boolean) + .filter((token) => !lowQualityTokens.has(token)); + return meaningfulTokens.length === 0; +} + +function cleanupInventoryItemAnchorValue(value: string): string { + return String(value ?? "") + .replace(/^['"«»“”„`’‘]+|['"«»“”„`’‘]+$/gu, "") + .replace(/\s+/g, " ") + .trim(); +} + +function trimInventoryItemAnchorTail(rawValue: string): string { + let value = cleanupInventoryItemAnchorValue(rawValue); + const tailPatterns = [ + /\s+для\s+остатка(?:\s+на\s+складе.*)?$/iu, + /\s+из\s+текущ(?:его|их)\s+остат(?:ка|ков).*$/iu, + /\s+из\s+остат(?:ка|ков).*$/iu, + /\s+в\s+остатке.*$/iu, + /\s+на\s+складе.*$/iu, + /\s*:\s*закупк.*$/iu + ]; + for (const pattern of tailPatterns) { + value = value.replace(pattern, ""); + } + return cleanupInventoryItemAnchorValue(value); +} + +function extractSelectedObjectQuotedValue(text: string): string | undefined { + const patterns = [ + /(?:по\s+выбранному\s+объекту|for\s+selected\s+object)\s*[«"]([^»"\r\n]+)[»"]/iu, + /(?:по\s+выбранному\s+объекту|for\s+selected\s+object)\s*:\s*[«"]([^»"\r\n]+)[»"]/iu + ]; + for (const pattern of patterns) { + const match = String(text ?? "").match(pattern); + const candidate = cleanupInventoryItemAnchorValue(String(match?.[1] ?? "")); + if (candidate) { + return candidate; + } + } + return undefined; +} + +function extractInventoryItemFromSelectedObject(text: string): string | undefined { + const selectedObject = extractSelectedObjectQuotedValue(text); + if (!selectedObject) { + return undefined; + } + const firstLine = selectedObject + .replace(/\r\n?/g, "\n") + .split("\n") + .map((line) => cleanupInventoryItemAnchorValue(line)) + .find(Boolean); + const withoutNumberPrefix = cleanupInventoryItemAnchorValue(String(firstLine ?? "").replace(/^\d+\.\s*/, "")); + const primarySegment = cleanupInventoryItemAnchorValue(withoutNumberPrefix.split("|")[0] ?? withoutNumberPrefix); + const candidate = cleanupInventoryItemAnchorValue(primarySegment); + if (!candidate || isLowQualityInventoryItemAnchorValue(candidate)) { + return undefined; + } + return candidate; +} + +function extractInventoryItemAnchor(text: string): string | undefined { + const selectedObjectItem = extractInventoryItemFromSelectedObject(text); + if (selectedObjectItem) { + return selectedObjectItem; + } + const patterns = [ + /(?:товар(?:а|у|ом|ы)?|номенклатур(?:а|у|ы)|позици(?:я|ю|и)|item|product|sku)\s*[«"']([^«»"'?\r\n]+)[»"'](?=$|[\s,.;:!?])/iu, + /(?:товар(?:а|у|ом|ы)?|номенклатур(?:а|у|ы)|позици(?:я|ю|и)|item|product|sku)\s+([^\r\n,.;:!?]+?)(?=\s+(?:на|по|у|от|из|для|и|когда|через|сейчас|еще|ещё|котор|которые|который|покупателю|поставщика|поставщику|за|в)\b|[:?]|$)/iu + ]; + for (const pattern of patterns) { + const match = String(text ?? "").match(pattern); + const candidate = trimInventoryItemArrowSuffix(trimInventoryItemChainTail(trimInventoryItemAnchorTail(String(match?.[1] ?? "")))); + if (!candidate || isLowQualityInventoryItemAnchorValue(candidate)) { + continue; + } + return candidate; + } + return undefined; +} + +function trimInventoryItemChainTail(rawValue: string): string { + return cleanupInventoryItemAnchorValue( + cleanupInventoryItemAnchorValue(rawValue) + .replace(/\s*(?:->|=>|→)\s*(?:покупател\w*|buyer\b).*$/iu, "") + .replace(/\s*(?:->|=>|→)\s*(?:поставщик\w*|supplier\b).*$/iu, "") + ); +} + +function trimInventoryItemArrowSuffix(rawValue: string): string { + return cleanupAnchorValue(cleanupAnchorValue(rawValue).replace(/\s*(?:->|=>|→).+$/u, "")); +} + +function isTemporalWarehousePhrase(candidate: string): boolean { + const normalized = cleanupAnchorValue(candidate) + .toLowerCase() + .replace(/ё/g, "е") + .trim(); + return /^(?:в|на)\s+(?:январ(?:е|ь)|феврал(?:е|ь)|март(?:е)?|апрел(?:е|ь)|ма(?:й|е)|июн(?:е|ь)|июл(?:е|ь)|август(?:е)?|сентябр(?:е|ь)|октябр(?:е|ь)|ноябр(?:е|ь)|декабр(?:е|ь))(?:\s+\d{4}(?:\s+г(?:\.|ода)?)?)?$/iu.test( + normalized + ); +} + +function extractInventoryWarehouseAnchor(text: string): string | undefined { + const patterns = [ + /(?:на|по)\s+склад(?:е|у|ом)?\s+[«"']?([^\r\n,.;:!?]+?)(?:[»"']|(?=\s+(?:на|по|за|с|в)\b|[?]|$))/iu, + /склад(?:е|у|ом)?\s+[«"']?([^\r\n,.;:!?]+?)(?:[»"']|(?=\s+(?:на|по|за|с|в)\b|[?]|$))/iu + ]; + for (const pattern of patterns) { + const match = String(text ?? "").match(pattern); + const candidate = cleanupAnchorValue( + cleanupAnchorValue(String(match?.[1] ?? "")).replace( + /\s+(?:организац\w*|компани\w*|котор(?:ый|ые|ых)|на\s+дату|по\s+состоянию\s+на\s+дату).*$/iu, + "" + ) + ); + const normalizedCandidate = candidate + .toLowerCase() + .replace(/ё/g, "е") + .trim(); + if ( + !candidate || + candidate.includes("->") || + candidate.includes("=>") || + normalizedCandidate.startsWith("по состоянию") || + isTemporalWarehousePhrase(candidate) || + /^(?:сейчас|на|дату|дате|остаток|остатки)$/iu.test(candidate) + ) { + continue; + } + return candidate; + } + return undefined; +} + +function extractInventorySupplierAnchor(text: string): string | undefined { + const match = String(text ?? "").match( + /(?:от\s+поставщика|у\s+поставщика|поставщика|поставщику)\s+([^\r\n?]+?)(?=$|[?])/iu + ); + if (!match?.[1]) { + return undefined; + } + const candidate = cleanupAnchorValue( + cleanupAnchorValue(String(match[1])).replace( + /\s+(?:сейчас|на\s+склад(?:е|у|ом)?|на\s+дату|по\s+состоянию\s+на\s+дату|котор(?:ый|ые|ых)|куплен(?:ы|а|о)?|были|был|лежат|лежит|еще|ещё|организац\w*|компани\w*).*$/iu, + "" + ) + ); + if ( + !candidate || + isLowQualityCounterpartyAnchorValue(candidate) || + /^(?:были|был|куплен|куплены|которые|который|которых|сейчас|лежат|лежит)\b/iu.test(candidate) + ) { + return undefined; + } + return candidate; +} + +function asksForInventorySupplierIdentity(text: string): boolean { + return /(?:^|[\s,.;:!?])(?:у|от)\s+какого\s+поставщика\b/iu.test(String(text ?? "")); +} + function extractAccountTokenHeuristic(text: string): string | undefined { const source = String(text ?? ""); const dotted = source.match(/(?:^|[^\d])(\d{2}[.,]\d{1,2})(?!\d)/u); @@ -932,6 +1173,14 @@ function requiredFiltersByIntent(intent: AddressIntent): Array { @@ -1222,4 +1510,3 @@ export function extractAddressFilters(userMessage: string, intent: AddressIntent warnings }; } - diff --git a/llm_normalizer/backend/src/services/addressIntentResolver.ts b/llm_normalizer/backend/src/services/addressIntentResolver.ts index dc08c74..a8a5e97 100644 --- a/llm_normalizer/backend/src/services/addressIntentResolver.ts +++ b/llm_normalizer/backend/src/services/addressIntentResolver.ts @@ -1542,16 +1542,32 @@ function hasAccountNumberAnchor(text: string): boolean { return /(?:account|сч[её]т|счет)\D{0,12}\d{2}(?:[.,]\d{1,2})?/i.test(text); } +function hasInventoryAccount41Anchor(text: string): boolean { + return /(?:сч[её]т(?:а|е|у)?|счет(?:а|е|у)?)\D{0,12}41(?:[.,]0?1)?/iu.test(text) || /41(?:[.,]0?1)?\D{0,12}(?:сч[её]т(?:а|е|у)?|счет(?:а|е|у)?)/iu.test(text); +} + +function hasInventoryAsOfCue(text: string): boolean { + return /(?:сейчас|текущ|на\s+дату|по\s+состоянию|срез|на\s+конец|date|as\s+of|current|now|today)/iu.test( + text + ); +} + function hasInventoryOnHandSignal(text: string): boolean { + const hasColloquialStockSnapshotCue = /(?:что|ч[её])\s+(?:у\s+нас\s+)?на\s+склад(?:е|у|ом)(?=$|[\s,.;:!?])/iu.test( + text + ); + const hasAccount41Anchor = hasInventoryAccount41Anchor(text); const hasStockLexeme = /(?:склад(?:е|у|ом|ы|ов)?|warehouse|stock(?:room)?|inventory|on[\s-]?hand)/iu.test(text); - if (!hasStockLexeme) { + if (!hasStockLexeme && !hasAccount41Anchor) { return false; } if ( hasInventoryProvenanceSignalV2(text) || hasInventoryPurchaseDocumentsSignalV2(text) || - hasInventorySaleTraceSignalV2(text) + hasInventorySaleTraceSignalV2(text) || + hasInventoryAgingSignal(text) || + hasInventoryPurchaseToSaleChainSignal(text) ) { return false; } @@ -1562,7 +1578,11 @@ function hasInventoryOnHandSignal(text: string): boolean { text ); const hasRequestCue = /(?:покажи|показать|выведи|дай|какие|что|какой|сколько|show|list|which|what)/iu.test(text); - return (hasGoodsLexeme || hasBalanceLexeme) && (hasRequestCue || hasBalanceLexeme); + if (hasAccount41Anchor && (hasGoodsLexeme || hasBalanceLexeme || hasRequestCue || hasInventoryAsOfCue(text))) { + return true; + } + return (hasGoodsLexeme || hasBalanceLexeme || hasColloquialStockSnapshotCue) && + (hasRequestCue || hasBalanceLexeme || hasColloquialStockSnapshotCue); } function hasInventoryProvenanceSignal(text: string): boolean { @@ -1590,6 +1610,12 @@ function hasInventoryProvenanceSignalV2(text: string): boolean { return hasItemCue && hasSupplierCue && hasPurchaseCue; } +function hasInventoryPurchaseDateSignal(text: string): boolean { + const hasItemCue = /(?:товар|номенклатур|sku|item|product)/iu.test(text); + const hasPurchaseDateCue = /(?:когда\s+был\s+куплен|когда\s+куплен|дата\s+закупк|purchase\s+date)/iu.test(text); + return hasItemCue && hasPurchaseDateCue; +} + function hasInventoryPurchaseDocumentsSignalV2(text: string): boolean { const hasItemCue = /(?:товар|номенклатур|sku|item|product)/iu.test(text); const hasPurchaseDocCue = /(?:по\s+каким\s+документам\s+был\s+куплен|по\s+каким\s+документам\s+куплен|какими\s+документами\s+был\s+куплен|документ(?:ам|ы)\s+закупк|purchase\s+documents|documents\s+of\s+purchase|through\s+which\s+documents)/iu.test( @@ -1607,25 +1633,48 @@ function hasInventorySaleTraceSignalV2(text: string): boolean { } function hasInventorySupplierStockOverlapSignal(text: string): boolean { + const hasDirectSingleItemSupplierQuestion = + /(?:от\s+какого\s+поставщика\s+куплен\s+(?:товар|номенклатур(?:а|у|ы)|позици(?:я|ю|и))|от\s+кого\s+куплен\s+(?:товар|номенклатур(?:а|у|ы)|позици(?:я|ю|и)))/iu.test( + text + ); + if (hasDirectSingleItemSupplierQuestion) { + return false; + } const hasSupplierCue = /(?:поставщик|supplier|vendor|от\s+поставщика|у\s+поставщика)/iu.test(text); - const hasStockCue = /(?:товар|номенклатур|склад|остат(?:ок|ки)|лежат|на\s+дату|по\s+состоянию\s+на\s+дату|current\s+stock|stock\s+overlap|что\s+сейчас\s+лежит)/iu.test( + const hasStockCue = /(?:склад|остат(?:ок|ке|ков)|лежат|лежит|сейчас\s+еще|сейчас\s+ещ[её]|на\s+дату|по\s+состоянию\s+на\s+дату|current\s+stock|stock\s+overlap|что\s+сейчас\s+лежит)/iu.test( text ); return hasSupplierCue && hasStockCue; } function hasInventoryAgingSignal(text: string): boolean { - return /(?:стар(?:ые|ым|ых)\s+закупк|закупал(?:ись|ся)\s+очень\s+давно|очень\s+давно|давно\s+куплен|когда\s+куплен|возраст\s+остатк|aged?\s+stock|old\s+purchase|aging\s+by\s+purchase\s+date|very\s+old\s+stock)/iu.test( - text - ); + const hasResidueCue = + /(?:остат(?:ок|ки)|в\s+остатке|среди\s+текущих\s+остатков|на\s+складе|stock\s+residue|stock\s+balance)/iu.test(text); + const hasAgingCue = + /(?:стар(?:ые|ым|ых)\s+закупк|стары(?:м|х)\s+закупк(?:ам|и|ах)|относит(?:ся|ся\s+ли)?\s+.*\s+к\s+старым\s+закупк|закупал(?:ись|ся)\s+очень\s+давно|очень\s+давно|давно\s+куплен|давно\s+приобретен|куплен\s+задолго\s+до(?:\s+даты)?|закуплен(?:ы|а)?\s+давно|приобретен\s+давно|задолго\s+до(?:\s+даты)?|возраст\s+остатк|возраст\s+закупк|aged?\s+stock|old\s+purchase|old\s+purchases|old\s+stock|bought\s+long\s+ago|purchased\s+long\s+ago|aging\s+by\s+purchase\s+date|very\s+old\s+stock|very\s+old\s+purchase|old\s+procurement|older\s+purchases|aged\s+items|old\s+goods)/iu.test( + text + ); + return hasAgingCue || (hasResidueCue && /(?:давно\s+куплен|давно\s+приобретен|задолго\s+до)/iu.test(text)); } function hasInventoryPurchaseToSaleChainSignal(text: string): boolean { - const hasSupplierCue = /(?:поставщик|supplier|vendor|от\s+кого\s+куплен)/iu.test(text); - const hasBuyerCue = /(?:покупател|buyer|customer|client|кому\s+был\s+продан)/iu.test(text); const hasItemCue = /(?:товар|номенклатур|sku|item|product)/iu.test(text); - const hasPurchaseSaleCue = /(?:куплен(?:ы)?|закупк|позже\s+продан(?:ы)?|продан(?:ы)?|purchase|sale|цепочк[аи]\s+движен)/iu.test(text); - return (hasSupplierCue && hasBuyerCue && hasItemCue && hasPurchaseSaleCue) || /(?:purchase[\s-]?to[\s-]?sale\s+chain|закупка\s*->\s*склад\s*->\s*продажа)/iu.test(text); + const hasChainCue = + /(?:закупк.*склад.*продаж|purchase[\s-]?to[\s-]?sale|purchase\s*->\s*(?:warehouse|stock)\s*->\s*sale|закупка\s*->\s*склад\s*->\s*продажа|цепочк[аи]\s+движен|документально\s+подтвержденн\w+\s+цепочк|supplier\s*->\s*item\s*->\s*(?:buyer|customer)|supplier\s+to\s+buyer|supplier\s+to\s+item\s+to\s+buyer)/iu.test( + text + ) || text.includes("->"); + return hasItemCue && hasChainCue; +} + +function hasInventorySupplierToBuyerChainSignal(text: string): boolean { + const hasSupplierCue = /(?:поставщик|supplier|vendor)/iu.test(text); + const hasBuyerCue = /(?:покупател|buyer|customer|client)/iu.test(text); + const hasItemCue = /(?:товар|номенклатур|sku|item|product)/iu.test(text); + const hasChainCue = + /(?:документально\s+подтвержденн\w+\s+цепочк|supplier\s*->\s*item\s*->\s*buyer|supplier\s*->\s*item\s*->\s*customer|supplier\s*->\s*buyer|supplier\s+to\s+buyer|supplier\s+to\s+buyer\s+chain|supplier\s+to\s+item\s+to\s+buyer|поставщик\s*->\s*товар\s*->\s*покупател|поставщик\s*->\s*товар\s*->\s*клиент|поставщик\s*->\s*товар\s*->\s*покупатель|поставщик\s+к\s+покупател|поставщик\s+к\s+клиент|поставщик\s+к\s+товару\s+и\s+покупателю)/iu.test( + text + ) || text.includes("->"); + return hasSupplierCue && hasBuyerCue && hasItemCue && hasChainCue; } export function resolveAddressIntent(userMessage: string): AddressIntentResolution { @@ -1745,27 +1794,35 @@ export function resolveAddressIntent(userMessage: string): AddressIntentResoluti }; } - if (hasInventoryProvenanceSignalV2(text)) { + if ( + /(?:старым\s+закупк(?:ам|и|ах)|относится\s+ли\s+.*\s+к\s+старым\s+закупк(?:ам|и|ах)|очень\s+давно|давно\s+куплен|давно\s+приобретен|old\s+stock|old\s+purchase|aging\s+by\s+purchase\s+date)/iu.test( + text + ) + ) { return { - intent: "inventory_purchase_provenance_for_item", - confidence: "medium", - reasons: ["inventory_provenance_signal_detected"] + intent: "inventory_aging_by_purchase_date", + confidence: "high", + reasons: ["inventory_aging_signal_detected_strong"] }; } - if (hasInventoryPurchaseDocumentsSignalV2(text)) { + if (hasInventoryAccount41Anchor(text) && hasInventoryAsOfCue(text)) { return { - intent: "inventory_purchase_documents_for_item", - confidence: "medium", - reasons: ["inventory_purchase_documents_signal_detected"] + intent: "inventory_on_hand_as_of_date", + confidence: "high", + reasons: ["inventory_account_41_as_of_date_signal_detected"] }; } - if (hasInventoryPurchaseToSaleChainSignal(text)) { + if ( + /(?:без\s+понятн(?:ой|ого)\s+привязк(?:и|а)\s+к\s+поставщик|без\s+привязк(?:и|а)\s+к\s+поставщик|unresolved\s+supplier\s+link)/iu.test( + text + ) + ) { return { - intent: "inventory_purchase_to_sale_chain", + intent: "inventory_supplier_stock_overlap_as_of_date", confidence: "medium", - reasons: ["inventory_purchase_to_sale_chain_signal_detected"] + reasons: ["inventory_unresolved_provenance_signal_detected"] }; } @@ -1777,6 +1834,29 @@ export function resolveAddressIntent(userMessage: string): AddressIntentResoluti }; } + if ( + /(?:supplier\s*->\s*buyer|supplier\s+to\s+buyer|supplier\s+to\s+buyer\s+chain|поставщик\s+к\s+покупателю|поставщик\s*->\s*товар\s*->\s*покупател|документально\s+подтвержденн\w+\s+цепочк)/iu.test( + text + ) && + /(?:поставщик|supplier|vendor)/iu.test(text) && + /(?:покупател|buyer|customer|client)/iu.test(text) && + /(?:товар|номенклатур|sku|item|product)/iu.test(text) + ) { + return { + intent: "inventory_purchase_to_sale_chain", + confidence: "high", + reasons: ["inventory_supplier_to_buyer_chain_signal_detected_strong"] + }; + } + + if (hasInventoryPurchaseToSaleChainSignal(text)) { + return { + intent: "inventory_purchase_to_sale_chain", + confidence: "medium", + reasons: ["inventory_purchase_to_sale_chain_signal_detected"] + }; + } + if (hasInventoryAgingSignal(text)) { return { intent: "inventory_aging_by_purchase_date", @@ -1785,6 +1865,30 @@ export function resolveAddressIntent(userMessage: string): AddressIntentResoluti }; } + if (hasInventoryProvenanceSignalV2(text)) { + return { + intent: "inventory_purchase_provenance_for_item", + confidence: "medium", + reasons: ["inventory_provenance_signal_detected"] + }; + } + + if (hasInventoryPurchaseDateSignal(text)) { + return { + intent: "inventory_purchase_provenance_for_item", + confidence: "medium", + reasons: ["inventory_purchase_date_signal_detected"] + }; + } + + if (hasInventoryPurchaseDocumentsSignalV2(text)) { + return { + intent: "inventory_purchase_documents_for_item", + confidence: "medium", + reasons: ["inventory_purchase_documents_signal_detected"] + }; + } + if (hasInventorySaleTraceSignalV2(text)) { return { intent: "inventory_sale_trace_for_item", @@ -1793,6 +1897,14 @@ export function resolveAddressIntent(userMessage: string): AddressIntentResoluti }; } + if (hasInventorySupplierToBuyerChainSignal(text)) { + return { + intent: "inventory_purchase_to_sale_chain", + confidence: "medium", + reasons: ["inventory_supplier_to_buyer_chain_signal_detected"] + }; + } + if (hasInventoryOnHandSignal(text)) { return { intent: "inventory_on_hand_as_of_date", diff --git a/llm_normalizer/backend/src/services/addressQueryService.ts b/llm_normalizer/backend/src/services/addressQueryService.ts index bfc8e27..fb69fd0 100644 --- a/llm_normalizer/backend/src/services/addressQueryService.ts +++ b/llm_normalizer/backend/src/services/addressQueryService.ts @@ -1284,6 +1284,24 @@ function applyAddressFilters(rows: NormalizedAddressRow[], filters: AddressFilte } } + if (filters.item && String(filters.item).trim()) { + const needle = String(filters.item); + const before = filtered.length; + filtered = filtered.filter((row) => matchesAnchorText(rowSearchableText(row), needle)); + if (before > 0 && filtered.length === 0 && mismatchReason === null) { + mismatchReason = "item_anchor_not_matched_in_materialized_rows"; + } + } + + if (filters.warehouse && String(filters.warehouse).trim()) { + const needle = String(filters.warehouse); + const before = filtered.length; + filtered = filtered.filter((row) => matchesAnchorText(rowSearchableText(row), needle)); + if (before > 0 && filtered.length === 0 && mismatchReason === null) { + mismatchReason = "warehouse_anchor_not_matched_in_materialized_rows"; + } + } + if (filters.document_ref && String(filters.document_ref).trim()) { const needle = String(filters.document_ref); const before = filtered.length; @@ -1367,6 +1385,10 @@ function isConfirmedBalanceIntent(intent: AddressIntent): boolean { intent === "account_balance_snapshot" || intent === "documents_forming_balance" || intent === "inventory_on_hand_as_of_date" || + intent === "inventory_purchase_provenance_for_item" || + intent === "inventory_purchase_documents_for_item" || + intent === "inventory_sale_trace_for_item" || + intent === "inventory_purchase_to_sale_chain" || intent === "open_contracts_confirmed_as_of_date" || intent === "payables_confirmed_as_of_date" || intent === "receivables_confirmed_as_of_date" || @@ -1779,7 +1801,24 @@ function canAutoBroadenPeriodWindow(intent: AddressIntent, filters: AddressFilte intent === "list_documents_by_counterparty" || intent === "bank_operations_by_counterparty" || intent === "list_documents_by_contract" || - intent === "bank_operations_by_contract" + intent === "bank_operations_by_contract" || + intent === "inventory_purchase_provenance_for_item" || + intent === "inventory_purchase_documents_for_item" || + intent === "inventory_supplier_stock_overlap_as_of_date" || + intent === "inventory_sale_trace_for_item" || + intent === "inventory_purchase_to_sale_chain" || + intent === "inventory_aging_by_purchase_date" + ); +} + +function shouldBoostAutoBroadenedLimit(intent: AddressIntent): boolean { + return ( + intent === "inventory_purchase_provenance_for_item" || + intent === "inventory_purchase_documents_for_item" || + intent === "inventory_supplier_stock_overlap_as_of_date" || + intent === "inventory_sale_trace_for_item" || + intent === "inventory_purchase_to_sale_chain" || + intent === "inventory_aging_by_purchase_date" ); } @@ -2133,6 +2172,12 @@ function normalizeMissingAnchorLabel(anchor: string): string { if (anchor === "organization") { return "организация"; } + if (anchor === "item") { + return "товар"; + } + if (anchor === "warehouse") { + return "склад"; + } if (anchor === "period" || anchor === "period_from" || anchor === "period_to" || anchor === "as_of_date") { return "период/дата"; } @@ -2220,6 +2265,14 @@ function buildLimitedOffers(input: { offers.push("показать подтвержденный реестр открытой дебиторской задолженности на дату среза по 62/76"); } else if (input.intent === "inventory_on_hand_as_of_date") { offers.push("показать подтвержденный срез товаров на складах на дату по остатку счета 41.01"); + } else if (input.intent === "inventory_purchase_provenance_for_item") { + offers.push("показать подтвержденные закупочные движения по товару на 41.01 с датами и документами"); + } else if (input.intent === "inventory_purchase_documents_for_item") { + offers.push("показать документы поступления по товару на 41.01"); + } else if (input.intent === "inventory_sale_trace_for_item") { + offers.push("показать подтвержденные движения выбытия товара со счета 41.01"); + } else if (input.intent === "inventory_purchase_to_sale_chain") { + offers.push("показать документальную цепочку по товару: поступление на 41.01 и последующее выбытие"); } else if (input.intent === "open_contracts_confirmed_as_of_date") { offers.push("показать подтвержденный реестр договоров с открытыми взаиморасчетами на дату по 60/62/76"); } else if (input.intent === "vat_payable_confirmed_as_of_date") { @@ -3352,6 +3405,14 @@ export class AddressQueryService { const autoBroadenedFilters: AddressFilterSet = { ...filters.extracted_filters }; delete autoBroadenedFilters.period_from; delete autoBroadenedFilters.period_to; + if (shouldBoostAutoBroadenedLimit(intent.intent)) { + autoBroadenedFilters.limit = Math.max( + ADDRESS_ANCHOR_RECOVERY_LIMIT, + typeof autoBroadenedFilters.limit === "number" && Number.isFinite(autoBroadenedFilters.limit) + ? Math.max(1, Math.trunc(autoBroadenedFilters.limit)) + : 0 + ); + } const broadenedSelection = selectAddressRecipe(intent.intent, autoBroadenedFilters); if (broadenedSelection.selected_recipe && broadenedSelection.missing_required_filters.length === 0) { const broadenedPlan = buildAddressRecipePlan(broadenedSelection.selected_recipe, autoBroadenedFilters); diff --git a/llm_normalizer/backend/src/services/addressRecipeCatalog.ts b/llm_normalizer/backend/src/services/addressRecipeCatalog.ts index c9bb696..a1a0865 100644 --- a/llm_normalizer/backend/src/services/addressRecipeCatalog.ts +++ b/llm_normalizer/backend/src/services/addressRecipeCatalog.ts @@ -20,7 +20,27 @@ const MOVEMENTS_QUERY_TEMPLATE = ` ПРЕДСТАВЛЕНИЕ(Движения.СубконтоКт2) КАК СубконтоКт2, ПРЕДСТАВЛЕНИЕ(Движения.СубконтоКт3) КАК СубконтоКт3 ИЗ - РегистрБухгалтерии.Хозрасчетный КАК Движения + РегистрБухгалтерии.Хозрасчетный.ДвиженияССубконто КАК Движения +__WHERE_CLAUSE__ +УПОРЯДОЧИТЬ ПО + Движения.Период __ORDER_DIRECTION__ +`; + +const INVENTORY_MOVEMENTS_QUERY_TEMPLATE = ` +ВЫБРАТЬ ПЕРВЫЕ __LIMIT__ + Движения.Период КАК Период, + ПРЕДСТАВЛЕНИЕ(Движения.Регистратор) КАК Регистратор, + ПРЕДСТАВЛЕНИЕ(Движения.СчетДт) КАК СчетДт, + ПРЕДСТАВЛЕНИЕ(Движения.СчетКт) КАК СчетКт, + Движения.Сумма КАК Сумма, + ПРЕДСТАВЛЕНИЕ(Движения.СубконтоДт1) КАК СубконтоДт1, + ПРЕДСТАВЛЕНИЕ(Движения.СубконтоДт2) КАК СубконтоДт2, + ПРЕДСТАВЛЕНИЕ(Движения.СубконтоДт3) КАК СубконтоДт3, + ПРЕДСТАВЛЕНИЕ(Движения.СубконтоКт1) КАК СубконтоКт1, + ПРЕДСТАВЛЕНИЕ(Движения.СубконтоКт2) КАК СубконтоКт2, + ПРЕДСТАВЛЕНИЕ(Движения.СубконтоКт3) КАК СубконтоКт3 +ИЗ + РегистрБухгалтерии.Хозрасчетный.ДвиженияССубконто КАК Движения __WHERE_CLAUSE__ УПОРЯДОЧИТЬ ПО Движения.Период __ORDER_DIRECTION__ @@ -707,6 +727,72 @@ const BASE_RECIPES: AddressRecipeDefinition[] = [ account_scope_mode: "strict", query_template: "inventory_on_hand_as_of_balance_profile" }, + { + recipe_id: "address_inventory_purchase_provenance_for_item_v1", + intent: "inventory_purchase_provenance_for_item", + purpose: "Trace purchase-side 41.01 movements for one inventory item and summarize supplier/date provenance evidence", + required_filters: ["item"], + optional_filters: ["as_of_date", "period_from", "period_to", "organization", "warehouse", "limit", "sort"], + default_limit: 400, + account_scope: ["41.01"], + account_scope_mode: "strict", + query_template: "inventory_purchase_provenance_profile" + }, + { + recipe_id: "address_inventory_purchase_documents_for_item_v1", + intent: "inventory_purchase_documents_for_item", + purpose: "Trace purchase-side 41.01 movements for one inventory item and list source purchase documents", + required_filters: ["item"], + optional_filters: ["as_of_date", "period_from", "period_to", "organization", "warehouse", "limit", "sort"], + default_limit: 400, + account_scope: ["41.01"], + account_scope_mode: "strict", + query_template: "inventory_purchase_documents_profile" + }, + { + recipe_id: "address_inventory_supplier_stock_overlap_as_of_date_v1", + intent: "inventory_supplier_stock_overlap_as_of_date", + purpose: "Trace purchase-side 41.01 movements and summarize supplier overlap with current or dated stock slice", + required_filters: [], + optional_filters: ["as_of_date", "period_from", "period_to", "organization", "warehouse", "counterparty", "limit", "sort"], + default_limit: 500, + account_scope: ["41.01"], + account_scope_mode: "strict", + query_template: "inventory_supplier_stock_overlap_profile" + }, + { + recipe_id: "address_inventory_sale_trace_for_item_v1", + intent: "inventory_sale_trace_for_item", + purpose: "Trace sale-side 41.01 movements for one inventory item and summarize sale evidence", + required_filters: ["item"], + optional_filters: ["as_of_date", "period_from", "period_to", "organization", "warehouse", "limit", "sort"], + default_limit: 400, + account_scope: ["41.01"], + account_scope_mode: "strict", + query_template: "inventory_sale_trace_profile" + }, + { + recipe_id: "address_inventory_purchase_to_sale_chain_v1", + intent: "inventory_purchase_to_sale_chain", + purpose: "Trace both purchase and sale side 41.01 movements for one inventory item and summarize the document chain", + required_filters: ["item"], + optional_filters: ["as_of_date", "period_from", "period_to", "organization", "warehouse", "limit", "sort"], + default_limit: 600, + account_scope: ["41.01"], + account_scope_mode: "strict", + query_template: "inventory_purchase_to_sale_chain_profile" + }, + { + recipe_id: "address_inventory_aging_by_purchase_date_v1", + intent: "inventory_aging_by_purchase_date", + purpose: "Trace purchase-side 41.01 movements and summarize age of stock residue by purchase dates", + required_filters: [], + optional_filters: ["item", "as_of_date", "period_from", "period_to", "organization", "warehouse", "limit", "sort"], + default_limit: 500, + account_scope: ["41.01"], + account_scope_mode: "strict", + query_template: "inventory_aging_by_purchase_date_profile" + }, { recipe_id: "address_open_contracts_confirmed_as_of_date_v1", intent: "open_contracts_confirmed_as_of_date", @@ -1039,6 +1125,28 @@ function buildAccountPrefixPredicate(fieldPath: string, prefixes: string[]): str return clauses.length === 1 ? clauses[0] : `(${clauses.join(" ИЛИ ")})`; } +function buildInventoryMovementQuery( + filters: AddressFilterSet, + resolvedLimit: number, + side: "dt" | "kt" | "either" +): string { + const debitPredicate = buildAccountPrefixPredicate("Движения.СчетДт", ["41.01"]); + const creditPredicate = buildAccountPrefixPredicate("Движения.СчетКт", ["41.01"]); + const inventoryCondition = + side === "dt" + ? debitPredicate + : side === "kt" + ? creditPredicate + : `(${debitPredicate} ИЛИ ${creditPredicate})`; + return INVENTORY_MOVEMENTS_QUERY_TEMPLATE + .replace("__LIMIT__", String(resolvedLimit)) + .replace( + "__WHERE_CLAUSE__", + buildWhereClause(filters, "Движения.Период", [inventoryCondition]) + ) + .replaceAll("__ORDER_DIRECTION__", resolveOrderDirection(filters.sort)); +} + function shouldBoostLimitForAllTimeCounterparty(filters: AddressFilterSet): boolean { const hasAnchor = (typeof filters.counterparty === "string" && filters.counterparty.trim().length > 0) || @@ -1067,6 +1175,12 @@ function maxLimitForIntent(intent: AddressIntent): number { intent === "vat_payable_forecast" || intent === "vat_liability_confirmed_for_tax_period" || intent === "inventory_on_hand_as_of_date" || + intent === "inventory_purchase_provenance_for_item" || + intent === "inventory_purchase_documents_for_item" || + intent === "inventory_supplier_stock_overlap_as_of_date" || + intent === "inventory_sale_trace_for_item" || + intent === "inventory_purchase_to_sale_chain" || + intent === "inventory_aging_by_purchase_date" || intent === "open_contracts_confirmed_as_of_date" || intent === "list_contracts_by_counterparty" || intent === "list_documents_by_counterparty" || @@ -1259,6 +1373,18 @@ export function buildAddressRecipePlan( .replaceAll("__INVENTORY_ACCOUNTS_MATCH__", buildAccountPrefixPredicate("Остатки.Счет", ["41.01"])) .replaceAll("__ORDER_DIRECTION__", resolveOrderDirection(filters.sort)); })() + : recipe.query_template === "inventory_purchase_provenance_profile" + ? buildInventoryMovementQuery(filters, resolvedLimit, "dt") + : recipe.query_template === "inventory_purchase_documents_profile" + ? buildInventoryMovementQuery(filters, resolvedLimit, "dt") + : recipe.query_template === "inventory_supplier_stock_overlap_profile" + ? buildInventoryMovementQuery(filters, resolvedLimit, "dt") + : recipe.query_template === "inventory_sale_trace_profile" + ? buildInventoryMovementQuery(filters, resolvedLimit, "kt") + : recipe.query_template === "inventory_purchase_to_sale_chain_profile" + ? buildInventoryMovementQuery(filters, resolvedLimit, "either") + : recipe.query_template === "inventory_aging_by_purchase_date_profile" + ? buildInventoryMovementQuery(filters, resolvedLimit, "dt") : recipe.query_template === "contracts_by_counterparty_profile" ? CONTRACTS_BY_COUNTERPARTY_QUERY_TEMPLATE.replaceAll("__LIMIT__", String(resolvedLimit)) : recipe.query_template === "open_contracts_confirmed_as_of_balance_profile" diff --git a/llm_normalizer/backend/src/services/address_runtime/composeStage.ts b/llm_normalizer/backend/src/services/address_runtime/composeStage.ts index fce5883..24d7e8c 100644 --- a/llm_normalizer/backend/src/services/address_runtime/composeStage.ts +++ b/llm_normalizer/backend/src/services/address_runtime/composeStage.ts @@ -910,6 +910,165 @@ function buildInventoryOnHandAggregate(rows: ComposeStageRow[], asOfDate: string }); } +function inventoryTraceDateLabel(value: string | null): string { + return value ? formatDateRu(value) : "дата не указана"; +} + +function hasInventoryAccountPrefix(value: string | null | undefined, prefix: string): boolean { + const normalized = String(value ?? "") + .trim() + .replace(",", "."); + return normalized === prefix || normalized.startsWith(`${prefix}.`) || normalized.startsWith(prefix); +} + +function isInventoryPurchaseMovement(row: ComposeStageRow): boolean { + return hasInventoryAccountPrefix(row.account_dt, "41.01"); +} + +function isInventorySaleMovement(row: ComposeStageRow): boolean { + return hasInventoryAccountPrefix(row.account_kt, "41.01"); +} + +function looksLikeInventoryTraceDocumentToken(value: string): boolean { + const normalized = String(value ?? "").trim(); + if (!normalized) { + return false; + } + return ( + /(?:№|contract|invoice|payment|order|накладн|акт|счет|сч[её]т|поступлен|реализац|договор)/iu.test(normalized) || + /(?:[a-zа-яё].*\d|\d.*[a-zа-яё])/iu.test(normalized) + ); +} + +function looksLikeInventoryPartyToken(value: string): boolean { + const normalized = String(value ?? "").trim(); + if (!normalized || normalized.length < 3) { + return false; + } + if (/^(?:0|<пусто>|пустая ссылка)$/iu.test(normalized)) { + return false; + } + if (/^\d{4}-\d{2}-\d{2}/.test(normalized)) { + return false; + } + if (/(?:склад|warehouse)/iu.test(normalized)) { + return false; + } + if (looksLikeInventoryTraceDocumentToken(normalized)) { + return false; + } + if ( + /(?:ооо|ао|пао|зао|ип|llc|ltd|inc|corp|компани|организац|департамент|комитет|министерств|служб|управлен|торговый\s+дом)/iu.test( + normalized + ) + ) { + return true; + } + const letterChars = (normalized.match(/[A-Za-zА-Яа-яЁё]/g) ?? []).length; + if (letterChars < 3) { + return false; + } + const words = normalized.split(/\s+/u).filter(Boolean); + if (words.length >= 2) { + return true; + } + return normalized === normalized.toUpperCase() && normalized.length >= 4; +} + +function extractInventoryCounterpartyCandidates(row: ComposeStageRow): string[] { + const itemToken = normalizeEntityToken(extractInventoryItemName(row)); + const warehouseToken = normalizeEntityToken(extractInventoryWarehouseName(row)); + const organizationToken = normalizeEntityToken(extractInventoryOrganizationName(row)); + const candidates: string[] = []; + for (const token of row.analytics) { + const normalized = String(token ?? "").trim(); + if (!normalized || !looksLikeInventoryPartyToken(normalized)) { + continue; + } + const comparable = normalizeEntityToken(normalized); + if (!comparable || comparable === itemToken || comparable === warehouseToken || comparable === organizationToken) { + continue; + } + candidates.push(normalized); + } + return uniqueStrings(candidates); +} + +interface InventoryTraceSummary { + item: string | null; + warehouses: string[]; + organizations: string[]; + counterparties: string[]; + documents: string[]; + firstPeriod: string | null; + lastPeriod: string | null; + totalAmount: number; +} + +function summarizeInventoryTraceRows(rows: ComposeStageRow[]): InventoryTraceSummary { + const items = uniqueStrings( + rows + .map((row) => extractInventoryItemName(row)) + .filter((item): item is string => Boolean(item)) + ); + const warehouses = uniqueStrings( + rows + .map((row) => extractInventoryWarehouseName(row)) + .filter((item): item is string => Boolean(item)) + ); + const organizations = uniqueStrings( + rows + .map((row) => extractInventoryOrganizationName(row)) + .filter((item): item is string => Boolean(item)) + ); + const counterparties = uniqueStrings(rows.flatMap((row) => extractInventoryCounterpartyCandidates(row))); + const documents = uniqueStrings( + rows + .map((row) => String(row.registrator ?? "").trim()) + .filter((item) => item.length > 0 && item !== "(без названия)") + ); + const periods = rows + .map((row) => String(row.period ?? "").trim()) + .filter((item) => item.length > 0) + .sort((left, right) => left.localeCompare(right, "ru")); + const totalAmount = rows.reduce((sum, row) => sum + (typeof row.amount === "number" && Number.isFinite(row.amount) ? row.amount : 0), 0); + return { + item: items[0] ?? null, + warehouses, + organizations, + counterparties, + documents, + firstPeriod: periods[0] ?? null, + lastPeriod: periods.length > 0 ? periods[periods.length - 1] : null, + totalAmount + }; +} + +function formatInventoryTraceRows(rows: ComposeStageRow[], limit = 10): string[] { + return rows.slice(0, limit).map((row, index) => { + const parties = extractInventoryCounterpartyCandidates(row); + const warehouse = extractInventoryWarehouseName(row); + const organization = extractInventoryOrganizationName(row); + const amount = + typeof row.amount === "number" && Number.isFinite(row.amount) ? formatMoneyRub(row.amount) : "сумма не указана"; + const parts = [ + `${index + 1}. ${row.registrator}`, + `дата: ${inventoryTraceDateLabel(row.period)}`, + `сумма: ${amount}` + ]; + if (warehouse) { + parts.push(`склад: ${warehouse}`); + } + if (organization) { + parts.push(`организация: ${organization}`); + } + if (parties.length > 0) { + parts.push(`контрагент: ${parties[0]}`); + } + return parts.join(" | "); + }); +} + interface CounterpartyRiskAggregate { name: string; totalAmount: number; @@ -3719,6 +3878,265 @@ export function composeFactualReply( }; } + if (intent === "inventory_purchase_documents_for_item") { + const asOfDate = resolvePayablesAsOfDate(options); + const purchaseRows = rows.filter((row) => isInventoryPurchaseMovement(row)); + const summary = summarizeInventoryTraceRows(purchaseRows); + const itemLabel = summary.item ?? "товар не определен"; + const lines: string[] = [ + `Собран подтвержденный список документов поступления по товару ${itemLabel} до ${formatDateRu(asOfDate)}.`, + "", + "Блок 1. Статус результата", + "- Результат: подтвержденные движения поступления товара на 41.01 по доступным бухгалтерским проводкам.", + "", + "Блок 2. Что учтено", + `- Дата верхней границы: ${formatDateRu(asOfDate)}.`, + "- Контур: движения, где товар поступает на счет 41.01.", + `- Документов в выборке: ${formatNumberWithDots(summary.documents.length)}.`, + `- Операций в выборке: ${formatNumberWithDots(purchaseRows.length)}.` + ]; + if (summary.counterparties.length > 0) { + lines.push(`- Найденные контрагенты в закупочных движениях: ${summary.counterparties.slice(0, 3).join("; ")}.`); + } + lines.push("", "Блок 3. Документы"); + if (purchaseRows.length > 0) { + lines.push(...formatInventoryTraceRows(purchaseRows, 12)); + } else { + lines.push("- По выбранному товару не найдено проводок поступления на 41.01 в доступном контуре."); + } + return { + responseType: purchaseRows.length > 0 ? "FACTUAL_LIST" : "FACTUAL_SUMMARY", + text: joinLines(lines), + semantics: { + result_mode: "confirmed_balance", + evidence_strength: purchaseRows.length > 0 ? "strong" : "medium", + balance_confirmed: purchaseRows.length > 0 + } + }; + } + + if (intent === "inventory_purchase_provenance_for_item") { + const asOfDate = resolvePayablesAsOfDate(options); + const purchaseRows = rows.filter((row) => isInventoryPurchaseMovement(row)); + const summary = summarizeInventoryTraceRows(purchaseRows); + const itemLabel = summary.item ?? "товар не определен"; + const lines: string[] = [ + `Собран подтвержденный закупочный след по товару ${itemLabel} до ${formatDateRu(asOfDate)}.`, + "", + "Блок 1. Статус результата", + "- Результат: показаны подтвержденные закупочные движения на 41.01 по выбранному товару.", + "- Важно: без партионности этот контур не подменяет собой лот-level доказательство происхождения текущего остатка.", + "", + "Блок 2. Сводка", + `- Первая найденная дата закупочного движения: ${inventoryTraceDateLabel(summary.firstPeriod)}.`, + `- Последняя найденная дата закупочного движения: ${inventoryTraceDateLabel(summary.lastPeriod)}.`, + `- Документов поступления: ${formatNumberWithDots(summary.documents.length)}.`, + `- Операций поступления: ${formatNumberWithDots(purchaseRows.length)}.` + ]; + if (summary.counterparties.length === 1) { + lines.push(`- По доступным закупочным движениям товар связан с поставщиком: ${summary.counterparties[0]}.`); + } else if (summary.counterparties.length > 1) { + lines.push(`- По доступным закупочным движениям найдено несколько поставщиков: ${summary.counterparties.slice(0, 4).join("; ")}.`); + } else if (purchaseRows.length > 0) { + lines.push("- Закупочные документы найдены, но поставщик не материализован отдельным полем в текущем exact-контуре."); + } + if (summary.documents.length > 0) { + lines.push("", "Блок 3. Опорные документы", ...formatInventoryTraceRows(purchaseRows, 8)); + } + return { + responseType: purchaseRows.length > 0 ? "FACTUAL_SUMMARY" : "FACTUAL_SUMMARY", + text: joinLines(lines), + semantics: { + result_mode: "confirmed_balance", + evidence_strength: + purchaseRows.length > 0 ? (summary.counterparties.length === 1 ? "strong" : "medium") : "medium", + balance_confirmed: purchaseRows.length > 0 + } + }; + } + + if (intent === "inventory_supplier_stock_overlap_as_of_date") { + const asOfDate = resolvePayablesAsOfDate(options); + const purchaseRows = rows.filter((row) => isInventoryPurchaseMovement(row)); + const summary = summarizeInventoryTraceRows(purchaseRows); + const unresolvedRows = purchaseRows.filter((row) => extractInventoryCounterpartyCandidates(row).length === 0); + const warehouseLabel = summary.warehouses[0] ?? "не указанного склада"; + const lines: string[] = [ + `Собран exact-срез supplier overlap для складского остатка до ${formatDateRu(asOfDate)}.`, + "", + "Блок 1. Статус результата", + `- Контур: подтвержденные закупочные движения на 41.01, связанные со складом ${warehouseLabel}.`, + "- Важно: без партионности этот контур показывает документально наблюдаемые supplier candidates, но не подменяет собой лот-level атрибуцию текущего остатка.", + "", + "Блок 2. Сводка", + `- Первая найденная дата закупочного движения: ${inventoryTraceDateLabel(summary.firstPeriod)}.`, + `- Последняя найденная дата закупочного движения: ${inventoryTraceDateLabel(summary.lastPeriod)}.`, + `- Закупочных документов в выборке: ${formatNumberWithDots(summary.documents.length)}.`, + `- Закупочных операций в выборке: ${formatNumberWithDots(purchaseRows.length)}.` + ]; + if (summary.counterparties.length > 0) { + lines.push(`- Найденные поставщики в наблюдаемом контуре: ${summary.counterparties.slice(0, 6).join("; ")}.`); + } else if (purchaseRows.length > 0) { + lines.push("- Закупочные движения найдены, но поставщик не материализован отдельным полем в текущем exact-контуре."); + } else { + lines.push("- В доступном exact-контуре не найдено закупочных движений по 41.01 для выбранного складского среза."); + } + if (unresolvedRows.length > 0) { + lines.push(`- Операций без явно материализованного поставщика: ${formatNumberWithDots(unresolvedRows.length)}.`); + } + if (purchaseRows.length > 0) { + lines.push("", "Блок 3. Опорные документы", ...formatInventoryTraceRows(purchaseRows, 10)); + } + return { + responseType: "FACTUAL_SUMMARY", + text: joinLines(lines), + semantics: { + result_mode: "confirmed_balance", + evidence_strength: purchaseRows.length > 0 ? (summary.counterparties.length > 0 ? "strong" : "medium") : "medium", + balance_confirmed: purchaseRows.length > 0 + } + }; + } + + if (intent === "inventory_aging_by_purchase_date") { + const asOfDate = resolvePayablesAsOfDate(options); + const purchaseRows = rows.filter((row) => isInventoryPurchaseMovement(row)); + const summary = summarizeInventoryTraceRows(purchaseRows); + const firstPeriodTime = summary.firstPeriod ? Date.parse(summary.firstPeriod) : Number.NaN; + const asOfTime = Date.parse(`${asOfDate}T23:59:59.000Z`); + const ageDays = + Number.isFinite(firstPeriodTime) && Number.isFinite(asOfTime) && firstPeriodTime <= asOfTime + ? Math.floor((asOfTime - firstPeriodTime) / 86_400_000) + : null; + const itemLabel = summary.item ?? "выбранному складскому остатку"; + const lines: string[] = [ + `Собран exact-срез возраста закупочного следа по ${itemLabel} до ${formatDateRu(asOfDate)}.`, + "", + "Блок 1. Статус результата", + "- Контур: показаны подтвержденные закупочные движения на 41.01 и их временной разброс.", + "- Важно: без партионности этот контур не доказывает возраст конкретного лота, а показывает документально наблюдаемый диапазон закупок.", + "", + "Блок 2. Сводка", + `- Первая найденная дата закупочного движения: ${inventoryTraceDateLabel(summary.firstPeriod)}.`, + `- Последняя найденная дата закупочного движения: ${inventoryTraceDateLabel(summary.lastPeriod)}.`, + `- Закупочных документов в выборке: ${formatNumberWithDots(summary.documents.length)}.`, + `- Закупочных операций в выборке: ${formatNumberWithDots(purchaseRows.length)}.` + ]; + if (ageDays !== null) { + lines.push(`- Между самой ранней найденной закупкой и датой среза прошло ${formatNumberWithDots(ageDays)} дн.`); + } + if (summary.counterparties.length > 0) { + lines.push(`- Поставщики, встречающиеся в наблюдаемом закупочном следе: ${summary.counterparties.slice(0, 4).join("; ")}.`); + } + if (purchaseRows.length > 0) { + lines.push("", "Блок 3. Опорные документы", ...formatInventoryTraceRows(purchaseRows, 8)); + } else { + lines.push("", "Блок 3. Опорные документы", "- В доступном exact-контуре не найдено закупочных движений по 41.01 для выбранного среза."); + } + return { + responseType: "FACTUAL_SUMMARY", + text: joinLines(lines), + semantics: { + result_mode: "confirmed_balance", + evidence_strength: purchaseRows.length > 0 ? "strong" : "medium", + balance_confirmed: purchaseRows.length > 0 + } + }; + } + + if (intent === "inventory_sale_trace_for_item") { + const asOfDate = resolvePayablesAsOfDate(options); + const saleRows = rows.filter((row) => isInventorySaleMovement(row)); + const summary = summarizeInventoryTraceRows(saleRows); + const itemLabel = summary.item ?? "товар не определен"; + const lines: string[] = [ + `Собран подтвержденный след выбытия по товару ${itemLabel} до ${formatDateRu(asOfDate)}.`, + "", + "Блок 1. Статус результата", + "- Результат: показаны подтвержденные движения выбытия товара со счета 41.01.", + "", + "Блок 2. Сводка", + `- Первая найденная дата выбытия: ${inventoryTraceDateLabel(summary.firstPeriod)}.`, + `- Последняя найденная дата выбытия: ${inventoryTraceDateLabel(summary.lastPeriod)}.`, + `- Документов выбытия: ${formatNumberWithDots(summary.documents.length)}.`, + `- Операций выбытия: ${formatNumberWithDots(saleRows.length)}.` + ]; + if (summary.counterparties.length === 1) { + lines.push(`- По доступным движениям товар отгружался покупателю: ${summary.counterparties[0]}.`); + } else if (summary.counterparties.length > 1) { + lines.push(`- По доступным движениям найдено несколько покупателей: ${summary.counterparties.slice(0, 4).join("; ")}.`); + } else if (saleRows.length > 0) { + lines.push("- Документы выбытия найдены, но покупатель не материализован отдельным полем в текущем exact-контуре."); + } + lines.push("", "Блок 3. Документы выбытия"); + if (saleRows.length > 0) { + lines.push(...formatInventoryTraceRows(saleRows, 12)); + } else { + lines.push("- По выбранному товару не найдено проводок выбытия со счета 41.01 в доступном контуре."); + } + return { + responseType: saleRows.length > 0 ? "FACTUAL_LIST" : "FACTUAL_SUMMARY", + text: joinLines(lines), + semantics: { + result_mode: "confirmed_balance", + evidence_strength: saleRows.length > 0 ? (summary.counterparties.length > 0 ? "strong" : "medium") : "medium", + balance_confirmed: saleRows.length > 0 + } + }; + } + + if (intent === "inventory_purchase_to_sale_chain") { + const asOfDate = resolvePayablesAsOfDate(options); + const purchaseRows = rows.filter((row) => isInventoryPurchaseMovement(row)); + const saleRows = rows.filter((row) => isInventorySaleMovement(row)); + const purchaseSummary = summarizeInventoryTraceRows(purchaseRows); + const saleSummary = summarizeInventoryTraceRows(saleRows); + const itemLabel = purchaseSummary.item ?? saleSummary.item ?? "товар не определен"; + const lines: string[] = [ + `Собрана документальная цепочка по товару ${itemLabel} до ${formatDateRu(asOfDate)}.`, + "", + "Блок 1. Статус результата", + `- Закупочных движений на 41.01: ${formatNumberWithDots(purchaseRows.length)}.`, + `- Движений выбытия со счета 41.01: ${formatNumberWithDots(saleRows.length)}.` + ]; + if (purchaseRows.length > 0 && saleRows.length > 0) { + lines.push("- В текущем контуре найдены обе стороны цепочки: поступление и последующее выбытие."); + } else if (purchaseRows.length > 0) { + lines.push("- Найдена только закупочная часть цепочки; выбытие в текущем exact-контуре не подтверждено."); + } else if (saleRows.length > 0) { + lines.push("- Найдена только часть выбытия; закупочная часть цепочки в текущем exact-контуре не подтверждена."); + } else { + lines.push("- Для выбранного товара не найдено движений по 41.01, из которых можно собрать цепочку."); + } + if (purchaseRows.length > 0) { + lines.push( + "", + "Блок 2. Закупка", + `- Первая дата: ${inventoryTraceDateLabel(purchaseSummary.firstPeriod)}.`, + `- Последняя дата: ${inventoryTraceDateLabel(purchaseSummary.lastPeriod)}.`, + ...formatInventoryTraceRows(purchaseRows, 6) + ); + } + if (saleRows.length > 0) { + lines.push( + "", + "Блок 3. Выбытие", + `- Первая дата: ${inventoryTraceDateLabel(saleSummary.firstPeriod)}.`, + `- Последняя дата: ${inventoryTraceDateLabel(saleSummary.lastPeriod)}.`, + ...formatInventoryTraceRows(saleRows, 6) + ); + } + return { + responseType: purchaseRows.length > 0 || saleRows.length > 0 ? "FACTUAL_SUMMARY" : "FACTUAL_SUMMARY", + text: joinLines(lines), + semantics: { + result_mode: "confirmed_balance", + evidence_strength: purchaseRows.length > 0 && saleRows.length > 0 ? "strong" : purchaseRows.length > 0 || saleRows.length > 0 ? "medium" : "weak", + balance_confirmed: purchaseRows.length > 0 || saleRows.length > 0 + } + }; + } + if (intent === "open_contracts_confirmed_as_of_date") { const asOfDate = resolvePayablesAsOfDate(options); const confirmedContracts = buildOpenContractConfirmedBalanceAggregate(rows, asOfDate); diff --git a/llm_normalizer/backend/src/services/address_runtime/decomposeStage.ts b/llm_normalizer/backend/src/services/address_runtime/decomposeStage.ts index 00645a4..b482460 100644 --- a/llm_normalizer/backend/src/services/address_runtime/decomposeStage.ts +++ b/llm_normalizer/backend/src/services/address_runtime/decomposeStage.ts @@ -490,6 +490,12 @@ function mergeFollowupFilters( intent === "list_open_contracts" || intent === "open_contracts_confirmed_as_of_date" || intent === "inventory_on_hand_as_of_date" || + intent === "inventory_purchase_provenance_for_item" || + intent === "inventory_purchase_documents_for_item" || + intent === "inventory_supplier_stock_overlap_as_of_date" || + intent === "inventory_sale_trace_for_item" || + intent === "inventory_purchase_to_sale_chain" || + intent === "inventory_aging_by_purchase_date" || intent === "payables_confirmed_as_of_date" || intent === "receivables_confirmed_as_of_date" || intent === "vat_payable_confirmed_as_of_date" @@ -524,6 +530,21 @@ function mergeFollowupFilters( reasons.push("as_of_date_from_followup_context"); } } + if ( + !sameDateRequested && + (intent === "inventory_sale_trace_for_item" || intent === "inventory_purchase_to_sale_chain") && + !hasExplicitPeriodLiteral(userMessage) && + !hasExplicitCurrentDateHint(userMessage) + ) { + const inheritedAsOfDate = previousAsOfDate ?? previousPeriodTo ?? previousPeriodFrom; + const currentAsOfDate = toNonEmptyString(merged.as_of_date); + const todayIso = new Date().toISOString().slice(0, 10); + const currentLooksDefaultedToToday = currentAsOfDate === todayIso; + if (inheritedAsOfDate && (!currentAsOfDate || currentLooksDefaultedToToday) && currentAsOfDate !== inheritedAsOfDate) { + merged.as_of_date = inheritedAsOfDate; + reasons.push("as_of_date_from_followup_context"); + } + } if ( !sameDateRequested && hasFollowupSignalForConfirmed && @@ -572,6 +593,12 @@ function mergeFollowupFilters( intent === "documents_forming_balance" || intent === "open_contracts_confirmed_as_of_date" || intent === "inventory_on_hand_as_of_date" || + intent === "inventory_purchase_provenance_for_item" || + intent === "inventory_purchase_documents_for_item" || + intent === "inventory_supplier_stock_overlap_as_of_date" || + intent === "inventory_sale_trace_for_item" || + intent === "inventory_purchase_to_sale_chain" || + intent === "inventory_aging_by_purchase_date" || intent === "payables_confirmed_as_of_date" || intent === "receivables_confirmed_as_of_date" || intent === "vat_payable_confirmed_as_of_date"; diff --git a/llm_normalizer/backend/src/services/assistantService.ts b/llm_normalizer/backend/src/services/assistantService.ts index 186745a..2069970 100644 --- a/llm_normalizer/backend/src/services/assistantService.ts +++ b/llm_normalizer/backend/src/services/assistantService.ts @@ -3814,12 +3814,27 @@ const ADDRESS_INTENTS_KEEP_ADDRESS_LANE = new Set([ "list_documents_by_counterparty", "bank_operations_by_counterparty", "list_contracts_by_counterparty", + "inventory_purchase_provenance_for_item", + "inventory_purchase_documents_for_item", + "inventory_supplier_stock_overlap_as_of_date", + "inventory_sale_trace_for_item", + "inventory_purchase_to_sale_chain", + "inventory_aging_by_purchase_date", "contract_usage_overview", "contract_usage_and_value", "vat_payable_forecast", "vat_liability_confirmed_for_tax_period", "vat_payable_confirmed_as_of_date" ]); +const ADDRESS_INTENTS_ALLOW_STRICT_DEEP_INVESTIGATION_BYPASS = new Set([ + "inventory_purchase_provenance_for_item", + "inventory_purchase_documents_for_item", + "inventory_sale_trace_for_item", + "inventory_purchase_to_sale_chain" +]); +function shouldBypassStrictDeepInvestigationCueForAddressIntent(intent) { + return Boolean(intent && ADDRESS_INTENTS_ALLOW_STRICT_DEEP_INVESTIGATION_BYPASS.has(intent)); +} export function resolveAssistantOrchestrationDecision(input) { const rawUserMessage = String(input?.rawUserMessage ?? input?.userMessage ?? ""); const effectiveAddressUserMessage = String(input?.effectiveAddressUserMessage ?? rawUserMessage); @@ -3873,11 +3888,13 @@ export function resolveAssistantOrchestrationDecision(input) { hasStrictDeepInvestigationCue(repairedRawUserMessage) || hasStrictDeepInvestigationCue(effectiveAddressUserMessage) || hasStrictDeepInvestigationCue(repairedEffectiveAddressUserMessage); + const strictDeepInvestigationBypassAllowed = shouldBypassStrictDeepInvestigationCueForAddressIntent(intentResolution.intent) || + shouldBypassStrictDeepInvestigationCueForAddressIntent(llmContractIntent); const keepAddressLaneByIntent = semanticApplyCanonicalRecommended && Boolean((intentResolution.intent && ADDRESS_INTENTS_KEEP_ADDRESS_LANE.has(intentResolution.intent)) || (llmContractIntent && ADDRESS_INTENTS_KEEP_ADDRESS_LANE.has(llmContractIntent)) || openContractsAddressSignal) && - !strictDeepInvestigationCueDetected; + (!strictDeepInvestigationCueDetected || strictDeepInvestigationBypassAllowed); const strongDataSignal = hasStrongDataIntentSignal(rawUserMessage) || hasStrongDataIntentSignal(repairedRawUserMessage) || hasStrongDataIntentSignal(effectiveAddressUserMessage) || @@ -4023,7 +4040,7 @@ export function resolveAssistantOrchestrationDecision(input) { hasShortDebtMirrorFollowupSignal(effectiveAddressUserMessage) || hasShortDebtMirrorFollowupSignal(repairedRawUserMessage) || hasShortDebtMirrorFollowupSignal(repairedEffectiveAddressUserMessage)); - const supportedAddressIntentDetected = !strictDeepInvestigationCueDetected && + const supportedAddressIntentDetected = (!strictDeepInvestigationCueDetected || strictDeepInvestigationBypassAllowed) && Boolean((intentResolution.intent && ADDRESS_INTENTS_KEEP_ADDRESS_LANE.has(intentResolution.intent)) || (llmContractIntent && ADDRESS_INTENTS_KEEP_ADDRESS_LANE.has(llmContractIntent)) || openContractsAddressSignal); @@ -4175,6 +4192,7 @@ export function resolveAssistantOrchestrationDecision(input) { semantic_reason_codes: semanticReasonCodes, semantic_route_arbitration: { supported_address_intent_detected: supportedAddressIntentDetected, + strict_deep_investigation_bypass_allowed: strictDeepInvestigationBypassAllowed, semantic_deep_investigation_hint_detected: semanticDeepInvestigationHintDetected, semantic_aggregate_shape_detected: semanticAggregateShapeDetected, followup_semantic_override_to_deep_allowed: followupSemanticOverrideToDeepAllowed diff --git a/llm_normalizer/backend/src/types/addressQuery.ts b/llm_normalizer/backend/src/types/addressQuery.ts index 56ca635..b30e165 100644 --- a/llm_normalizer/backend/src/types/addressQuery.ts +++ b/llm_normalizer/backend/src/types/addressQuery.ts @@ -111,6 +111,8 @@ export interface AddressFilterSet { counterparty?: string; contract?: string; account?: string; + item?: string; + warehouse?: string; document_type?: string; document_ref?: string; status?: string; @@ -150,7 +152,9 @@ export interface AddressRecipeDefinition { | "inventory_purchase_provenance_profile" | "inventory_purchase_documents_profile" | "inventory_supplier_stock_overlap_profile" - | "inventory_sale_trace_profile"; + | "inventory_sale_trace_profile" + | "inventory_purchase_to_sale_chain_profile" + | "inventory_aging_by_purchase_date_profile"; required_filters: Array; optional_filters: Array; default_limit: number; diff --git a/llm_normalizer/backend/tests/addressCapabilityPolicy.test.ts b/llm_normalizer/backend/tests/addressCapabilityPolicy.test.ts index 9e2acaf..a054e33 100644 --- a/llm_normalizer/backend/tests/addressCapabilityPolicy.test.ts +++ b/llm_normalizer/backend/tests/addressCapabilityPolicy.test.ts @@ -42,28 +42,73 @@ describe("address capability policy", () => { expect(isCapabilityRouteBlocked(decision)).toBe(false); }); - it("marks inventory provenance intents as blocked exact-capability gaps", () => { + it("enables inventory provenance intent as compute exact capability", () => { const decision = resolveAddressCapabilityRouteDecision("inventory_purchase_provenance_for_item"); expect(decision.capability_id).toBe("inventory_inventory_purchase_provenance_for_item"); expect(decision.capability_layer).toBe("compute"); expect(decision.capability_route_mode).toBe("exact"); - expect(decision.capability_route_enabled).toBe(false); - expect(decision.capability_route_reason).toBe("inventory_provenance_route_not_implemented"); - expect(isCapabilityRouteBlocked(decision)).toBe(true); + expect(decision.capability_route_enabled).toBe(true); + expect(decision.capability_route_reason).toBe("inventory_trace_route_enabled"); + expect(isCapabilityRouteBlocked(decision)).toBe(false); }); - it("marks purchase-to-sale trace and aging intents as blocked exact-capability gaps", () => { + it("enables inventory supplier overlap intent as compute exact capability", () => { + const decision = resolveAddressCapabilityRouteDecision("inventory_supplier_stock_overlap_as_of_date"); + expect(decision.capability_id).toBe("inventory_inventory_supplier_stock_overlap_as_of_date"); + expect(decision.capability_layer).toBe("compute"); + expect(decision.capability_route_mode).toBe("exact"); + expect(decision.capability_route_enabled).toBe(true); + expect(decision.capability_route_reason).toBe("inventory_supplier_stock_overlap_route_enabled"); + expect(isCapabilityRouteBlocked(decision)).toBe(false); + }); + + it("enables purchase-document and sale-trace intents", () => { + const purchaseDocsDecision = resolveAddressCapabilityRouteDecision("inventory_purchase_documents_for_item"); + expect(purchaseDocsDecision.capability_route_enabled).toBe(true); + expect(purchaseDocsDecision.capability_route_reason).toBe("inventory_trace_route_enabled"); + + const saleTraceDecision = resolveAddressCapabilityRouteDecision("inventory_sale_trace_for_item"); + expect(saleTraceDecision.capability_route_enabled).toBe(true); + expect(saleTraceDecision.capability_route_reason).toBe("inventory_trace_route_enabled"); + }); + + + it("keeps inventory purchase documents and sale chain on exact compute routes", () => { + const purchaseDocsDecision = resolveAddressCapabilityRouteDecision("inventory_purchase_documents_for_item"); + expect(purchaseDocsDecision.capability_id).toBe("inventory_inventory_purchase_documents_for_item"); + expect(purchaseDocsDecision.capability_layer).toBe("compute"); + expect(purchaseDocsDecision.capability_route_mode).toBe("exact"); + + const chainDecision = resolveAddressCapabilityRouteDecision("inventory_purchase_to_sale_chain"); + expect(chainDecision.capability_id).toBe("inventory_inventory_purchase_to_sale_chain"); + expect(chainDecision.capability_layer).toBe("compute"); + expect(chainDecision.capability_route_mode).toBe("exact"); + }); + + it("enables purchase-to-sale trace and aging by purchase date", () => { const chainDecision = resolveAddressCapabilityRouteDecision("inventory_purchase_to_sale_chain"); expect(chainDecision.capability_id).toBe("inventory_inventory_purchase_to_sale_chain"); expect(chainDecision.capability_route_mode).toBe("exact"); - expect(chainDecision.capability_route_enabled).toBe(false); - expect(isCapabilityRouteBlocked(chainDecision)).toBe(true); + expect(chainDecision.capability_route_enabled).toBe(true); + expect(chainDecision.capability_route_reason).toBe("inventory_purchase_to_sale_chain_route_enabled"); + expect(isCapabilityRouteBlocked(chainDecision)).toBe(false); const agingDecision = resolveAddressCapabilityRouteDecision("inventory_aging_by_purchase_date"); expect(agingDecision.capability_id).toBe("inventory_inventory_aging_by_purchase_date"); expect(agingDecision.capability_route_mode).toBe("exact"); - expect(agingDecision.capability_route_enabled).toBe(false); - expect(isCapabilityRouteBlocked(agingDecision)).toBe(true); + expect(agingDecision.capability_route_enabled).toBe(true); + expect(agingDecision.capability_route_reason).toBe("inventory_aging_route_enabled"); + expect(isCapabilityRouteBlocked(agingDecision)).toBe(false); + }); + + it("enables aging by purchase date as an exact inventory capability", () => { + const decision = resolveAddressCapabilityRouteDecision("inventory_aging_by_purchase_date"); + expect(decision.capability_id).toBe("inventory_inventory_aging_by_purchase_date"); + expect(decision.capability_layer).toBe("compute"); + expect(decision.capability_route_mode).toBe("exact"); + expect(decision.capability_route_enabled).toBe(true); + expect(decision.capability_route_reason).toBe("inventory_aging_route_enabled"); + expect(isCapabilityRouteBlocked(decision)).toBe(false); }); it("maps document drilldown intent to navigation capability", () => { diff --git a/llm_normalizer/backend/tests/addressInventoryChainTail.test.ts b/llm_normalizer/backend/tests/addressInventoryChainTail.test.ts new file mode 100644 index 0000000..47c4f73 --- /dev/null +++ b/llm_normalizer/backend/tests/addressInventoryChainTail.test.ts @@ -0,0 +1,14 @@ +import { describe, expect, it } from "vitest"; +import { extractAddressFilters } from "../src/services/addressFilterExtractor"; + +describe("inventory supplier-item-buyer chain filter extraction", () => { + it("trims buyer tail from item filter in documentary chain questions", () => { + const filters = extractAddressFilters( + "Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, РћРћРћ -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта РіРѕСЂРѕРґР° РњРѕСЃРєРІС‹", + "inventory_purchase_to_sale_chain" + ).extracted_filters; + + expect(filters.item).toContain("1000*400*2100"); + expect(filters.item).not.toContain("покупатель"); + }); +}); diff --git a/llm_normalizer/backend/tests/addressInventorySelectedObjectFollowup.test.ts b/llm_normalizer/backend/tests/addressInventorySelectedObjectFollowup.test.ts new file mode 100644 index 0000000..d3f664b --- /dev/null +++ b/llm_normalizer/backend/tests/addressInventorySelectedObjectFollowup.test.ts @@ -0,0 +1,94 @@ +import { afterEach, describe, expect, it, vi } from "vitest"; + +const { executeAddressMcpQueryMock } = vi.hoisted(() => ({ + executeAddressMcpQueryMock: vi.fn() +})); + +vi.mock("../src/services/addressMcpClient", async () => { + const actual = await vi.importActual( + "../src/services/addressMcpClient" + ); + return { + ...actual, + executeAddressMcpQuery: executeAddressMcpQueryMock + }; +}); + +import { AddressQueryService } from "../src/services/addressQueryService"; + +afterEach(() => { + executeAddressMcpQueryMock.mockReset(); + vi.restoreAllMocks(); +}); + +describe("inventory selected-object follow-up", () => { + it("auto-broadens dated stock follow-up window for inventory provenance", async () => { + executeAddressMcpQueryMock + .mockResolvedValueOnce({ + fetched_rows: 1, + matched_rows: 1, + raw_rows: [ + { + Period: "2021-03-09T00:00:00Z", + Registrator: "Поступление товаров и услуг 00000000001 от 09.03.2021 0:00:00", + AccountDt: "41.01", + AccountKt: "60.01", + Amount: 442075, + SubcontoDt1: "Рабочая станция универсального специалиста с угловым элементом.", + SubcontoDt3: "Основной склад", + SubcontoKt1: "АСТРА", + SubcontoKt2: "А_03/2021 от 01.03.2021г.", + Organization: "ООО \\Альтернатива Плюс\\" + } + ], + rows: [], + error: null + }) + .mockResolvedValueOnce({ + fetched_rows: 2, + matched_rows: 2, + raw_rows: [ + { + Period: "2020-02-11T00:00:00Z", + Registrator: "Поступление товаров и услуг 00000000077 от 11.02.2020 0:00:00", + AccountDt: "41.01", + AccountKt: "60.01", + Amount: 165.83, + SubcontoDt1: "Кромка с клеем 33 альмандин 137 м", + SubcontoDt3: "Основной склад", + SubcontoKt1: "Торговый дом \\Союз МСК\\", + SubcontoKt2: "Договор поставки № 12 от 01.02.2020", + Organization: "ООО \\Альтернатива Плюс\\" + }, + { + Period: "2020-02-11T00:00:00Z", + Registrator: "Поступление товаров и услуг 00000000077 от 11.02.2020 0:00:00", + AccountDt: "41.01", + AccountKt: "60.01", + Amount: 165.83, + SubcontoDt1: "Кромка с клеем 33 дуб ниагара 137 м", + SubcontoDt3: "Основной склад", + SubcontoKt1: "Торговый дом \\Союз МСК\\", + SubcontoKt2: "Договор поставки № 12 от 01.02.2020", + Organization: "ООО \\Альтернатива Плюс\\" + } + ], + rows: [], + error: null + }); + + const service = new AddressQueryService(); + const result = await service.tryHandle( + 'По выбранному объекту "Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\\\Альтернатива Плюс\\\\ | дата строки: 2021-03-31T23:59:59Z": От какого поставщика куплен товар' + ); + + expect(result?.handled).toBe(true); + expect(result?.response_type).toBe("FACTUAL_SUMMARY"); + expect(result?.debug.detected_intent).toBe("inventory_purchase_provenance_for_item"); + expect(result?.debug.extracted_filters?.item).toBe("Кромка с клеем 33 альмандин 137 м"); + expect(result?.debug.reasons).toContain("period_window_auto_broadened_to_available_data"); + expect(result?.debug.limitations).toContain("period_window_auto_broadened_to_available_data"); + expect(String(result?.reply_text ?? "")).toContain("Торговый дом \\Союз МСК\\"); + expect(executeAddressMcpQueryMock).toHaveBeenCalledTimes(2); + }); +}); diff --git a/llm_normalizer/backend/tests/addressInventoryWarehouseAnchor.test.ts b/llm_normalizer/backend/tests/addressInventoryWarehouseAnchor.test.ts new file mode 100644 index 0000000..6c83227 --- /dev/null +++ b/llm_normalizer/backend/tests/addressInventoryWarehouseAnchor.test.ts @@ -0,0 +1,26 @@ +import { describe, expect, it } from "vitest"; +import { extractAddressFilters } from "../src/services/addressFilterExtractor"; + +describe("inventory warehouse anchor extraction", () => { + it("does not treat 'по состоянию ...' as warehouse name in stock snapshot questions", () => { + const filters = extractAddressFilters( + "Какие товары находятся на складе по состоянию на 15 марта 2020 года?", + "inventory_on_hand_as_of_date" + ).extracted_filters; + + expect(filters.as_of_date).toBe("2020-03-15"); + expect(filters.warehouse).toBeUndefined(); + }); + + it("does not treat month phrases as warehouse name in stock snapshot questions", () => { + const filters = extractAddressFilters( + "Какие товары лежат на складе на март 2019", + "inventory_on_hand_as_of_date" + ).extracted_filters; + + expect(filters.period_from).toBe("2019-03-01"); + expect(filters.period_to).toBe("2019-03-31"); + expect(filters.as_of_date).toBe("2019-03-31"); + expect(filters.warehouse).toBeUndefined(); + }); +}); diff --git a/llm_normalizer/backend/tests/addressQueryRuntimeM23.test.ts b/llm_normalizer/backend/tests/addressQueryRuntimeM23.test.ts index d206806..4329163 100644 --- a/llm_normalizer/backend/tests/addressQueryRuntimeM23.test.ts +++ b/llm_normalizer/backend/tests/addressQueryRuntimeM23.test.ts @@ -130,6 +130,222 @@ describe("address query shape classifier", () => { expect(result.mode).toBe("address_query"); }); + it("extracts item anchor for inventory provenance questions", () => { + const filters = extractAddressFilters( + "От какого поставщика куплен товар Шкаф картотечный?", + "inventory_purchase_provenance_for_item" + ).extracted_filters; + expect(filters.item).toBe("Шкаф картотечный"); + }); + + it("cuts inventory item anchor before current-stock tail", () => { + const filters = extractAddressFilters( + "От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад", + "inventory_purchase_provenance_for_item" + ).extracted_filters; + expect(filters.item).toBe("Диван трехместный"); + expect(filters.warehouse).toBe("Основной склад"); + }); + + it("cuts inventory item anchor before chain suffix and ignores chain pseudo-warehouse", () => { + const filters = extractAddressFilters( + "Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа", + "inventory_purchase_to_sale_chain" + ).extracted_filters; + expect(filters.item).toBe("Шкаф картотечный 1000*400*2100"); + expect(filters.warehouse).toBeUndefined(); + }); + + it("cuts inventory item anchor before purchase-doc residue tail", () => { + const filters = extractAddressFilters( + "По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад", + "inventory_purchase_documents_for_item" + ).extracted_filters; + expect(filters.item).toBe("Диван трехместный"); + expect(filters.warehouse).toBe("Основной склад"); + }); + + it("extracts item anchor from selected-object inventory row for provenance follow-up", () => { + const filters = extractAddressFilters( + 'По выбранному объекту "Кромка с клеем 33 альмандин 137 м | склад: Основной склад | количество: 1,000 | стоимость: 165,83 ₽ | организация: ООО \\\\Альтернатива Плюс\\\\ | дата строки: 2021-03-31T23:59:59Z": От какого поставщика куплен товар', + "inventory_purchase_provenance_for_item" + ).extracted_filters; + expect(filters.item).toBe("Кромка с клеем 33 альмандин 137 м"); + }); + + it("keeps full supplier anchor with comma suffix for stock-overlap questions", () => { + const filters = extractAddressFilters( + "Какие товары от поставщика Гамма-мебель, ООО сейчас еще лежат на складе Основной склад?", + "inventory_supplier_stock_overlap_as_of_date" + ).extracted_filters; + expect(filters.counterparty).toBe("Гамма-мебель, ООО"); + }); + + it("does not capture organization wording as supplier anchor in overlap questions", () => { + const filters = extractAddressFilters( + "У какого поставщика были куплены товары, которые сейчас лежат на складе Основной склад организации ООО \\Альтернатива Плюс\\", + "inventory_supplier_stock_overlap_as_of_date" + ).extracted_filters; + expect(filters.counterparty).toBeUndefined(); + expect(filters.warehouse).toBe("Основной склад"); + }); + + it("extracts item anchor for inventory aging questions", () => { + const filters = extractAddressFilters( + "Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам", + "inventory_aging_by_purchase_date" + ).extracted_filters; + expect(filters.item).toBe("Шкаф картотечный 1000*400*2100"); + }); + + it("builds dedicated inventory purchase-documents query plan", () => { + const selected = selectAddressRecipe("inventory_purchase_documents_for_item", { + item: "Шкаф картотечный", + as_of_date: "2020-03-31" + }); + expect(selected.selected_recipe?.recipe_id).toBe("address_inventory_purchase_documents_for_item_v1"); + const plan = buildAddressRecipePlan(selected.selected_recipe!, { + item: "Шкаф картотечный", + as_of_date: "2020-03-31" + }); + expect(plan.query).toContain("РегистрБухгалтерии.Хозрасчетный.ДвиженияССубконто"); + expect(plan.query).toContain("Движения.СчетДт"); + expect(plan.query).toContain("ПРЕДСТАВЛЕНИЕ(Движения.СубконтоДт1) КАК СубконтоДт1"); + expect(plan.query).toContain("41.01"); + }); + + it("builds overlap recipe for supplier-linked stock slice", () => { + const selected = selectAddressRecipe("inventory_supplier_stock_overlap_as_of_date", { + counterparty: "Гамма-мебель, ООО", + warehouse: "Основной склад", + as_of_date: "2020-03-31" + }); + expect(selected.selected_recipe?.recipe_id).toBe("address_inventory_supplier_stock_overlap_as_of_date_v1"); + const plan = buildAddressRecipePlan(selected.selected_recipe!, { + counterparty: "Гамма-мебель, ООО", + warehouse: "Основной склад", + as_of_date: "2020-03-31" + }); + expect(plan.query).toContain("РегистрБухгалтерии.Хозрасчетный.ДвиженияССубконто"); + expect(plan.query).toContain("Движения.СчетДт"); + expect(plan.query).toContain("41.01"); + }); + + it("renders inventory purchase documents from purchase-side 41.01 movements", () => { + const reply = composeFactualReply( + "inventory_purchase_documents_for_item", + [ + { + period: "2020-03-15T12:00:00Z", + registrator: "Поступление товаров и услуг 0001", + account_dt: "41.01", + account_kt: "60.01", + amount: 150000, + analytics: ["Шкаф картотечный", "Основной склад", "ООО Ромашка", "Гамма-мебель, ООО"], + item: "Шкаф картотечный", + warehouse: "Основной склад", + organization: "ООО Ромашка" + } + ], + { + asOfDate: "2020-03-31", + useRubCurrency: true + } + ); + expect(reply.text).toContain("Шкаф картотечный"); + expect(reply.text).toContain("Поступление товаров и услуг 0001"); + expect(reply.semantics?.result_mode).toBe("confirmed_balance"); + }); + + it("renders inventory provenance summary from purchase-side 41.01 movements", () => { + const reply = composeFactualReply( + "inventory_purchase_provenance_for_item", + [ + { + period: "2020-03-15T12:00:00Z", + registrator: "Поступление товаров и услуг 0001", + account_dt: "41.01", + account_kt: "60.01", + amount: 150000, + analytics: ["Шкаф картотечный", "Основной склад", "ООО Ромашка", "Гамма-мебель, ООО"], + item: "Шкаф картотечный", + warehouse: "Основной склад", + organization: "ООО Ромашка" + } + ], + { + asOfDate: "2020-03-31", + useRubCurrency: true + } + ); + expect(reply.text).toContain("закупочный след"); + expect(reply.text).toContain("Гамма-мебель, ООО"); + expect(reply.semantics?.balance_confirmed).toBe(true); + }); + + it("renders inventory sale trace from credit-side 41.01 movements", () => { + const reply = composeFactualReply( + "inventory_sale_trace_for_item", + [ + { + period: "2020-04-10T12:00:00Z", + registrator: "Реализация товаров и услуг 0007", + account_dt: "90.02", + account_kt: "41.01", + amount: 210000, + analytics: ["Шкаф картотечный", "Основной склад", "ООО Ромашка", "Департамент капитального ремонта города Москвы"], + item: "Шкаф картотечный", + warehouse: "Основной склад", + organization: "ООО Ромашка" + } + ], + { + asOfDate: "2020-04-30", + useRubCurrency: true + } + ); + expect(reply.text).toContain("след выбытия"); + expect(reply.text).toContain("Реализация товаров и услуг 0007"); + expect(reply.text).toContain("Департамент капитального ремонта города Москвы"); + }); + + it("renders purchase-to-sale chain from both sides of 41.01", () => { + const reply = composeFactualReply( + "inventory_purchase_to_sale_chain", + [ + { + period: "2020-03-15T12:00:00Z", + registrator: "Поступление товаров и услуг 0001", + account_dt: "41.01", + account_kt: "60.01", + amount: 150000, + analytics: ["Шкаф картотечный", "Основной склад", "ООО Ромашка", "Гамма-мебель, ООО"], + item: "Шкаф картотечный", + warehouse: "Основной склад", + organization: "ООО Ромашка" + }, + { + period: "2020-04-10T12:00:00Z", + registrator: "Реализация товаров и услуг 0007", + account_dt: "90.02", + account_kt: "41.01", + amount: 210000, + analytics: ["Шкаф картотечный", "Основной склад", "ООО Ромашка", "Департамент капитального ремонта города Москвы"], + item: "Шкаф картотечный", + warehouse: "Основной склад", + organization: "ООО Ромашка" + } + ], + { + asOfDate: "2020-04-30", + useRubCurrency: true + } + ); + expect(reply.text).toContain("документальная цепочка"); + expect(reply.text).toContain("Поступление товаров и услуг 0001"); + expect(reply.text).toContain("Реализация товаров и услуг 0007"); + expect(reply.semantics?.result_mode).toBe("confirmed_balance"); + }); }); describe("address compose stage utf8 headers", () => { @@ -4090,6 +4306,39 @@ describe("address recipe catalog counterparty filtering", () => { expect(plan.query).toContain("ДоговорКонтрагента"); }); + it("keeps recipe-default limits for inventory exact intents", () => { + const onHand = extractAddressFilters("Какие товары сейчас лежат на складе?", "inventory_on_hand_as_of_date"); + const provenance = extractAddressFilters( + "От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад?", + "inventory_purchase_provenance_for_item" + ); + const purchaseDocs = extractAddressFilters( + "По каким документам был куплен товар Диван трехместный для остатка на складе Основной склад?", + "inventory_purchase_documents_for_item" + ); + const overlap = extractAddressFilters( + "Какие товары от поставщика Гамма-мебель, ООО сейчас еще лежат на складе Основной склад?", + "inventory_supplier_stock_overlap_as_of_date" + ); + const saleTrace = extractAddressFilters("Кому был продан товар Шкаф картотечный 1000*400*2100?", "inventory_sale_trace_for_item"); + const chain = extractAddressFilters( + "Через какие документы прошел путь товара Шкаф картотечный 1000*400*2100: закупка -> склад -> продажа?", + "inventory_purchase_to_sale_chain" + ); + const aging = extractAddressFilters( + "Есть ли среди текущих остатков на складе Основной склад позиции, закупленные очень давно?", + "inventory_aging_by_purchase_date" + ); + + expect(onHand.extracted_filters.limit).toBeUndefined(); + expect(provenance.extracted_filters.limit).toBeUndefined(); + expect(purchaseDocs.extracted_filters.limit).toBeUndefined(); + expect(overlap.extracted_filters.limit).toBeUndefined(); + expect(saleTrace.extracted_filters.limit).toBeUndefined(); + expect(chain.extracted_filters.limit).toBeUndefined(); + expect(aging.extracted_filters.limit).toBeUndefined(); + }); + it("selects customer value recipe and keeps top-20 default", () => { const selected = selectAddressRecipe("customer_revenue_and_payments", {}); expect(selected.selected_recipe).toBeTruthy(); @@ -4339,6 +4588,52 @@ describe("address recipe catalog counterparty filtering", () => { expect(result.confidence).toBe("high"); }); + it("detects colloquial warehouse snapshot wording as inventory-on-hand intent", () => { + const result = resolveAddressIntent("что у нас на складе на март 2017"); + expect(result.intent).toBe("inventory_on_hand_as_of_date"); + expect(result.confidence).toBe("high"); + }); + + it("routes account 41 composition wording into inventory snapshot intent", () => { + const result = resolveAddressIntent("Из каких товаров состоит остаток по 41 счету"); + expect(result.intent).toBe("inventory_on_hand_as_of_date"); + }); + + it("routes account 41 date snapshot wording into inventory snapshot intent", () => { + const result = resolveAddressIntent("Какие товары числятся на 41 счете на дату 2020-03-31"); + expect(result.intent).toBe("inventory_on_hand_as_of_date"); + }); + + it("routes supplier stock overlap wording into overlap intent", () => { + const result = resolveAddressIntent("Какие товары от поставщика Гамма-мебель, ООО сейчас еще лежат на складе Основной склад"); + expect(result.intent).toBe("inventory_supplier_stock_overlap_as_of_date"); + }); + + it("routes supplier to buyer chain wording into purchase-to-sale chain intent", () => { + const result = resolveAddressIntent( + "Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы" + ); + expect(result.intent).toBe("inventory_purchase_to_sale_chain"); +}); + +it("routes supplier-to-buyer inventory chains as exact trace intents", () => { + const result = resolveAddressIntent( + "Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы" + ); + + expect(result.intent).toBe("inventory_purchase_to_sale_chain"); + expect(result.confidence).toBe("medium"); +}); + +it("routes old purchase residue questions to aging-by-purchase-date", () => { + const result = resolveAddressIntent( + "Относится ли товар Шкаф картотечный 1000*400*2100 в остатке на дату 2020-03-31 к старым закупкам" + ); + + expect(result.intent).toBe("inventory_aging_by_purchase_date"); + expect(result.confidence).toBe("high"); +}); + it("derives as_of_date for inventory-on-hand from explicit month window", () => { const filters = extractAddressFilters( "Какие товары лежат на складе на март 2020", @@ -4400,6 +4695,13 @@ describe("address recipe catalog counterparty filtering", () => { expect(result.intent).toBe("inventory_purchase_provenance_for_item"); }); + it("keeps direct item supplier questions in provenance intent even with current-stock tail", () => { + const result = resolveAddressIntent( + "От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад?" + ); + expect(result.intent).toBe("inventory_purchase_provenance_for_item"); + }); + it("keeps inventory supplier overlap questions out of on-hand routing", () => { const result = resolveAddressIntent("Какие товары от поставщика Альфа сейчас лежат на складе?"); expect(result.intent).toBe("inventory_supplier_stock_overlap_as_of_date"); @@ -4414,7 +4716,7 @@ describe("address recipe catalog counterparty filtering", () => { const result = resolveAddressIntent( "Через какие документы прошел путь товара Шкаф картоотечный: закупка -> склад -> продажа?" ); - expect(result.intent).toBe("inventory_sale_trace_for_item"); + expect(result.intent).toBe("inventory_purchase_to_sale_chain"); }); it("keeps inventory provenance wording out of inventory-on-hand routing", () => { @@ -4427,6 +4729,16 @@ describe("address recipe catalog counterparty filtering", () => { expect(result.intent).toBe("inventory_aging_by_purchase_date"); }); + it("keeps very old purchase wording out of on-hand routing", () => { + const result = resolveAddressIntent("Относится ли товар к закупленным задолго до даты остатка на складе?"); + expect(result.intent).toBe("inventory_aging_by_purchase_date"); + }); + + it("routes old stock wording with residue anchor to aging intent", () => { + const result = resolveAddressIntent("Это остаток по очень давно купленному товару?"); + expect(result.intent).toBe("inventory_aging_by_purchase_date"); + }); + it("routes purchase-document trace wording to dedicated inventory intent", () => { const result = resolveAddressIntent("Какими документами был куплен товар Шкаф картоотечный?"); expect(result.intent).toBe("inventory_purchase_documents_for_item"); @@ -4436,9 +4748,33 @@ describe("address recipe catalog counterparty filtering", () => { expect(result.intent).toBe("inventory_aging_by_purchase_date"); }); + it("routes residue wording with explicit cut-off date into aging intent", () => { + const result = resolveAddressIntent( + "Есть ли среди текущих остатков на складе Основной склад позиции, закупленные задолго до 2020-03-31?" + ); + expect(result.intent).toBe("inventory_aging_by_purchase_date"); + }); + it("keeps unresolved stock provenance wording out of open-items routing", () => { const result = resolveAddressIntent("Какие товары сейчас висят в остатке без понятной привязки к поставщику?"); - expect(result.intent).toBe("inventory_purchase_provenance_for_item"); + expect(result.intent).toBe("inventory_supplier_stock_overlap_as_of_date"); + }); + + it("routes documentary supplier-to-buyer chain wording into inventory chain intent", () => { + const result = resolveAddressIntent( + "Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы?" + ); + expect(result.intent).toBe("inventory_purchase_to_sale_chain"); + }); + + it("routes explicit supplier-item-buyer chain wording into inventory chain intent", () => { + const result = resolveAddressIntent("supplier -> item -> buyer"); + expect(result.intent).toBe("inventory_purchase_to_sale_chain"); + }); + + it("routes documented supplier-item-buyer chain wording into inventory chain intent", () => { + const result = resolveAddressIntent("Документально подтвержденная цепочка: поставщик -> товар -> покупатель"); + expect(result.intent).toBe("inventory_purchase_to_sale_chain"); }); }); diff --git a/llm_normalizer/backend/tests/assistantAddressLlmPredecompose.test.ts b/llm_normalizer/backend/tests/assistantAddressLlmPredecompose.test.ts index 058a57b..d10e5f1 100644 --- a/llm_normalizer/backend/tests/assistantAddressLlmPredecompose.test.ts +++ b/llm_normalizer/backend/tests/assistantAddressLlmPredecompose.test.ts @@ -254,6 +254,102 @@ describe("assistant address llm pre-decompose candidate preference", () => { expect(response.debug?.llm_decomposition_reason).not.toBe("normalized_fragment_applied"); }); + it("keeps colloquial warehouse snapshot questions in exact inventory contour when llm rewrites them abstractly", async () => { + const calls: Array<{ message: string }> = []; + const addressQueryService = { + tryHandle: vi.fn(async (message: string) => { + calls.push({ message }); + return buildAddressLaneResult(message); + }) + } as any; + + const normalizerService = { + normalize: vi.fn(async () => ({ + trace_id: "norm-predecompose-inventory-colloquial", + ok: true, + normalized: { + schema_version: "normalized_query_v2_0_2", + user_message_raw: "что у нас на складе на март 2017", + message_in_scope: true, + scope_confidence: "medium", + contains_multiple_tasks: false, + fragments: [ + { + fragment_id: "F1", + raw_fragment_text: "что у нас на складе на март 2017", + normalized_fragment_text: "информация о наличии товаров на складе за март 2017 года", + domain_relevance: "in_scope", + business_scope: "company_specific_accounting", + entity_hints: [], + account_hints: [], + document_hints: [], + register_hints: [], + time_scope: { + type: "explicit", + value: "2017-03", + confidence: "high" + }, + flags: { + has_multi_entity_scope: false, + asks_for_chain_explanation: false, + asks_for_ranking_or_top: false, + asks_for_period_summary: false, + asks_for_rule_check: false, + asks_for_anomaly_scan: false, + asks_for_exact_object_trace: false, + asks_for_evidence: false, + mentions_period_close_context: false + }, + candidate_labels: ["simple_factual"], + confidence: "medium", + execution_readiness: "executable", + clarification_reason: null, + soft_assumption_used: [], + route_status: "routed", + no_route_reason: null + } + ], + discarded_fragments: [], + global_notes: { + needs_clarification: false, + clarification_reason: null + } + }, + raw_model_output: null, + validation: { passed: true, errors: [] }, + usage: { input_tokens: 1, output_tokens: 1, total_tokens: 2 }, + latency_ms: 10, + prompt_version: "normalizer_v2_0_2", + schema_version: "v2_0_2", + request_count_for_case: 1 + })) + } as any; + + const sessions = new AssistantSessionStore(); + const service = new AssistantService( + normalizerService, + sessions as any, + {} as any, + { persistSession: vi.fn() } as any, + addressQueryService + ); + + const response = await service.handleMessage({ + session_id: `asst-predecompose-inventory-colloquial-${Date.now()}`, + user_message: "что у нас на складе на март 2017", + llmProvider: "local", + useMock: false + } as any); + + expect(response.ok).toBe(true); + expect(response.reply_type).toBe("factual"); + expect(calls).toHaveLength(1); + expect(calls[0].message.toLowerCase()).toContain("складе"); + expect(response.debug?.tool_gate_decision).toBe("run_address_lane"); + expect(response.debug?.llm_predecompose_contract?.intent).toBe("inventory_on_hand_as_of_date"); + expect(response.debug?.llm_decomposition_reason).not.toBe("normalized_fragment_applied"); + }); + it("does not treat service verb as counterparty anchor when llm rewrites noisy bank phrase", async () => { const calls: Array<{ message: string }> = []; const addressQueryService = { diff --git a/llm_normalizer/backend/tests/assistantLivingRouter.test.ts b/llm_normalizer/backend/tests/assistantLivingRouter.test.ts index c8a4e22..b8bd432 100644 --- a/llm_normalizer/backend/tests/assistantLivingRouter.test.ts +++ b/llm_normalizer/backend/tests/assistantLivingRouter.test.ts @@ -264,6 +264,36 @@ describe("assistant orchestration contract", () => { expect(decision.livingReason).toBe("address_lane_triggered"); }); + it("keeps inventory provenance and sale-trace queries in address lane", () => { + const decision = resolveAssistantOrchestrationDecision({ + rawUserMessage: "От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад", + effectiveAddressUserMessage: "От какого поставщика куплен товар Диван трехместный из текущего остатка на складе Основной склад", + followupContext: { + previous_intent: "inventory_purchase_provenance_for_item", + previous_filters: { + as_of_date: "2020-03-31" + } + }, + llmPreDecomposeMeta: { + applied: true, + llmCanonicalCandidateDetected: true, + predecomposeContract: { + mode: "address_query", + mode_confidence: "high", + intent: "inventory_purchase_provenance_for_item", + intent_confidence: "high" + } + } as any, + useMock: false + }); + + expect(decision.runAddressLane).toBe(true); + expect(decision.toolGateDecision).toBe("run_address_lane"); + expect(decision.toolGateReason).toBe("address_mode_classifier_detected"); + expect(decision.livingMode).toBe("address_data"); + expect(decision.livingReason).toBe("address_lane_triggered"); + }); + it("keeps customer-value ranking question in address lane even when LLM semantic guard rejects canonical rewrite", () => { const decision = resolveAssistantOrchestrationDecision({ rawUserMessage: "кто больше всего принес денег в 2020", @@ -558,6 +588,47 @@ describe("assistant orchestration contract", () => { expect(decision.livingReason).toBe("address_lane_triggered"); }); + it("keeps documentary inventory chain verification in address lane for supported exact intent", () => { + const question = + "Есть ли документально подтвержденная цепочка: поставщик Гамма-мебель, ООО -> товар Шкаф картотечный 1000*400*2100 -> покупатель Департамент капитального ремонта города Москвы"; + const decision = resolveAssistantOrchestrationDecision({ + rawUserMessage: question, + effectiveAddressUserMessage: question, + followupContext: null, + llmPreDecomposeMeta: { + applied: true, + llmCanonicalCandidateDetected: true, + predecomposeContract: { + mode: "deep_analysis", + mode_confidence: "high", + intent: "inventory_purchase_to_sale_chain", + intent_confidence: "medium" + }, + semanticExtractionContract: { + valid: true, + apply_canonical_recommended: true, + reason_codes: ["deep_investigation_signal_detected"], + guard_hints: { + deep_investigation_signal_detected: true + }, + extraction: { + query_shape: "VERIFY_FACTUAL", + aggregation_profile: "unknown" + } + } + } as any, + useMock: false + }); + + expect(decision.runAddressLane).toBe(true); + expect(decision.toolGateDecision).toBe("run_address_lane"); + expect(decision.livingMode).toBe("address_data"); + expect(decision.livingReason).toBe("address_lane_triggered"); + expect(decision.orchestrationContract?.deep_analysis_signal_fallback_to_deep).toBe(false); + expect(decision.orchestrationContract?.semantic_route_arbitration?.supported_address_intent_detected).toBe(true); + expect(decision.orchestrationContract?.semantic_route_arbitration?.strict_deep_investigation_bypass_allowed).toBe(true); + }); + it("keeps 'a na tekushuyu datu' follow-up in address lane when previous VAT context exists", () => { const decision = resolveAssistantOrchestrationDecision({ rawUserMessage: "а на текущую дату", diff --git a/llm_normalizer/data/eval_cases/assistant_autogen_runtime_job-X-D_QsIwS1.json b/llm_normalizer/data/eval_cases/assistant_autogen_runtime_job-X-D_QsIwS1.json new file mode 100644 index 0000000..9877f67 --- /dev/null +++ b/llm_normalizer/data/eval_cases/assistant_autogen_runtime_job-X-D_QsIwS1.json @@ -0,0 +1,22 @@ +{ + "suite_id": "assistant_autogen_runtime_job-X-D_QsIwS1", + "suite_version": "0.1.0", + "schema_version": "assistant_autogen_runtime_v0_1", + "scenario_count": 1, + "case_ids": [ + "AUTO-001" + ], + "cases": [ + { + "case_id": "AUTO-001", + "scenario_tag": "autogen_runtime", + "question_type": "direct", + "broadness_level": "medium", + "turns": [ + { + "user_message": "Какие товары лежат на складе на март 2017" + } + ] + } + ] +} \ No newline at end of file diff --git a/llm_normalizer/data/eval_cases/assistant_autogen_runtime_job-Ypd6PvQH49.json b/llm_normalizer/data/eval_cases/assistant_autogen_runtime_job-Ypd6PvQH49.json new file mode 100644 index 0000000..28ed5e3 --- /dev/null +++ b/llm_normalizer/data/eval_cases/assistant_autogen_runtime_job-Ypd6PvQH49.json @@ -0,0 +1,22 @@ +{ + "suite_id": "assistant_autogen_runtime_job-Ypd6PvQH49", + "suite_version": "0.1.0", + "schema_version": "assistant_autogen_runtime_v0_1", + "scenario_count": 1, + "case_ids": [ + "AUTO-001" + ], + "cases": [ + { + "case_id": "AUTO-001", + "scenario_tag": "autogen_runtime", + "question_type": "direct", + "broadness_level": "medium", + "turns": [ + { + "user_message": "Какие товары лежат на складе на 15 марта 2020" + } + ] + } + ] +} \ No newline at end of file diff --git a/llm_normalizer/data/eval_cases/assistant_autogen_runtime_job-iFZBx9sfg7.json b/llm_normalizer/data/eval_cases/assistant_autogen_runtime_job-iFZBx9sfg7.json new file mode 100644 index 0000000..a9f70d8 --- /dev/null +++ b/llm_normalizer/data/eval_cases/assistant_autogen_runtime_job-iFZBx9sfg7.json @@ -0,0 +1,22 @@ +{ + "suite_id": "assistant_autogen_runtime_job-iFZBx9sfg7", + "suite_version": "0.1.0", + "schema_version": "assistant_autogen_runtime_v0_1", + "scenario_count": 1, + "case_ids": [ + "AUTO-001" + ], + "cases": [ + { + "case_id": "AUTO-001", + "scenario_tag": "autogen_runtime", + "question_type": "direct", + "broadness_level": "medium", + "turns": [ + { + "user_message": "Какие товары лежат на складе на март 2019" + } + ] + } + ] +} \ No newline at end of file diff --git a/llm_normalizer/data/eval_cases/assistant_autogen_runtime_job-ygtwpBa5EM.json b/llm_normalizer/data/eval_cases/assistant_autogen_runtime_job-ygtwpBa5EM.json new file mode 100644 index 0000000..3729589 --- /dev/null +++ b/llm_normalizer/data/eval_cases/assistant_autogen_runtime_job-ygtwpBa5EM.json @@ -0,0 +1,22 @@ +{ + "suite_id": "assistant_autogen_runtime_job-ygtwpBa5EM", + "suite_version": "0.1.0", + "schema_version": "assistant_autogen_runtime_v0_1", + "scenario_count": 1, + "case_ids": [ + "AUTO-001" + ], + "cases": [ + { + "case_id": "AUTO-001", + "scenario_tag": "autogen_runtime", + "question_type": "direct", + "broadness_level": "medium", + "turns": [ + { + "user_message": "что у нас на складе на март 2017" + } + ] + } + ] +} \ No newline at end of file diff --git a/llm_normalizer/frontend/dist/assets/index-B9mz4jx4.js b/llm_normalizer/frontend/dist/assets/index-B9mz4jx4.js new file mode 100644 index 0000000..1bba361 --- /dev/null +++ b/llm_normalizer/frontend/dist/assets/index-B9mz4jx4.js @@ -0,0 +1,26 @@ +(function(){const p=document.createElement("link").relList;if(p&&p.supports&&p.supports("modulepreload"))return;for(const j of document.querySelectorAll('link[rel="modulepreload"]'))R(j);new MutationObserver(j=>{for(const T of j)if(T.type==="childList")for(const $ of T.addedNodes)$.tagName==="LINK"&&$.rel==="modulepreload"&&R($)}).observe(document,{childList:!0,subtree:!0});function m(j){const T={};return j.integrity&&(T.integrity=j.integrity),j.referrerPolicy&&(T.referrerPolicy=j.referrerPolicy),j.crossOrigin==="use-credentials"?T.credentials="include":j.crossOrigin==="anonymous"?T.credentials="omit":T.credentials="same-origin",T}function R(j){if(j.ep)return;j.ep=!0;const T=m(j);fetch(j.href,T)}})();function Oc(i){return i&&i.__esModule&&Object.prototype.hasOwnProperty.call(i,"default")?i.default:i}var Oi={exports:{}},to={},$i={exports:{}},he={};var mc;function yf(){if(mc)return he;mc=1;var i=Symbol.for("react.element"),p=Symbol.for("react.portal"),m=Symbol.for("react.fragment"),R=Symbol.for("react.strict_mode"),j=Symbol.for("react.profiler"),T=Symbol.for("react.provider"),$=Symbol.for("react.context"),Y=Symbol.for("react.forward_ref"),F=Symbol.for("react.suspense"),I=Symbol.for("react.memo"),W=Symbol.for("react.lazy"),z=Symbol.iterator;function U(h){return h===null||typeof h!="object"?null:(h=z&&h[z]||h["@@iterator"],typeof h=="function"?h:null)}var oe={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},Me=Object.assign,te={};function se(h,C,G){this.props=h,this.context=C,this.refs=te,this.updater=G||oe}se.prototype.isReactComponent={},se.prototype.setState=function(h,C){if(typeof h!="object"&&typeof h!="function"&&h!=null)throw Error("setState(...): takes an object of state variables to update or a function which returns an object of state variables.");this.updater.enqueueSetState(this,h,C,"setState")},se.prototype.forceUpdate=function(h){this.updater.enqueueForceUpdate(this,h,"forceUpdate")};function q(){}q.prototype=se.prototype;function re(h,C,G){this.props=h,this.context=C,this.refs=te,this.updater=G||oe}var Se=re.prototype=new q;Se.constructor=re,Me(Se,se.prototype),Se.isPureReactComponent=!0;var Pe=Array.isArray,Ae=Object.prototype.hasOwnProperty,De={current:null},$e={key:!0,ref:!0,__self:!0,__source:!0};function We(h,C,G){var ae,ce={},de=null,xe=null;if(C!=null)for(ae in C.ref!==void 0&&(xe=C.ref),C.key!==void 0&&(de=""+C.key),C)Ae.call(C,ae)&&!$e.hasOwnProperty(ae)&&(ce[ae]=C[ae]);var ge=arguments.length-2;if(ge===1)ce.children=G;else if(1>>1,C=D[h];if(0>>1;hj(ce,O))dej(xe,ce)?(D[h]=xe,D[de]=O,h=de):(D[h]=ce,D[ae]=O,h=ae);else if(dej(xe,O))D[h]=xe,D[de]=O,h=de;else break e}}return Q}function j(D,Q){var O=D.sortIndex-Q.sortIndex;return O!==0?O:D.id-Q.id}if(typeof performance=="object"&&typeof performance.now=="function"){var T=performance;i.unstable_now=function(){return T.now()}}else{var $=Date,Y=$.now();i.unstable_now=function(){return $.now()-Y}}var F=[],I=[],W=1,z=null,U=3,oe=!1,Me=!1,te=!1,se=typeof setTimeout=="function"?setTimeout:null,q=typeof clearTimeout=="function"?clearTimeout:null,re=typeof setImmediate<"u"?setImmediate:null;typeof navigator<"u"&&navigator.scheduling!==void 0&&navigator.scheduling.isInputPending!==void 0&&navigator.scheduling.isInputPending.bind(navigator.scheduling);function Se(D){for(var Q=m(I);Q!==null;){if(Q.callback===null)R(I);else if(Q.startTime<=D)R(I),Q.sortIndex=Q.expirationTime,p(F,Q);else break;Q=m(I)}}function Pe(D){if(te=!1,Se(D),!Me)if(m(F)!==null)Me=!0,Re(Ae);else{var Q=m(I);Q!==null&&me(Pe,Q.startTime-D)}}function Ae(D,Q){Me=!1,te&&(te=!1,q(We),We=-1),oe=!0;var O=U;try{for(Se(Q),z=m(F);z!==null&&(!(z.expirationTime>Q)||D&&!rt());){var h=z.callback;if(typeof h=="function"){z.callback=null,U=z.priorityLevel;var C=h(z.expirationTime<=Q);Q=i.unstable_now(),typeof C=="function"?z.callback=C:z===m(F)&&R(F),Se(Q)}else R(F);z=m(F)}if(z!==null)var G=!0;else{var ae=m(I);ae!==null&&me(Pe,ae.startTime-Q),G=!1}return G}finally{z=null,U=O,oe=!1}}var De=!1,$e=null,We=-1,Ge=5,Ze=-1;function rt(){return!(i.unstable_now()-ZeD||125h?(D.sortIndex=O,p(I,D),m(F)===null&&D===m(I)&&(te?(q(We),We=-1):te=!0,me(Pe,O-h))):(D.sortIndex=C,p(F,D),Me||oe||(Me=!0,Re(Ae))),D},i.unstable_shouldYield=rt,i.unstable_wrapCallback=function(D){var Q=U;return function(){var O=U;U=Q;try{return D.apply(this,arguments)}finally{U=O}}}})(Bi)),Bi}var yc;function jf(){return yc||(yc=1,Ui.exports=wf()),Ui.exports}var xc;function kf(){if(xc)return $t;xc=1;var i=Yi(),p=jf();function m(e){for(var t="https://reactjs.org/docs/error-decoder.html?invariant="+e,n=1;n"u"||typeof window.document>"u"||typeof window.document.createElement>"u"),F=Object.prototype.hasOwnProperty,I=/^[:A-Z_a-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD][:A-Z_a-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD\-.0-9\u00B7\u0300-\u036F\u203F-\u2040]*$/,W={},z={};function U(e){return F.call(z,e)?!0:F.call(W,e)?!1:I.test(e)?z[e]=!0:(W[e]=!0,!1)}function oe(e,t,n,r){if(n!==null&&n.type===0)return!1;switch(typeof t){case"function":case"symbol":return!0;case"boolean":return r?!1:n!==null?!n.acceptsBooleans:(e=e.toLowerCase().slice(0,5),e!=="data-"&&e!=="aria-");default:return!1}}function Me(e,t,n,r){if(t===null||typeof t>"u"||oe(e,t,n,r))return!0;if(r)return!1;if(n!==null)switch(n.type){case 3:return!t;case 4:return t===!1;case 5:return isNaN(t);case 6:return isNaN(t)||1>t}return!1}function te(e,t,n,r,s,l,u){this.acceptsBooleans=t===2||t===3||t===4,this.attributeName=r,this.attributeNamespace=s,this.mustUseProperty=n,this.propertyName=e,this.type=t,this.sanitizeURL=l,this.removeEmptyString=u}var se={};"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style".split(" ").forEach(function(e){se[e]=new te(e,0,!1,e,null,!1,!1)}),[["acceptCharset","accept-charset"],["className","class"],["htmlFor","for"],["httpEquiv","http-equiv"]].forEach(function(e){var t=e[0];se[t]=new te(t,1,!1,e[1],null,!1,!1)}),["contentEditable","draggable","spellCheck","value"].forEach(function(e){se[e]=new te(e,2,!1,e.toLowerCase(),null,!1,!1)}),["autoReverse","externalResourcesRequired","focusable","preserveAlpha"].forEach(function(e){se[e]=new te(e,2,!1,e,null,!1,!1)}),"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture disableRemotePlayback formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope".split(" ").forEach(function(e){se[e]=new te(e,3,!1,e.toLowerCase(),null,!1,!1)}),["checked","multiple","muted","selected"].forEach(function(e){se[e]=new te(e,3,!0,e,null,!1,!1)}),["capture","download"].forEach(function(e){se[e]=new te(e,4,!1,e,null,!1,!1)}),["cols","rows","size","span"].forEach(function(e){se[e]=new te(e,6,!1,e,null,!1,!1)}),["rowSpan","start"].forEach(function(e){se[e]=new te(e,5,!1,e.toLowerCase(),null,!1,!1)});var q=/[\-:]([a-z])/g;function re(e){return e[1].toUpperCase()}"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height".split(" ").forEach(function(e){var t=e.replace(q,re);se[t]=new te(t,1,!1,e,null,!1,!1)}),"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type".split(" ").forEach(function(e){var t=e.replace(q,re);se[t]=new te(t,1,!1,e,"http://www.w3.org/1999/xlink",!1,!1)}),["xml:base","xml:lang","xml:space"].forEach(function(e){var t=e.replace(q,re);se[t]=new te(t,1,!1,e,"http://www.w3.org/XML/1998/namespace",!1,!1)}),["tabIndex","crossOrigin"].forEach(function(e){se[e]=new te(e,1,!1,e.toLowerCase(),null,!1,!1)}),se.xlinkHref=new te("xlinkHref",1,!1,"xlink:href","http://www.w3.org/1999/xlink",!0,!1),["src","href","action","formAction"].forEach(function(e){se[e]=new te(e,1,!1,e.toLowerCase(),null,!0,!0)});function Se(e,t,n,r){var s=se.hasOwnProperty(t)?se[t]:null;(s!==null?s.type!==0:r||!(2f||s[u]!==l[f]){var g=` +`+s[u].replace(" at new "," at ");return e.displayName&&g.includes("")&&(g=g.replace("",e.displayName)),g}while(1<=u&&0<=f);break}}}finally{G=!1,Error.prepareStackTrace=n}return(e=e?e.displayName||e.name:"")?C(e):""}function ce(e){switch(e.tag){case 5:return C(e.type);case 16:return C("Lazy");case 13:return C("Suspense");case 19:return C("SuspenseList");case 0:case 2:case 15:return e=ae(e.type,!1),e;case 11:return e=ae(e.type.render,!1),e;case 1:return e=ae(e.type,!0),e;default:return""}}function de(e){if(e==null)return null;if(typeof e=="function")return e.displayName||e.name||null;if(typeof e=="string")return e;switch(e){case $e:return"Fragment";case De:return"Portal";case Ge:return"Profiler";case We:return"StrictMode";case Te:return"Suspense";case Fe:return"SuspenseList"}if(typeof e=="object")switch(e.$$typeof){case rt:return(e.displayName||"Context")+".Consumer";case Ze:return(e._context.displayName||"Context")+".Provider";case ie:var t=e.render;return e=e.displayName,e||(e=t.displayName||t.name||"",e=e!==""?"ForwardRef("+e+")":"ForwardRef"),e;case fe:return t=e.displayName||null,t!==null?t:de(e.type)||"Memo";case Re:t=e._payload,e=e._init;try{return de(e(t))}catch{}}return null}function xe(e){var t=e.type;switch(e.tag){case 24:return"Cache";case 9:return(t.displayName||"Context")+".Consumer";case 10:return(t._context.displayName||"Context")+".Provider";case 18:return"DehydratedFragment";case 11:return e=t.render,e=e.displayName||e.name||"",t.displayName||(e!==""?"ForwardRef("+e+")":"ForwardRef");case 7:return"Fragment";case 5:return t;case 4:return"Portal";case 3:return"Root";case 6:return"Text";case 16:return de(t);case 8:return t===We?"StrictMode":"Mode";case 22:return"Offscreen";case 12:return"Profiler";case 21:return"Scope";case 13:return"Suspense";case 19:return"SuspenseList";case 25:return"TracingMarker";case 1:case 0:case 17:case 2:case 14:case 15:if(typeof t=="function")return t.displayName||t.name||null;if(typeof t=="string")return t}return null}function ge(e){switch(typeof e){case"boolean":case"number":case"string":case"undefined":return e;case"object":return e;default:return""}}function ee(e){var t=e.type;return(e=e.nodeName)&&e.toLowerCase()==="input"&&(t==="checkbox"||t==="radio")}function ke(e){var t=ee(e)?"checked":"value",n=Object.getOwnPropertyDescriptor(e.constructor.prototype,t),r=""+e[t];if(!e.hasOwnProperty(t)&&typeof n<"u"&&typeof n.get=="function"&&typeof n.set=="function"){var s=n.get,l=n.set;return Object.defineProperty(e,t,{configurable:!0,get:function(){return s.call(this)},set:function(u){r=""+u,l.call(this,u)}}),Object.defineProperty(e,t,{enumerable:n.enumerable}),{getValue:function(){return r},setValue:function(u){r=""+u},stopTracking:function(){e._valueTracker=null,delete e[t]}}}}function Ft(e){e._valueTracker||(e._valueTracker=ke(e))}function qn(e){if(!e)return!1;var t=e._valueTracker;if(!t)return!0;var n=t.getValue(),r="";return e&&(r=ee(e)?e.checked?"true":"false":e.value),e=r,e!==n?(t.setValue(e),!0):!1}function An(e){if(e=e||(typeof document<"u"?document:void 0),typeof e>"u")return null;try{return e.activeElement||e.body}catch{return e.body}}function Tn(e,t){var n=t.checked;return O({},t,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:n??e._wrapperState.initialChecked})}function dr(e,t){var n=t.defaultValue==null?"":t.defaultValue,r=t.checked!=null?t.checked:t.defaultChecked;n=ge(t.value!=null?t.value:n),e._wrapperState={initialChecked:r,initialValue:n,controlled:t.type==="checkbox"||t.type==="radio"?t.checked!=null:t.value!=null}}function Jt(e,t){t=t.checked,t!=null&&Se(e,"checked",t,!1)}function Yt(e,t){Jt(e,t);var n=ge(t.value),r=t.type;if(n!=null)r==="number"?(n===0&&e.value===""||e.value!=n)&&(e.value=""+n):e.value!==""+n&&(e.value=""+n);else if(r==="submit"||r==="reset"){e.removeAttribute("value");return}t.hasOwnProperty("value")?mn(e,t.type,n):t.hasOwnProperty("defaultValue")&&mn(e,t.type,ge(t.defaultValue)),t.checked==null&&t.defaultChecked!=null&&(e.defaultChecked=!!t.defaultChecked)}function Gn(e,t,n){if(t.hasOwnProperty("value")||t.hasOwnProperty("defaultValue")){var r=t.type;if(!(r!=="submit"&&r!=="reset"||t.value!==void 0&&t.value!==null))return;t=""+e._wrapperState.initialValue,n||t===e.value||(e.value=t),e.defaultValue=t}n=e.name,n!==""&&(e.name=""),e.defaultChecked=!!e._wrapperState.initialChecked,n!==""&&(e.name=n)}function mn(e,t,n){(t!=="number"||An(e.ownerDocument)!==e)&&(n==null?e.defaultValue=""+e._wrapperState.initialValue:e.defaultValue!==""+n&&(e.defaultValue=""+n))}var Ut=Array.isArray;function Xt(e,t,n,r){if(e=e.options,t){t={};for(var s=0;s"+t.valueOf().toString()+"",t=en.firstChild;e.firstChild;)e.removeChild(e.firstChild);for(;t.firstChild;)e.appendChild(t.firstChild)}});function Bt(e,t){if(t){var n=e.firstChild;if(n&&n===e.lastChild&&n.nodeType===3){n.nodeValue=t;return}}e.textContent=t}var hn={animationIterationCount:!0,aspectRatio:!0,borderImageOutset:!0,borderImageSlice:!0,borderImageWidth:!0,boxFlex:!0,boxFlexGroup:!0,boxOrdinalGroup:!0,columnCount:!0,columns:!0,flex:!0,flexGrow:!0,flexPositive:!0,flexShrink:!0,flexNegative:!0,flexOrder:!0,gridArea:!0,gridRow:!0,gridRowEnd:!0,gridRowSpan:!0,gridRowStart:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnSpan:!0,gridColumnStart:!0,fontWeight:!0,lineClamp:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,tabSize:!0,widows:!0,zIndex:!0,zoom:!0,fillOpacity:!0,floodOpacity:!0,stopOpacity:!0,strokeDasharray:!0,strokeDashoffset:!0,strokeMiterlimit:!0,strokeOpacity:!0,strokeWidth:!0},Be=["Webkit","ms","Moz","O"];Object.keys(hn).forEach(function(e){Be.forEach(function(t){t=t+e.charAt(0).toUpperCase()+e.substring(1),hn[t]=hn[e]})});function st(e,t,n){return t==null||typeof t=="boolean"||t===""?"":n||typeof t!="number"||t===0||hn.hasOwnProperty(e)&&hn[e]?(""+t).trim():t+"px"}function gn(e,t){e=e.style;for(var n in t)if(t.hasOwnProperty(n)){var r=n.indexOf("--")===0,s=st(n,t[n],r);n==="float"&&(n="cssFloat"),r?e.setProperty(n,s):e[n]=s}}var vn=O({menuitem:!0},{area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0});function tn(e,t){if(t){if(vn[e]&&(t.children!=null||t.dangerouslySetInnerHTML!=null))throw Error(m(137,e));if(t.dangerouslySetInnerHTML!=null){if(t.children!=null)throw Error(m(60));if(typeof t.dangerouslySetInnerHTML!="object"||!("__html"in t.dangerouslySetInnerHTML))throw Error(m(61))}if(t.style!=null&&typeof t.style!="object")throw Error(m(62))}}function nn(e,t){if(e.indexOf("-")===-1)return typeof t.is=="string";switch(e){case"annotation-xml":case"color-profile":case"font-face":case"font-face-src":case"font-face-uri":case"font-face-format":case"font-face-name":case"missing-glyph":return!1;default:return!0}}var Ct=null;function Dn(e){return e=e.target||e.srcElement||window,e.correspondingUseElement&&(e=e.correspondingUseElement),e.nodeType===3?e.parentNode:e}var rn=null,bt=null,vt=null;function Jn(e){if(e=Us(e)){if(typeof rn!="function")throw Error(m(280));var t=e.stateNode;t&&(t=yo(t),rn(e.stateNode,e.type,t))}}function Ke(e){bt?vt?vt.push(e):vt=[e]:bt=e}function hr(){if(bt){var e=bt,t=vt;if(vt=bt=null,Jn(e),t)for(e=0;e>>=0,e===0?32:31-(Cs(e)/Zr|0)|0}var Xn=64,Bn=4194304;function At(e){switch(e&-e){case 1:return 1;case 2:return 2;case 4:return 4;case 8:return 8;case 16:return 16;case 32:return 32;case 64:case 128:case 256:case 512:case 1024:case 2048:case 4096:case 8192:case 16384:case 32768:case 65536:case 131072:case 262144:case 524288:case 1048576:case 2097152:return e&4194240;case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:return e&130023424;case 134217728:return 134217728;case 268435456:return 268435456;case 536870912:return 536870912;case 1073741824:return 1073741824;default:return e}}function wt(e,t){var n=e.pendingLanes;if(n===0)return 0;var r=0,s=e.suspendedLanes,l=e.pingedLanes,u=n&268435455;if(u!==0){var f=u&~s;f!==0?r=At(f):(l&=u,l!==0&&(r=At(l)))}else u=n&~s,u!==0?r=At(u):l!==0&&(r=At(l));if(r===0)return 0;if(t!==0&&t!==r&&(t&s)===0&&(s=r&-r,l=t&-t,s>=l||s===16&&(l&4194240)!==0))return t;if((r&4)!==0&&(r|=n&16),t=e.entangledLanes,t!==0)for(e=e.entanglements,t&=r;0n;n++)t.push(e);return t}function Ht(e,t,n){e.pendingLanes|=t,t!==536870912&&(e.suspendedLanes=0,e.pingedLanes=0),e=e.eventTimes,t=31-St(t),e[t]=n}function Vt(e,t){var n=e.pendingLanes&~t;e.pendingLanes=t,e.suspendedLanes=0,e.pingedLanes=0,e.expiredLanes&=t,e.mutableReadLanes&=t,e.entangledLanes&=t,t=e.entanglements;var r=e.eventTimes;for(e=e.expirationTimes;0=As),la=" ",ia=!1;function aa(e,t){switch(e){case"keyup":return fd.indexOf(t.keyCode)!==-1;case"keydown":return t.keyCode!==229;case"keypress":case"mousedown":case"focusout":return!0;default:return!1}}function ua(e){return e=e.detail,typeof e=="object"&&"data"in e?e.data:null}var rs=!1;function pd(e,t){switch(e){case"compositionend":return ua(t);case"keypress":return t.which!==32?null:(ia=!0,la);case"textInput":return e=t.data,e===la&&ia?null:e;default:return null}}function hd(e,t){if(rs)return e==="compositionend"||!vl&&aa(e,t)?(e=ea(),lo=dl=Sr=null,rs=!1,e):null;switch(e){case"paste":return null;case"keypress":if(!(t.ctrlKey||t.altKey||t.metaKey)||t.ctrlKey&&t.altKey){if(t.char&&1=t)return{node:n,offset:t-e};e=r}e:{for(;n;){if(n.nextSibling){n=n.nextSibling;break e}n=n.parentNode}n=void 0}n=ga(n)}}function ya(e,t){return e&&t?e===t?!0:e&&e.nodeType===3?!1:t&&t.nodeType===3?ya(e,t.parentNode):"contains"in e?e.contains(t):e.compareDocumentPosition?!!(e.compareDocumentPosition(t)&16):!1:!1}function xa(){for(var e=window,t=An();t instanceof e.HTMLIFrameElement;){try{var n=typeof t.contentWindow.location.href=="string"}catch{n=!1}if(n)e=t.contentWindow;else break;t=An(e.document)}return t}function _l(e){var t=e&&e.nodeName&&e.nodeName.toLowerCase();return t&&(t==="input"&&(e.type==="text"||e.type==="search"||e.type==="tel"||e.type==="url"||e.type==="password")||t==="textarea"||e.contentEditable==="true")}function kd(e){var t=xa(),n=e.focusedElem,r=e.selectionRange;if(t!==n&&n&&n.ownerDocument&&ya(n.ownerDocument.documentElement,n)){if(r!==null&&_l(n)){if(t=r.start,e=r.end,e===void 0&&(e=t),"selectionStart"in n)n.selectionStart=t,n.selectionEnd=Math.min(e,n.value.length);else if(e=(t=n.ownerDocument||document)&&t.defaultView||window,e.getSelection){e=e.getSelection();var s=n.textContent.length,l=Math.min(r.start,s);r=r.end===void 0?l:Math.min(r.end,s),!e.extend&&l>r&&(s=r,r=l,l=s),s=va(n,l);var u=va(n,r);s&&u&&(e.rangeCount!==1||e.anchorNode!==s.node||e.anchorOffset!==s.offset||e.focusNode!==u.node||e.focusOffset!==u.offset)&&(t=t.createRange(),t.setStart(s.node,s.offset),e.removeAllRanges(),l>r?(e.addRange(t),e.extend(u.node,u.offset)):(t.setEnd(u.node,u.offset),e.addRange(t)))}}for(t=[],e=n;e=e.parentNode;)e.nodeType===1&&t.push({element:e,left:e.scrollLeft,top:e.scrollTop});for(typeof n.focus=="function"&&n.focus(),n=0;n=document.documentMode,ss=null,Sl=null,Ds=null,wl=!1;function _a(e,t,n){var r=n.window===n?n.document:n.nodeType===9?n:n.ownerDocument;wl||ss==null||ss!==An(r)||(r=ss,"selectionStart"in r&&_l(r)?r={start:r.selectionStart,end:r.selectionEnd}:(r=(r.ownerDocument&&r.ownerDocument.defaultView||window).getSelection(),r={anchorNode:r.anchorNode,anchorOffset:r.anchorOffset,focusNode:r.focusNode,focusOffset:r.focusOffset}),Ds&&Ls(Ds,r)||(Ds=r,r=ho(Sl,"onSelect"),0us||(e.current=Ll[us],Ll[us]=null,us--)}function Le(e,t){us++,Ll[us]=e.current,e.current=t}var Cr={},ft=kr(Cr),It=kr(!1),Fr=Cr;function cs(e,t){var n=e.type.contextTypes;if(!n)return Cr;var r=e.stateNode;if(r&&r.__reactInternalMemoizedUnmaskedChildContext===t)return r.__reactInternalMemoizedMaskedChildContext;var s={},l;for(l in n)s[l]=t[l];return r&&(e=e.stateNode,e.__reactInternalMemoizedUnmaskedChildContext=t,e.__reactInternalMemoizedMaskedChildContext=s),s}function Lt(e){return e=e.childContextTypes,e!=null}function xo(){Oe(It),Oe(ft)}function Da(e,t,n){if(ft.current!==Cr)throw Error(m(168));Le(ft,t),Le(It,n)}function za(e,t,n){var r=e.stateNode;if(t=t.childContextTypes,typeof r.getChildContext!="function")return n;r=r.getChildContext();for(var s in r)if(!(s in t))throw Error(m(108,xe(e)||"Unknown",s));return O({},n,r)}function _o(e){return e=(e=e.stateNode)&&e.__reactInternalMemoizedMergedChildContext||Cr,Fr=ft.current,Le(ft,e),Le(It,It.current),!0}function Oa(e,t,n){var r=e.stateNode;if(!r)throw Error(m(169));n?(e=za(e,t,Fr),r.__reactInternalMemoizedMergedChildContext=e,Oe(It),Oe(ft),Le(ft,e)):Oe(It),Le(It,n)}var nr=null,So=!1,Dl=!1;function $a(e){nr===null?nr=[e]:nr.push(e)}function zd(e){So=!0,$a(e)}function Nr(){if(!Dl&&nr!==null){Dl=!0;var e=0,t=d;try{var n=nr;for(d=1;e>=u,s-=u,rr=1<<32-St(t)+s|n<ne?(nt=Z,Z=null):nt=Z.sibling;var je=N(_,Z,S[ne],L);if(je===null){Z===null&&(Z=nt);break}e&&Z&&je.alternate===null&&t(_,Z),v=l(je,v,ne),X===null?K=je:X.sibling=je,X=je,Z=nt}if(ne===S.length)return n(_,Z),Ue&&Br(_,ne),K;if(Z===null){for(;nene?(nt=Z,Z=null):nt=Z.sibling;var Dr=N(_,Z,je.value,L);if(Dr===null){Z===null&&(Z=nt);break}e&&Z&&Dr.alternate===null&&t(_,Z),v=l(Dr,v,ne),X===null?K=Dr:X.sibling=Dr,X=Dr,Z=nt}if(je.done)return n(_,Z),Ue&&Br(_,ne),K;if(Z===null){for(;!je.done;ne++,je=S.next())je=M(_,je.value,L),je!==null&&(v=l(je,v,ne),X===null?K=je:X.sibling=je,X=je);return Ue&&Br(_,ne),K}for(Z=r(_,Z);!je.done;ne++,je=S.next())je=B(Z,_,ne,je.value,L),je!==null&&(e&&je.alternate!==null&&Z.delete(je.key===null?ne:je.key),v=l(je,v,ne),X===null?K=je:X.sibling=je,X=je);return e&&Z.forEach(function(vf){return t(_,vf)}),Ue&&Br(_,ne),K}function qe(_,v,S,L){if(typeof S=="object"&&S!==null&&S.type===$e&&S.key===null&&(S=S.props.children),typeof S=="object"&&S!==null){switch(S.$$typeof){case Ae:e:{for(var K=S.key,X=v;X!==null;){if(X.key===K){if(K=S.type,K===$e){if(X.tag===7){n(_,X.sibling),v=s(X,S.props.children),v.return=_,_=v;break e}}else if(X.elementType===K||typeof K=="object"&&K!==null&&K.$$typeof===Re&&Va(K)===X.type){n(_,X.sibling),v=s(X,S.props),v.ref=Bs(_,X,S),v.return=_,_=v;break e}n(_,X);break}else t(_,X);X=X.sibling}S.type===$e?(v=Gr(S.props.children,_.mode,L,S.key),v.return=_,_=v):(L=Go(S.type,S.key,S.props,null,_.mode,L),L.ref=Bs(_,v,S),L.return=_,_=L)}return u(_);case De:e:{for(X=S.key;v!==null;){if(v.key===X)if(v.tag===4&&v.stateNode.containerInfo===S.containerInfo&&v.stateNode.implementation===S.implementation){n(_,v.sibling),v=s(v,S.children||[]),v.return=_,_=v;break e}else{n(_,v);break}else t(_,v);v=v.sibling}v=Ti(S,_.mode,L),v.return=_,_=v}return u(_);case Re:return X=S._init,qe(_,v,X(S._payload),L)}if(Ut(S))return H(_,v,S,L);if(Q(S))return V(_,v,S,L);Co(_,S)}return typeof S=="string"&&S!==""||typeof S=="number"?(S=""+S,v!==null&&v.tag===6?(n(_,v.sibling),v=s(v,S),v.return=_,_=v):(n(_,v),v=Ai(S,_.mode,L),v.return=_,_=v),u(_)):n(_,v)}return qe}var ps=Qa(!0),Wa=Qa(!1),No=kr(null),Eo=null,hs=null,Bl=null;function bl(){Bl=hs=Eo=null}function Hl(e){var t=No.current;Oe(No),e._currentValue=t}function Vl(e,t,n){for(;e!==null;){var r=e.alternate;if((e.childLanes&t)!==t?(e.childLanes|=t,r!==null&&(r.childLanes|=t)):r!==null&&(r.childLanes&t)!==t&&(r.childLanes|=t),e===n)break;e=e.return}}function gs(e,t){Eo=e,Bl=hs=null,e=e.dependencies,e!==null&&e.firstContext!==null&&((e.lanes&t)!==0&&(Dt=!0),e.firstContext=null)}function un(e){var t=e._currentValue;if(Bl!==e)if(e={context:e,memoizedValue:t,next:null},hs===null){if(Eo===null)throw Error(m(308));hs=e,Eo.dependencies={lanes:0,firstContext:e}}else hs=hs.next=e;return t}var br=null;function Ql(e){br===null?br=[e]:br.push(e)}function Ka(e,t,n,r){var s=t.interleaved;return s===null?(n.next=n,Ql(t)):(n.next=s.next,s.next=n),t.interleaved=n,or(e,r)}function or(e,t){e.lanes|=t;var n=e.alternate;for(n!==null&&(n.lanes|=t),n=e,e=e.return;e!==null;)e.childLanes|=t,n=e.alternate,n!==null&&(n.childLanes|=t),n=e,e=e.return;return n.tag===3?n.stateNode:null}var Er=!1;function Wl(e){e.updateQueue={baseState:e.memoizedState,firstBaseUpdate:null,lastBaseUpdate:null,shared:{pending:null,interleaved:null,lanes:0},effects:null}}function qa(e,t){e=e.updateQueue,t.updateQueue===e&&(t.updateQueue={baseState:e.baseState,firstBaseUpdate:e.firstBaseUpdate,lastBaseUpdate:e.lastBaseUpdate,shared:e.shared,effects:e.effects})}function lr(e,t){return{eventTime:e,lane:t,tag:0,payload:null,callback:null,next:null}}function Pr(e,t,n){var r=e.updateQueue;if(r===null)return null;if(r=r.shared,(_e&2)!==0){var s=r.pending;return s===null?t.next=t:(t.next=s.next,s.next=t),r.pending=t,or(e,n)}return s=r.interleaved,s===null?(t.next=t,Ql(r)):(t.next=s.next,s.next=t),r.interleaved=t,or(e,n)}function Po(e,t,n){if(t=t.updateQueue,t!==null&&(t=t.shared,(n&4194240)!==0)){var r=t.lanes;r&=e.pendingLanes,n|=r,t.lanes=n,Zn(e,n)}}function Ga(e,t){var n=e.updateQueue,r=e.alternate;if(r!==null&&(r=r.updateQueue,n===r)){var s=null,l=null;if(n=n.firstBaseUpdate,n!==null){do{var u={eventTime:n.eventTime,lane:n.lane,tag:n.tag,payload:n.payload,callback:n.callback,next:null};l===null?s=l=u:l=l.next=u,n=n.next}while(n!==null);l===null?s=l=t:l=l.next=t}else s=l=t;n={baseState:r.baseState,firstBaseUpdate:s,lastBaseUpdate:l,shared:r.shared,effects:r.effects},e.updateQueue=n;return}e=n.lastBaseUpdate,e===null?n.firstBaseUpdate=t:e.next=t,n.lastBaseUpdate=t}function Ro(e,t,n,r){var s=e.updateQueue;Er=!1;var l=s.firstBaseUpdate,u=s.lastBaseUpdate,f=s.shared.pending;if(f!==null){s.shared.pending=null;var g=f,w=g.next;g.next=null,u===null?l=w:u.next=w,u=g;var E=e.alternate;E!==null&&(E=E.updateQueue,f=E.lastBaseUpdate,f!==u&&(f===null?E.firstBaseUpdate=w:f.next=w,E.lastBaseUpdate=g))}if(l!==null){var M=s.baseState;u=0,E=w=g=null,f=l;do{var N=f.lane,B=f.eventTime;if((r&N)===N){E!==null&&(E=E.next={eventTime:B,lane:0,tag:f.tag,payload:f.payload,callback:f.callback,next:null});e:{var H=e,V=f;switch(N=t,B=n,V.tag){case 1:if(H=V.payload,typeof H=="function"){M=H.call(B,M,N);break e}M=H;break e;case 3:H.flags=H.flags&-65537|128;case 0:if(H=V.payload,N=typeof H=="function"?H.call(B,M,N):H,N==null)break e;M=O({},M,N);break e;case 2:Er=!0}}f.callback!==null&&f.lane!==0&&(e.flags|=64,N=s.effects,N===null?s.effects=[f]:N.push(f))}else B={eventTime:B,lane:N,tag:f.tag,payload:f.payload,callback:f.callback,next:null},E===null?(w=E=B,g=M):E=E.next=B,u|=N;if(f=f.next,f===null){if(f=s.shared.pending,f===null)break;N=f,f=N.next,N.next=null,s.lastBaseUpdate=N,s.shared.pending=null}}while(!0);if(E===null&&(g=M),s.baseState=g,s.firstBaseUpdate=w,s.lastBaseUpdate=E,t=s.shared.interleaved,t!==null){s=t;do u|=s.lane,s=s.next;while(s!==t)}else l===null&&(s.shared.lanes=0);Qr|=u,e.lanes=u,e.memoizedState=M}}function Ja(e,t,n){if(e=t.effects,t.effects=null,e!==null)for(t=0;tn?n:4,e(!0);var r=Yl.transition;Yl.transition={};try{e(!1),t()}finally{d=n,Yl.transition=r}}function hu(){return cn().memoizedState}function Ud(e,t,n){var r=Tr(e);if(n={lane:r,action:n,hasEagerState:!1,eagerState:null,next:null},gu(e))vu(t,n);else if(n=Ka(e,t,n,r),n!==null){var s=kt();Rn(n,e,r,s),yu(n,t,r)}}function Bd(e,t,n){var r=Tr(e),s={lane:r,action:n,hasEagerState:!1,eagerState:null,next:null};if(gu(e))vu(t,s);else{var l=e.alternate;if(e.lanes===0&&(l===null||l.lanes===0)&&(l=t.lastRenderedReducer,l!==null))try{var u=t.lastRenderedState,f=l(u,n);if(s.hasEagerState=!0,s.eagerState=f,kn(f,u)){var g=t.interleaved;g===null?(s.next=s,Ql(t)):(s.next=g.next,g.next=s),t.interleaved=s;return}}catch{}n=Ka(e,t,s,r),n!==null&&(s=kt(),Rn(n,e,r,s),yu(n,t,r))}}function gu(e){var t=e.alternate;return e===Ve||t!==null&&t===Ve}function vu(e,t){Qs=To=!0;var n=e.pending;n===null?t.next=t:(t.next=n.next,n.next=t),e.pending=t}function yu(e,t,n){if((n&4194240)!==0){var r=t.lanes;r&=e.pendingLanes,n|=r,t.lanes=n,Zn(e,n)}}var Do={readContext:un,useCallback:mt,useContext:mt,useEffect:mt,useImperativeHandle:mt,useInsertionEffect:mt,useLayoutEffect:mt,useMemo:mt,useReducer:mt,useRef:mt,useState:mt,useDebugValue:mt,useDeferredValue:mt,useTransition:mt,useMutableSource:mt,useSyncExternalStore:mt,useId:mt,unstable_isNewReconciler:!1},bd={readContext:un,useCallback:function(e,t){return Wn().memoizedState=[e,t===void 0?null:t],e},useContext:un,useEffect:iu,useImperativeHandle:function(e,t,n){return n=n!=null?n.concat([e]):null,Io(4194308,4,cu.bind(null,t,e),n)},useLayoutEffect:function(e,t){return Io(4194308,4,e,t)},useInsertionEffect:function(e,t){return Io(4,2,e,t)},useMemo:function(e,t){var n=Wn();return t=t===void 0?null:t,e=e(),n.memoizedState=[e,t],e},useReducer:function(e,t,n){var r=Wn();return t=n!==void 0?n(t):t,r.memoizedState=r.baseState=t,e={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:e,lastRenderedState:t},r.queue=e,e=e.dispatch=Ud.bind(null,Ve,e),[r.memoizedState,e]},useRef:function(e){var t=Wn();return e={current:e},t.memoizedState=e},useState:ou,useDebugValue:si,useDeferredValue:function(e){return Wn().memoizedState=e},useTransition:function(){var e=ou(!1),t=e[0];return e=Fd.bind(null,e[1]),Wn().memoizedState=e,[t,e]},useMutableSource:function(){},useSyncExternalStore:function(e,t,n){var r=Ve,s=Wn();if(Ue){if(n===void 0)throw Error(m(407));n=n()}else{if(n=t(),tt===null)throw Error(m(349));(Vr&30)!==0||eu(r,t,n)}s.memoizedState=n;var l={value:n,getSnapshot:t};return s.queue=l,iu(nu.bind(null,r,l,e),[e]),r.flags|=2048,qs(9,tu.bind(null,r,l,n,t),void 0,null),n},useId:function(){var e=Wn(),t=tt.identifierPrefix;if(Ue){var n=sr,r=rr;n=(r&~(1<<32-St(r)-1)).toString(32)+n,t=":"+t+"R"+n,n=Ws++,0<\/script>",e=e.removeChild(e.firstChild)):typeof r.is=="string"?e=u.createElement(n,{is:r.is}):(e=u.createElement(n),n==="select"&&(u=e,r.multiple?u.multiple=!0:r.size&&(u.size=r.size))):e=u.createElementNS(e,n),e[Vn]=t,e[Fs]=r,$u(e,t,!1,!1),t.stateNode=e;e:{switch(u=nn(n,r),n){case"dialog":ze("cancel",e),ze("close",e),s=r;break;case"iframe":case"object":case"embed":ze("load",e),s=r;break;case"video":case"audio":for(s=0;sSs&&(t.flags|=128,r=!0,Gs(l,!1),t.lanes=4194304)}else{if(!r)if(e=Mo(u),e!==null){if(t.flags|=128,r=!0,n=e.updateQueue,n!==null&&(t.updateQueue=n,t.flags|=4),Gs(l,!0),l.tail===null&&l.tailMode==="hidden"&&!u.alternate&&!Ue)return pt(t),null}else 2*Ie()-l.renderingStartTime>Ss&&n!==1073741824&&(t.flags|=128,r=!0,Gs(l,!1),t.lanes=4194304);l.isBackwards?(u.sibling=t.child,t.child=u):(n=l.last,n!==null?n.sibling=u:t.child=u,l.last=u)}return l.tail!==null?(t=l.tail,l.rendering=t,l.tail=t.sibling,l.renderingStartTime=Ie(),t.sibling=null,n=He.current,Le(He,r?n&1|2:n&1),t):(pt(t),null);case 22:case 23:return Pi(),r=t.memoizedState!==null,e!==null&&e.memoizedState!==null!==r&&(t.flags|=8192),r&&(t.mode&1)!==0?(qt&1073741824)!==0&&(pt(t),t.subtreeFlags&6&&(t.flags|=8192)):pt(t),null;case 24:return null;case 25:return null}throw Error(m(156,t.tag))}function Jd(e,t){switch(Ol(t),t.tag){case 1:return Lt(t.type)&&xo(),e=t.flags,e&65536?(t.flags=e&-65537|128,t):null;case 3:return vs(),Oe(It),Oe(ft),Jl(),e=t.flags,(e&65536)!==0&&(e&128)===0?(t.flags=e&-65537|128,t):null;case 5:return ql(t),null;case 13:if(Oe(He),e=t.memoizedState,e!==null&&e.dehydrated!==null){if(t.alternate===null)throw Error(m(340));ms()}return e=t.flags,e&65536?(t.flags=e&-65537|128,t):null;case 19:return Oe(He),null;case 4:return vs(),null;case 10:return Hl(t.type._context),null;case 22:case 23:return Pi(),null;case 24:return null;default:return null}}var Fo=!1,ht=!1,Yd=typeof WeakSet=="function"?WeakSet:Set,b=null;function xs(e,t){var n=e.ref;if(n!==null)if(typeof n=="function")try{n(null)}catch(r){Qe(e,t,r)}else n.current=null}function gi(e,t,n){try{n()}catch(r){Qe(e,t,r)}}var Bu=!1;function Xd(e,t){if(Pl=so,e=xa(),_l(e)){if("selectionStart"in e)var n={start:e.selectionStart,end:e.selectionEnd};else e:{n=(n=e.ownerDocument)&&n.defaultView||window;var r=n.getSelection&&n.getSelection();if(r&&r.rangeCount!==0){n=r.anchorNode;var s=r.anchorOffset,l=r.focusNode;r=r.focusOffset;try{n.nodeType,l.nodeType}catch{n=null;break e}var u=0,f=-1,g=-1,w=0,E=0,M=e,N=null;t:for(;;){for(var B;M!==n||s!==0&&M.nodeType!==3||(f=u+s),M!==l||r!==0&&M.nodeType!==3||(g=u+r),M.nodeType===3&&(u+=M.nodeValue.length),(B=M.firstChild)!==null;)N=M,M=B;for(;;){if(M===e)break t;if(N===n&&++w===s&&(f=u),N===l&&++E===r&&(g=u),(B=M.nextSibling)!==null)break;M=N,N=M.parentNode}M=B}n=f===-1||g===-1?null:{start:f,end:g}}else n=null}n=n||{start:0,end:0}}else n=null;for(Rl={focusedElem:e,selectionRange:n},so=!1,b=t;b!==null;)if(t=b,e=t.child,(t.subtreeFlags&1028)!==0&&e!==null)e.return=t,b=e;else for(;b!==null;){t=b;try{var H=t.alternate;if((t.flags&1024)!==0)switch(t.tag){case 0:case 11:case 15:break;case 1:if(H!==null){var V=H.memoizedProps,qe=H.memoizedState,_=t.stateNode,v=_.getSnapshotBeforeUpdate(t.elementType===t.type?V:Nn(t.type,V),qe);_.__reactInternalSnapshotBeforeUpdate=v}break;case 3:var S=t.stateNode.containerInfo;S.nodeType===1?S.textContent="":S.nodeType===9&&S.documentElement&&S.removeChild(S.documentElement);break;case 5:case 6:case 4:case 17:break;default:throw Error(m(163))}}catch(L){Qe(t,t.return,L)}if(e=t.sibling,e!==null){e.return=t.return,b=e;break}b=t.return}return H=Bu,Bu=!1,H}function Js(e,t,n){var r=t.updateQueue;if(r=r!==null?r.lastEffect:null,r!==null){var s=r=r.next;do{if((s.tag&e)===e){var l=s.destroy;s.destroy=void 0,l!==void 0&&gi(t,n,l)}s=s.next}while(s!==r)}}function Uo(e,t){if(t=t.updateQueue,t=t!==null?t.lastEffect:null,t!==null){var n=t=t.next;do{if((n.tag&e)===e){var r=n.create;n.destroy=r()}n=n.next}while(n!==t)}}function vi(e){var t=e.ref;if(t!==null){var n=e.stateNode;e.tag,e=n,typeof t=="function"?t(e):t.current=e}}function bu(e){var t=e.alternate;t!==null&&(e.alternate=null,bu(t)),e.child=null,e.deletions=null,e.sibling=null,e.tag===5&&(t=e.stateNode,t!==null&&(delete t[Vn],delete t[Fs],delete t[Il],delete t[Ld],delete t[Dd])),e.stateNode=null,e.return=null,e.dependencies=null,e.memoizedProps=null,e.memoizedState=null,e.pendingProps=null,e.stateNode=null,e.updateQueue=null}function Hu(e){return e.tag===5||e.tag===3||e.tag===4}function Vu(e){e:for(;;){for(;e.sibling===null;){if(e.return===null||Hu(e.return))return null;e=e.return}for(e.sibling.return=e.return,e=e.sibling;e.tag!==5&&e.tag!==6&&e.tag!==18;){if(e.flags&2||e.child===null||e.tag===4)continue e;e.child.return=e,e=e.child}if(!(e.flags&2))return e.stateNode}}function yi(e,t,n){var r=e.tag;if(r===5||r===6)e=e.stateNode,t?n.nodeType===8?n.parentNode.insertBefore(e,t):n.insertBefore(e,t):(n.nodeType===8?(t=n.parentNode,t.insertBefore(e,n)):(t=n,t.appendChild(e)),n=n._reactRootContainer,n!=null||t.onclick!==null||(t.onclick=vo));else if(r!==4&&(e=e.child,e!==null))for(yi(e,t,n),e=e.sibling;e!==null;)yi(e,t,n),e=e.sibling}function xi(e,t,n){var r=e.tag;if(r===5||r===6)e=e.stateNode,t?n.insertBefore(e,t):n.appendChild(e);else if(r!==4&&(e=e.child,e!==null))for(xi(e,t,n),e=e.sibling;e!==null;)xi(e,t,n),e=e.sibling}var it=null,En=!1;function Rr(e,t,n){for(n=n.child;n!==null;)Qu(e,t,n),n=n.sibling}function Qu(e,t,n){if(ct&&typeof ct.onCommitFiberUnmount=="function")try{ct.onCommitFiberUnmount(Mt,n)}catch{}switch(n.tag){case 5:ht||xs(n,t);case 6:var r=it,s=En;it=null,Rr(e,t,n),it=r,En=s,it!==null&&(En?(e=it,n=n.stateNode,e.nodeType===8?e.parentNode.removeChild(n):e.removeChild(n)):it.removeChild(n.stateNode));break;case 18:it!==null&&(En?(e=it,n=n.stateNode,e.nodeType===8?Tl(e.parentNode,n):e.nodeType===1&&Tl(e,n),Ps(e)):Tl(it,n.stateNode));break;case 4:r=it,s=En,it=n.stateNode.containerInfo,En=!0,Rr(e,t,n),it=r,En=s;break;case 0:case 11:case 14:case 15:if(!ht&&(r=n.updateQueue,r!==null&&(r=r.lastEffect,r!==null))){s=r=r.next;do{var l=s,u=l.destroy;l=l.tag,u!==void 0&&((l&2)!==0||(l&4)!==0)&&gi(n,t,u),s=s.next}while(s!==r)}Rr(e,t,n);break;case 1:if(!ht&&(xs(n,t),r=n.stateNode,typeof r.componentWillUnmount=="function"))try{r.props=n.memoizedProps,r.state=n.memoizedState,r.componentWillUnmount()}catch(f){Qe(n,t,f)}Rr(e,t,n);break;case 21:Rr(e,t,n);break;case 22:n.mode&1?(ht=(r=ht)||n.memoizedState!==null,Rr(e,t,n),ht=r):Rr(e,t,n);break;default:Rr(e,t,n)}}function Wu(e){var t=e.updateQueue;if(t!==null){e.updateQueue=null;var n=e.stateNode;n===null&&(n=e.stateNode=new Yd),t.forEach(function(r){var s=af.bind(null,e,r);n.has(r)||(n.add(r),r.then(s,s))})}}function Pn(e,t){var n=t.deletions;if(n!==null)for(var r=0;rs&&(s=u),r&=~l}if(r=s,r=Ie()-r,r=(120>r?120:480>r?480:1080>r?1080:1920>r?1920:3e3>r?3e3:4320>r?4320:1960*ef(r/1960))-r,10e?16:e,Ar===null)var r=!1;else{if(e=Ar,Ar=null,Qo=0,(_e&6)!==0)throw Error(m(331));var s=_e;for(_e|=4,b=e.current;b!==null;){var l=b,u=l.child;if((b.flags&16)!==0){var f=l.deletions;if(f!==null){for(var g=0;gIe()-wi?Kr(e,0):Si|=n),Ot(e,t)}function oc(e,t){t===0&&((e.mode&1)===0?t=1:(t=Bn,Bn<<=1,(Bn&130023424)===0&&(Bn=4194304)));var n=kt();e=or(e,t),e!==null&&(Ht(e,t,n),Ot(e,n))}function lf(e){var t=e.memoizedState,n=0;t!==null&&(n=t.retryLane),oc(e,n)}function af(e,t){var n=0;switch(e.tag){case 13:var r=e.stateNode,s=e.memoizedState;s!==null&&(n=s.retryLane);break;case 19:r=e.stateNode;break;default:throw Error(m(314))}r!==null&&r.delete(t),oc(e,n)}var lc;lc=function(e,t,n){if(e!==null)if(e.memoizedProps!==t.pendingProps||It.current)Dt=!0;else{if((e.lanes&n)===0&&(t.flags&128)===0)return Dt=!1,qd(e,t,n);Dt=(e.flags&131072)!==0}else Dt=!1,Ue&&(t.flags&1048576)!==0&&Fa(t,jo,t.index);switch(t.lanes=0,t.tag){case 2:var r=t.type;$o(e,t),e=t.pendingProps;var s=cs(t,ft.current);gs(t,n),s=Zl(null,t,r,e,s,n);var l=ei();return t.flags|=1,typeof s=="object"&&s!==null&&typeof s.render=="function"&&s.$$typeof===void 0?(t.tag=1,t.memoizedState=null,t.updateQueue=null,Lt(r)?(l=!0,_o(t)):l=!1,t.memoizedState=s.state!==null&&s.state!==void 0?s.state:null,Wl(t),s.updater=zo,t.stateNode=s,s._reactInternals=t,li(t,r,e,n),t=ci(null,t,r,!0,l,n)):(t.tag=0,Ue&&l&&zl(t),jt(null,t,s,n),t=t.child),t;case 16:r=t.elementType;e:{switch($o(e,t),e=t.pendingProps,s=r._init,r=s(r._payload),t.type=r,s=t.tag=cf(r),e=Nn(r,e),s){case 0:t=ui(null,t,r,e,n);break e;case 1:t=Tu(null,t,r,e,n);break e;case 11:t=Eu(null,t,r,e,n);break e;case 14:t=Pu(null,t,r,Nn(r.type,e),n);break e}throw Error(m(306,r,""))}return t;case 0:return r=t.type,s=t.pendingProps,s=t.elementType===r?s:Nn(r,s),ui(e,t,r,s,n);case 1:return r=t.type,s=t.pendingProps,s=t.elementType===r?s:Nn(r,s),Tu(e,t,r,s,n);case 3:e:{if(Iu(t),e===null)throw Error(m(387));r=t.pendingProps,l=t.memoizedState,s=l.element,qa(e,t),Ro(t,r,null,n);var u=t.memoizedState;if(r=u.element,l.isDehydrated)if(l={element:r,isDehydrated:!1,cache:u.cache,pendingSuspenseBoundaries:u.pendingSuspenseBoundaries,transitions:u.transitions},t.updateQueue.baseState=l,t.memoizedState=l,t.flags&256){s=ys(Error(m(423)),t),t=Lu(e,t,r,n,s);break e}else if(r!==s){s=ys(Error(m(424)),t),t=Lu(e,t,r,n,s);break e}else for(Kt=jr(t.stateNode.containerInfo.firstChild),Wt=t,Ue=!0,Cn=null,n=Wa(t,null,r,n),t.child=n;n;)n.flags=n.flags&-3|4096,n=n.sibling;else{if(ms(),r===s){t=ir(e,t,n);break e}jt(e,t,r,n)}t=t.child}return t;case 5:return Ya(t),e===null&&Fl(t),r=t.type,s=t.pendingProps,l=e!==null?e.memoizedProps:null,u=s.children,Ml(r,s)?u=null:l!==null&&Ml(r,l)&&(t.flags|=32),Au(e,t),jt(e,t,u,n),t.child;case 6:return e===null&&Fl(t),null;case 13:return Du(e,t,n);case 4:return Kl(t,t.stateNode.containerInfo),r=t.pendingProps,e===null?t.child=ps(t,null,r,n):jt(e,t,r,n),t.child;case 11:return r=t.type,s=t.pendingProps,s=t.elementType===r?s:Nn(r,s),Eu(e,t,r,s,n);case 7:return jt(e,t,t.pendingProps,n),t.child;case 8:return jt(e,t,t.pendingProps.children,n),t.child;case 12:return jt(e,t,t.pendingProps.children,n),t.child;case 10:e:{if(r=t.type._context,s=t.pendingProps,l=t.memoizedProps,u=s.value,Le(No,r._currentValue),r._currentValue=u,l!==null)if(kn(l.value,u)){if(l.children===s.children&&!It.current){t=ir(e,t,n);break e}}else for(l=t.child,l!==null&&(l.return=t);l!==null;){var f=l.dependencies;if(f!==null){u=l.child;for(var g=f.firstContext;g!==null;){if(g.context===r){if(l.tag===1){g=lr(-1,n&-n),g.tag=2;var w=l.updateQueue;if(w!==null){w=w.shared;var E=w.pending;E===null?g.next=g:(g.next=E.next,E.next=g),w.pending=g}}l.lanes|=n,g=l.alternate,g!==null&&(g.lanes|=n),Vl(l.return,n,t),f.lanes|=n;break}g=g.next}}else if(l.tag===10)u=l.type===t.type?null:l.child;else if(l.tag===18){if(u=l.return,u===null)throw Error(m(341));u.lanes|=n,f=u.alternate,f!==null&&(f.lanes|=n),Vl(u,n,t),u=l.sibling}else u=l.child;if(u!==null)u.return=l;else for(u=l;u!==null;){if(u===t){u=null;break}if(l=u.sibling,l!==null){l.return=u.return,u=l;break}u=u.return}l=u}jt(e,t,s.children,n),t=t.child}return t;case 9:return s=t.type,r=t.pendingProps.children,gs(t,n),s=un(s),r=r(s),t.flags|=1,jt(e,t,r,n),t.child;case 14:return r=t.type,s=Nn(r,t.pendingProps),s=Nn(r.type,s),Pu(e,t,r,s,n);case 15:return Ru(e,t,t.type,t.pendingProps,n);case 17:return r=t.type,s=t.pendingProps,s=t.elementType===r?s:Nn(r,s),$o(e,t),t.tag=1,Lt(r)?(e=!0,_o(t)):e=!1,gs(t,n),_u(t,r,s),li(t,r,s,n),ci(null,t,r,!0,e,n);case 19:return Ou(e,t,n);case 22:return Mu(e,t,n)}throw Error(m(156,t.tag))};function ic(e,t){return Ne(e,t)}function uf(e,t,n,r){this.tag=e,this.key=n,this.sibling=this.child=this.return=this.stateNode=this.type=this.elementType=null,this.index=0,this.ref=null,this.pendingProps=t,this.dependencies=this.memoizedState=this.updateQueue=this.memoizedProps=null,this.mode=r,this.subtreeFlags=this.flags=0,this.deletions=null,this.childLanes=this.lanes=0,this.alternate=null}function fn(e,t,n,r){return new uf(e,t,n,r)}function Mi(e){return e=e.prototype,!(!e||!e.isReactComponent)}function cf(e){if(typeof e=="function")return Mi(e)?1:0;if(e!=null){if(e=e.$$typeof,e===ie)return 11;if(e===fe)return 14}return 2}function Lr(e,t){var n=e.alternate;return n===null?(n=fn(e.tag,t,e.key,e.mode),n.elementType=e.elementType,n.type=e.type,n.stateNode=e.stateNode,n.alternate=e,e.alternate=n):(n.pendingProps=t,n.type=e.type,n.flags=0,n.subtreeFlags=0,n.deletions=null),n.flags=e.flags&14680064,n.childLanes=e.childLanes,n.lanes=e.lanes,n.child=e.child,n.memoizedProps=e.memoizedProps,n.memoizedState=e.memoizedState,n.updateQueue=e.updateQueue,t=e.dependencies,n.dependencies=t===null?null:{lanes:t.lanes,firstContext:t.firstContext},n.sibling=e.sibling,n.index=e.index,n.ref=e.ref,n}function Go(e,t,n,r,s,l){var u=2;if(r=e,typeof e=="function")Mi(e)&&(u=1);else if(typeof e=="string")u=5;else e:switch(e){case $e:return Gr(n.children,s,l,t);case We:u=8,s|=8;break;case Ge:return e=fn(12,n,t,s|2),e.elementType=Ge,e.lanes=l,e;case Te:return e=fn(13,n,t,s),e.elementType=Te,e.lanes=l,e;case Fe:return e=fn(19,n,t,s),e.elementType=Fe,e.lanes=l,e;case me:return Jo(n,s,l,t);default:if(typeof e=="object"&&e!==null)switch(e.$$typeof){case Ze:u=10;break e;case rt:u=9;break e;case ie:u=11;break e;case fe:u=14;break e;case Re:u=16,r=null;break e}throw Error(m(130,e==null?e:typeof e,""))}return t=fn(u,n,t,s),t.elementType=e,t.type=r,t.lanes=l,t}function Gr(e,t,n,r){return e=fn(7,e,r,t),e.lanes=n,e}function Jo(e,t,n,r){return e=fn(22,e,r,t),e.elementType=me,e.lanes=n,e.stateNode={isHidden:!1},e}function Ai(e,t,n){return e=fn(6,e,null,t),e.lanes=n,e}function Ti(e,t,n){return t=fn(4,e.children!==null?e.children:[],e.key,t),t.lanes=n,t.stateNode={containerInfo:e.containerInfo,pendingChildren:null,implementation:e.implementation},t}function df(e,t,n,r,s){this.tag=t,this.containerInfo=e,this.finishedWork=this.pingCache=this.current=this.pendingChildren=null,this.timeoutHandle=-1,this.callbackNode=this.pendingContext=this.context=null,this.callbackPriority=0,this.eventTimes=Tt(0),this.expirationTimes=Tt(-1),this.entangledLanes=this.finishedLanes=this.mutableReadLanes=this.expiredLanes=this.pingedLanes=this.suspendedLanes=this.pendingLanes=0,this.entanglements=Tt(0),this.identifierPrefix=r,this.onRecoverableError=s,this.mutableSourceEagerHydrationData=null}function Ii(e,t,n,r,s,l,u,f,g){return e=new df(e,t,n,f,g),t===1?(t=1,l===!0&&(t|=8)):t=0,l=fn(3,null,null,t),e.current=l,l.stateNode=e,l.memoizedState={element:r,isDehydrated:n,cache:null,transitions:null,pendingSuspenseBoundaries:null},Wl(l),e}function ff(e,t,n){var r=3"u"||typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE!="function"))try{__REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(i)}catch(p){console.error(p)}}return i(),Fi.exports=kf(),Fi.exports}var Sc;function Nf(){if(Sc)return rl;Sc=1;var i=Cf();return rl.createRoot=i.createRoot,rl.hydrateRoot=i.hydrateRoot,rl}var Ef=Nf();const Pf=Oc(Ef),Rf="/api";async function Ee(i,p){const m=await fetch(`${Rf}${i}`,{...p,headers:{"Content-Type":"application/json",...p?.headers??{}}}),R=await m.json();if(!m.ok){const j=R.error?.message??"Ошибка запроса";throw new Error(j)}return R}const Ce={async listModels(i){return Ee("/llm/models",{method:"POST",body:JSON.stringify({llmProvider:i.llmProvider,apiKey:i.apiKey,model:i.model,baseUrl:i.baseUrl})})},async testConnection(i){return Ee("/llm/test-connection",{method:"POST",body:JSON.stringify({llmProvider:i.llmProvider,apiKey:i.apiKey,model:i.model,baseUrl:i.baseUrl})})},async normalize(i){return Ee("/normalize",{method:"POST",body:JSON.stringify({llmProvider:i.connection.llmProvider,apiKey:i.connection.apiKey,model:i.connection.model,baseUrl:i.connection.baseUrl,temperature:i.connection.temperature,maxOutputTokens:i.connection.maxOutputTokens,promptVersion:i.promptVersion,systemPrompt:i.prompts.systemPrompt,developerPrompt:i.prompts.developerPrompt,domainPrompt:i.prompts.domainPrompt,fewShotExamples:i.prompts.fewShotExamples,userQuestion:i.query.userQuestion,context:{period_hint:i.query.periodHint??"",business_context:i.query.businessContext??"",expected_route:i.query.expectedRoute??""},saveAsTestCase:!!i.saveAsTestCase,useMock:!!i.useMock})})},async loadHistory(){return Ee("/history")},async loadTrace(i){return Ee(`/history/${i}`)},async loadPresets(){return Ee("/presets")},async savePreset(i){return Ee("/presets/save",{method:"POST",body:JSON.stringify(i)})},async runEval(i){return Ee("/eval/run",{method:"POST",body:JSON.stringify({normalizeConfig:{llmProvider:i.connection.llmProvider,apiKey:i.connection.apiKey,model:i.connection.model,baseUrl:i.connection.baseUrl,temperature:i.connection.temperature,maxOutputTokens:i.connection.maxOutputTokens,promptVersion:i.promptVersion,systemPrompt:i.prompts.systemPrompt,developerPrompt:i.prompts.developerPrompt,domainPrompt:i.prompts.domainPrompt,fewShotExamples:i.prompts.fewShotExamples},caseIds:i.caseIds,useMock:!!i.useMock,mode:i.mode??"standard",caseSetFile:i.caseSetFile,rawQuestions:i.rawQuestions,eval_target:i.evalTarget,compare_with_report_file:i.compareWithReportFile,analysis_date:i.analysisDate})})},async startEvalRunAsync(i){return Ee("/eval/run-async/start",{method:"POST",body:JSON.stringify({normalizeConfig:{llmProvider:i.connection.llmProvider,apiKey:i.connection.apiKey,model:i.connection.model,baseUrl:i.connection.baseUrl,temperature:i.connection.temperature,maxOutputTokens:i.connection.maxOutputTokens,promptVersion:i.promptVersion,systemPrompt:i.prompts.systemPrompt,developerPrompt:i.prompts.developerPrompt,domainPrompt:i.prompts.domainPrompt,fewShotExamples:i.prompts.fewShotExamples},caseIds:i.caseIds,useMock:!!i.useMock,mode:i.mode??"standard",caseSetFile:i.caseSetFile,rawQuestions:i.rawQuestions,eval_target:i.evalTarget,compare_with_report_file:i.compareWithReportFile,questions:i.questions,analysis_date:i.analysisDate})})},async loadEvalRunAsyncStatus(i){return Ee(`/eval/run-async/${encodeURIComponent(i)}`)},async startRun(){return Ee("/accounting-agent/v1/runs/start",{method:"POST",body:JSON.stringify({initiator:"ndc_operator",source:"gui"})})},async finishRun(i){return Ee("/accounting-agent/v1/runs/finish",{method:"POST",body:JSON.stringify({runId:i,status:"DONE",source:"gui",reason:"Остановлено оператором из GUI"})})},async listRuns(){return Ee("/accounting-agent/v1/runs")},async listResults(){return Ee("/accounting-agent/v1/results")},async runTrace(i){return Ee(`/accounting-agent/v1/trace/run/${i}`)},async sendAssistantMessage(i){return Ee("/assistant/message",{method:"POST",body:JSON.stringify({session_id:i.sessionId??"",mode:"assistant",message:i.userMessage,user_message:i.userMessage,llmProvider:i.connection.llmProvider,apiKey:i.connection.apiKey,model:i.connection.model,baseUrl:i.connection.baseUrl,temperature:i.connection.temperature,maxOutputTokens:i.connection.maxOutputTokens,promptVersion:i.promptVersion??"address_query_runtime_v1",systemPrompt:i.prompts.systemPrompt,developerPrompt:i.prompts.developerPrompt,domainPrompt:i.prompts.domainPrompt,fewShotExamples:i.prompts.fewShotExamples,context:{period_hint:i.context?.periodHint??"",business_context:i.context?.businessContext??""},useMock:!!i.useMock})})},async loadAssistantSession(i){return Ee(`/assistant/session/${i}`)},async loadAssistantAnnotations(i){const p=new URLSearchParams;i?.session_id&&p.set("session_id",i.session_id),typeof i?.limit=="number"&&p.set("limit",String(i.limit));const m=p.toString();return Ee(`/assistant/annotations${m?`?${m}`:""}`)},async saveAssistantAnnotation(i){return Ee("/assistant/annotations",{method:"POST",body:JSON.stringify(i)})},async loadAutoRunsHistory(i){const p=new URLSearchParams;i?.from&&p.set("from",i.from),i?.to&&p.set("to",i.to),i?.target&&p.set("target",i.target),i?.mode&&p.set("mode",i.mode),i?.use_mock&&p.set("use_mock",i.use_mock),i?.prompt_contains&&p.set("prompt_contains",i.prompt_contains),typeof i?.limit=="number"&&p.set("limit",String(i.limit)),typeof i?.scan_limit=="number"&&p.set("scan_limit",String(i.scan_limit));const m=p.toString();return Ee(`/autoruns/history${m?`?${m}`:""}`)},async loadAutoRunDetail(i){return Ee(`/autoruns/history/${encodeURIComponent(i)}`)},async loadAutoRunCaseDialog(i,p){return Ee(`/autoruns/history/${encodeURIComponent(i)}/case/${encodeURIComponent(p)}/dialog`)},async loadAutoRunAnnotations(i){const p=new URLSearchParams;i?.run_id&&p.set("run_id",i.run_id),i?.case_id&&p.set("case_id",i.case_id),typeof i?.min_rating=="number"&&p.set("min_rating",String(i.min_rating)),i?.manual_case_decision&&p.set("manual_case_decision",i.manual_case_decision),typeof i?.limit=="number"&&p.set("limit",String(i.limit));const m=p.toString();return Ee(`/autoruns/annotations${m?`?${m}`:""}`)},async saveAutoRunAnnotation(i){return Ee("/autoruns/annotations",{method:"POST",body:JSON.stringify(i)})},async updateAutoRunAnnotation(i){return Ee(`/autoruns/annotations/${encodeURIComponent(i.annotation_id)}`,{method:"PATCH",body:JSON.stringify({resolved:i.resolved,resolved_by:i.resolved_by})})},async loadAutoRunPostAnalysis(i){const p=new URLSearchParams;i?.run_id&&p.set("run_id",i.run_id),typeof i?.limit_per_queue=="number"&&p.set("limit_per_queue",String(i.limit_per_queue)),typeof i?.annotation_limit=="number"&&p.set("annotation_limit",String(i.annotation_limit)),typeof i?.scan_limit=="number"&&p.set("scan_limit",String(i.scan_limit)),i?.from&&p.set("from",i.from),i?.to&&p.set("to",i.to),i?.target&&p.set("target",i.target),i?.mode&&p.set("mode",i.mode),i?.use_mock&&p.set("use_mock",i.use_mock),i?.prompt_contains&&p.set("prompt_contains",i.prompt_contains);const m=p.toString();return Ee(`/autoruns/post-analysis${m?`?${m}`:""}`)},async loadAutoRunAutogenHistory(i){const p=new URLSearchParams;i?.mode&&p.set("mode",i.mode),typeof i?.limit=="number"&&p.set("limit",String(i.limit));const m=p.toString();return Ee(`/autoruns/autogen/history${m?`?${m}`:""}`)},async loadAutoRunAutogenPersonalityCatalog(){return Ee("/autoruns/autogen/personality-catalog")},async generateAutoRunQuestions(i){return Ee("/autoruns/autogen/generate",{method:"POST",body:JSON.stringify(i)})}};function Gt({value:i}){return o.jsx("pre",{className:"json-view",children:JSON.stringify(i??{},null,2)})}function Mn({title:i,subtitle:p,actions:m,className:R,hideHeader:j,children:T}){return o.jsxs("section",{className:R?`panel-frame ${R}`:"panel-frame",children:[j?null:o.jsxs("header",{className:"panel-header",children:[o.jsxs("div",{children:[o.jsx("h2",{children:i}),p?o.jsx("p",{children:p}):null]}),m?o.jsx("div",{className:"panel-actions",children:m}):null]}),o.jsx("div",{className:"panel-body",children:T})]})}function Mf(i){const p=new Date(i);return Number.isNaN(p.getTime())?i:p.toLocaleString("ru-RU")}function Af({sessionId:i,conversation:p,statusText:m,errorMessage:R,useMock:j,appLogs:T}){const $=p.filter(I=>I.role==="assistant").length,Y=p.filter(I=>I.role==="user").length,F=p.length>0?p[p.length-1]:null;return o.jsxs(Mn,{title:"SAM",subtitle:"System Assistant Monitor: срез по текущей сессии и логам.",children:[o.jsxs("div",{className:"metrics-grid",children:[o.jsxs("div",{children:[o.jsx("span",{children:"session_id"}),o.jsx("strong",{children:i||"новая сессия"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"mock_mode"}),o.jsx("strong",{children:j?"on":"off"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"сообщений пользователя"}),o.jsx("strong",{children:Y})]}),o.jsxs("div",{children:[o.jsx("span",{children:"ответов ассистента"}),o.jsx("strong",{children:$})]}),o.jsxs("div",{children:[o.jsx("span",{children:"статус"}),o.jsx("strong",{children:m||"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"ошибка"}),o.jsx("strong",{children:R||"нет"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"последнее сообщение"}),o.jsx("strong",{children:F?.created_at?Mf(F.created_at):"нет данных"})]})]}),o.jsx("h3",{style:{marginTop:12},children:"Последние системные логи"}),o.jsx(Gt,{value:T.slice(0,120)})]})}const Tf=/(?:^|\n)\s*#{0,6}\s*(?:debug_payload_json|technical_breakdown_json|route_summary_json|debug_payload|technical_breakdown)\b/i,If=[/\b(?:debug_payload_json|technical_breakdown_json)\b/i,/\b(?:route_summary|semantic_profile|domain_scope|relation_patterns|account_scope)\b/i,/\b(?:coverage_report|retrieval_status|problem_unit_state|candidate_evidence)\b/i,/\b(?:graph_domain_scope|graph_runtime|selection_reason|why_included)\b/i];function Lf(i){try{return JSON.stringify(i,null,2)}catch{return String(i)}}function Df(i){const p=String(i??""),m=p.match(Tf);return(m?p.slice(0,m.index):p).replace(/###\s*(?:debug_payload_json|technical_breakdown_json|route_summary_json)[\s\S]*?(?:```[\s\S]*?```|$)/gi,"").replace(/(?:^|\n)\s*#{0,6}\s*(?:debug_payload_json|technical_breakdown_json|route_summary_json)\b[\s\S]*$/gi,"").split(/\r?\n/g).map($=>$.trimEnd()).filter($=>$.trim().length>0).filter($=>!If.some(Y=>Y.test($))).join(` +`).trim()}function zf(i,p,m="default"){const R=m==="technical",j=[];j.push("# Assistant conversation export"),j.push(`session_id: ${i||"n/a"}`),j.push(`export_mode: ${m}`),j.push(`exported_at: ${new Date().toISOString()}`),j.push("");for(let T=0;T{j.length!==0&&(R.push(j.join(` +`)),j=[])};for(const $ of m){const Y=$.trimEnd(),F=Y.trim();if(!F){T();continue}const I=/^Блок\s+\d+\./i.test(F),W=/^\d+\.\s/.test(F);(I||W)&&j.length>0&&T(),j.push(Y)}return T(),R.length>0?R:[i]}function Hf(i,p){const m=[],R=/\*\*(.+?)\*\*/g;let j=0,T=0,$;for(;($=R.exec(i))!==null;)$.index>j&&(m.push(o.jsx("span",{children:i.slice(j,$.index)},`${p}-t-${T}`)),T+=1),m.push(o.jsx("strong",{children:$[1]},`${p}-b-${T}`)),T+=1,j=R.lastIndex;return j0?m:[o.jsx("span",{children:i},`${p}-raw`)]}function Vf(i){const p=i.trimStart();return/^Блок\s+\d+\./i.test(p)?"assistant-msg-line heading":/^\d+\.\s/.test(p)?"assistant-msg-line numbered":/^-\s/.test(p)?"assistant-msg-line bullet":"assistant-msg-line"}function Qf(i,p=40){const m=i.replace(/\s+/g," ").trim();if(m.length<=p)return m;const R=m.split(" ").slice(0,3).join(" ").trim();return R.length>=10&&R.length<=p?`${R}…`:`${m.slice(0,p-1).trimEnd()}…`}function $c(i){return i.replace(/\*\*(.+?)\*\*/g,"$1").replace(/^\d+\.\s*/,"").trim()}function Wf(i){const p=i.replace(/\r\n?/g,` +`).split(` +`).map(j=>j.trim()).find(Boolean),m=$c(p??"");return(m.split("|")[0]?.trim()??m).replace(/\s+/g," ").trim()}function Kf(i){const p=i.replace(/\r\n?/g,` +`).split(` +`).map(R=>R.trim()).find(Boolean);return!p||!/^\d+\.\s/.test(p)?!1:$c(p).includes("|")}function qf(i,p){const m=p.replace(/\r\n?/g,` +`).replace(/\*\*(.+?)\*\*/g,"$1").split(` +`).map((j,T)=>{const $=j.trim();return T===0?$.replace(/^\d+\.\s*/,""):$}).filter(Boolean).join(" ").replace(/\s+/g," ").trim();if(!m)return null;const R=Wf(p)||m;return{message_id:i.message_id,source_text:m,anchor_text:R,preview_text:Qf(R)}}function Gf(i,p,m,R){return bf(i.text).map((T,$)=>{const Y=T.split(` +`),F=i.role==="assistant"&&Kf(T),I=F?qf(i,T):null,W=!!I&&p?.message_id===I?.message_id&&p?.source_text===I?.source_text,z=Y.map((U,oe)=>o.jsx("p",{className:Vf(U),children:Hf(U,`line-${$}-${oe}`)},`line-${$}-${oe}`));return!F||!I?o.jsx("div",{className:"assistant-msg-block",children:z},`block-${$}`):o.jsx("div",{className:W?"assistant-msg-block selectable active":"assistant-msg-block selectable",role:"button",tabIndex:0,onClick:()=>{if(W){R();return}m(I)},onKeyDown:U=>{if(!(U.key!=="Enter"&&U.key!==" ")){if(U.preventDefault(),W){R();return}m(I)}},children:z},`block-${$}`)})}function Fc({sessionId:i,conversation:p,inputValue:m,onInputChange:R,selectedContextChip:j,onSelectContextChip:T,onClearContextChip:$,useMock:Y,onUseMockChange:F,onSend:I,onClear:W,busy:z,statusText:U,errorMessage:oe,showCommentAction:Me=!1,onCommentAssistantMessage:te,isAssistantMessageCommented:se,canCommentAssistantMessage:q}){const re=x.useRef(null),Se=x.useRef(!0),Pe=x.useRef(null),[Ae,De]=x.useState("idle"),[$e,We]=x.useState("чат");function Ge(ie=!1){re.current&&(ie&&(Se.current=!0),re.current.scrollTop=re.current.scrollHeight)}x.useEffect(()=>{Se.current&&Ge()},[p]),x.useEffect(()=>()=>{Pe.current!==null&&window.clearTimeout(Pe.current)},[]);async function Ze(ie){if(p.length===0)return;const Te=zf(i,p,ie),Fe=await Ff(Te);We(ie==="technical"?"тех":"чат"),De(Fe?"success":"error"),Pe.current!==null&&window.clearTimeout(Pe.current),Pe.current=window.setTimeout(()=>{De("idle")},2200)}function rt(){if(!re.current)return;const ie=re.current,Te=ie.scrollHeight-ie.scrollTop-ie.clientHeight;Se.current=Te<16}return o.jsx(Mn,{className:"assistant-panel-frame",title:"Режим ассистента",children:o.jsxs("div",{className:"assistant-live-shell",children:[o.jsxs("div",{className:"assistant-toolbar",children:[o.jsxs("div",{className:"assistant-toolbar-actions",children:[o.jsx("button",{type:"button",className:"assistant-copy-btn",onClick:()=>{Ze("default")},disabled:p.length===0,title:"Экспорт только user-facing чата",children:"Скопировать чат"}),o.jsx("button",{type:"button",className:"assistant-copy-btn",onClick:()=>{Ze("technical")},disabled:p.length===0,title:"Технический экспорт с debug payload",children:"Скопировать техчат"}),o.jsx("button",{type:"button",className:"assistant-copy-btn",onClick:()=>W(),disabled:z&&p.length===0,children:"Сбросить сессию"})]}),o.jsxs("div",{className:"assistant-toolbar-meta",children:[i?o.jsx("span",{className:"status-chip",children:`session: ${i}`}):null,o.jsxs("div",{className:"assistant-toolbar-meta-right",children:[U?o.jsx("span",{className:"assistant-live-status",children:U}):null,Ae==="success"?o.jsxs("span",{className:"assistant-copy-feedback success",children:["Скопировано (",$e,")"]}):null,Ae==="error"?o.jsx("span",{className:"assistant-copy-feedback error",children:"Ошибка копирования"}):null]})]}),oe?o.jsx("p",{className:"error-text assistant-toolbar-error",children:oe}):null]}),o.jsx("div",{ref:re,className:"assistant-chat-list",onScroll:rt,children:p.map((ie,Te)=>{const Fe=ie.role==="assistant"&&Me&&typeof te=="function"&&(typeof q=="function"?q(ie,Te):!0),fe=ie.role==="assistant"&&typeof se=="function"?se(ie,Te):!1;return o.jsxs("article",{className:`assistant-msg ${ie.role}`,children:[o.jsxs("header",{className:"assistant-msg-head",children:[o.jsxs("div",{className:"assistant-msg-head-main",children:[o.jsx("strong",{children:Of(ie.role)}),o.jsx("span",{children:$f(ie.created_at)})]}),ie.role==="assistant"&&Me?o.jsx("div",{className:"assistant-msg-head-actions",children:o.jsx("button",{type:"button",className:fe?"autoruns-comment-icon assistant-comment-btn commented":"autoruns-comment-icon assistant-comment-btn",onClick:()=>te?.(ie,Te),disabled:!Fe,title:Fe?"Комментировать ответ ассистента":"Комментарий недоступен для этого сообщения","aria-label":Fe?"Комментировать ответ ассистента":"Комментарий недоступен для этого сообщения",children:o.jsx(Uf,{commented:fe})})}):null]}),o.jsx("div",{className:"assistant-msg-body",children:Gf(ie,j,T,$)}),ie.role==="assistant"&&ie.debug?o.jsxs("details",{className:"assistant-debug",children:[o.jsx("summary",{children:"Показать технический разбор"}),o.jsx(Gt,{value:ie.debug})]}):null]},ie.message_id)})}),o.jsxs("div",{className:"assistant-compose",children:[j?o.jsxs("div",{className:"assistant-compose-context",children:[o.jsx("span",{className:"assistant-compose-context-label",children:"Выбранный объект"}),o.jsxs("div",{className:"assistant-compose-context-pill",title:j.source_text,children:[o.jsx("span",{className:"assistant-compose-context-pill-text",children:j.preview_text}),o.jsx("button",{type:"button",className:"assistant-compose-context-clear",onClick:$,"aria-label":"Убрать выбранный объект",title:"Убрать выбранный объект",children:"×"})]})]}):null,o.jsxs("label",{className:"full-width",children:["Сообщение",o.jsx("textarea",{className:"assistant-input-textarea",value:m,onChange:ie=>R(ie.target.value),rows:4,placeholder:j?"Продолжите вопрос по выбранному объекту...":"Введите вопрос к данным компании..."})]}),o.jsxs("div",{className:"button-row assistant-send-row",children:[o.jsxs("label",{className:"checkbox-row",children:[o.jsx("input",{type:"checkbox",checked:Y,onChange:ie=>F(ie.target.checked)}),"Mock-режим"]}),o.jsx("button",{type:"button",className:"assistant-send-btn",onClick:()=>{Ge(!0),I()},disabled:z||!m.trim(),children:z?"Выполняю...":"Отправить"})]})]})]})})}const bi={fromLocal:"",toLocal:"",target:"all",mode:"all",useMock:"any",promptContains:"",limit:120},sl="needs_dialog_policy_fix",gt="__all__",al="__live__:",wc="ndc_autoruns_ui_config_v1",jc="ndc-autoruns-save",Hi=["Анализ запроса","Получение данных","Подготовка ответа"];function Jf(i,p){const m=i.trim();if(!m)return"";if(!p)return m;const R=m.toLowerCase(),j=p.anchor_text.trim(),T=j.toLowerCase();return T&&R.includes(T)?m:`По выбранному объекту "${j}": ${m}`}const Ji=[{id:"general",label:"Общий контур",domain:"",defaultPrompt:"Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл."}];function Yf(i=Ji){return i.reduce((p,m)=>(p[m.id]=m.defaultPrompt,p),{})}const kc={mode:"codex_creative",count:24,personalityId:"general",personalityPrompts:Yf(),persistToEvalCases:!0,generatedBy:"manual_reviewer"};function Vi(i){const p=String(i??"").trim();return/^\d{4}-\d{2}-\d{2}$/.test(p)?p:""}function Cc(i){const p=typeof i=="number"&&Number.isFinite(i)?Math.trunc(i):160;return Math.max(110,Math.min(520,p))}function Xf(i){const p=i.getFullYear(),m=String(i.getMonth()+1).padStart(2,"0"),R=String(i.getDate()).padStart(2,"0"),j=String(i.getHours()).padStart(2,"0"),T=String(i.getMinutes()).padStart(2,"0");return`${p}-${m}-${R}T${j}:${T}`}function Nc(){const i=new Date;return i.setDate(i.getDate()-14),Xf(i)}function ol(i){if(!i.trim())return;const p=Date.parse(i);if(Number.isFinite(p))return new Date(p).toISOString()}function ur(i){if(!i)return"нет данных";const p=Date.parse(i);return Number.isFinite(p)?new Date(p).toLocaleString("ru-RU"):i}function Zf(i,p){return p<=0?0:Math.max(0,Math.min(100,Number((i/p*100).toFixed(1))))}function ll(i){return typeof i!="number"?"нет данных":`${i.toFixed(1)}%`}function em(i){return i==="assistant_stage1"?"assistant/s1":i==="assistant_stage2"?"assistant/s2":i==="assistant_p0"?"assistant/p0":i}function Ec(i){return i==="up"?"Рост":i==="down"?"Регресс":"Без изменений"}function tm(i,p){return i.find(m=>m.case_id===p)??null}function Qi(i){const p=Math.max(1,Math.min(5,Math.round(i)));return`${"●".repeat(p)}${"○".repeat(5-p)}`}function Pc(i){return i.length===0?o.jsx("p",{className:"muted",children:"Покрытие доменов пока не сформировано."}):o.jsx("div",{className:"autoruns-coverage-list",children:i.map(p=>{const m=Zf(p.closed_cases,p.total_cases);return o.jsxs("div",{className:"autoruns-coverage-item",children:[o.jsxs("div",{className:"autoruns-coverage-head",children:[o.jsx("strong",{children:p.domain}),o.jsxs("span",{children:[p.closed_cases,"/",p.total_cases," (",m,"%)"]})]}),o.jsx("div",{className:"autoruns-coverage-bar",children:o.jsx("div",{style:{width:`${m}%`}})})]},p.domain)})})}function il(i){return`${al}${i}`}function js(i){return i.startsWith(al)}function Rc(i){return i.startsWith(al)?i.slice(al.length):""}function Uc(i){const p=i.report_summary?.run_timestamp??i.created_at,m=Math.max(0,i.total_cases-i.completed_cases);return{run_id:il(i.job_id),eval_target:i.eval_target,run_timestamp:p,mode:"single-pass-strict",llm_provider:null,model:null,use_mock:null,analysis_date:i.report_summary?.analysis_date??i.analysis_date??null,prompt_version:null,schema_version:null,suite_id:i.case_set_file,cases_total:i.total_cases,requests_total:null,report_path:`async_job:${i.job_id}`,score_index:i.report_summary?.score_index??null,blocking_failures:0,quality_failures:0,closed_cases:i.completed_cases,open_cases:m,domain_coverage:[{domain:"runtime",total_cases:i.total_cases,closed_cases:i.completed_cases}]}}function no(i,p){const m=Uc(i),R=i.cases.map(W=>({case_id:W.case_id,domain:null,query_class:null,status:W.status==="completed"?"closed":W.status==="failed"?"open":"unknown",score_index:null,trace_id:null,reply_type:null,session_id:`${i.run_id}-${W.case_id}`,dialog_available:W.messages.length>0,commented_count:0,latest_annotation_at:null,avg_rating:null,checks:null,metric_subscores:null})),T=p!==gt&&R.some(W=>W.case_id===p)?p:R.length>0?gt:"",$={ok:!0,run:m,coverage:{closed_cases:i.completed_cases,open_cases:Math.max(0,i.total_cases-i.completed_cases),domain_coverage:[{domain:"runtime",total_cases:i.total_cases,closed_cases:i.completed_cases}]},cases:R,annotations_summary:{total:0},report:i.report_summary?{run_id:i.report_summary.run_id,run_timestamp:i.report_summary.run_timestamp,score_index:i.report_summary.score_index,cases_total:i.report_summary.cases_total,analysis_date:i.report_summary.analysis_date??i.analysis_date??null}:{}},Y=[];let F=0;if(T===gt)for(const W of i.cases)for(let z=0;zz.case_id===T)??null;for(let z=0;z<(W?.messages.length??0);z+=1){const U=W?.messages[z];U&&Y.push({...U,message_index:z,case_id:T,case_message_index:z,commented:!1,annotation:null})}}const I={ok:!0,run_id:m.run_id,case_id:T,source:"assistant_session",session_id:T===gt?`${i.run_id}::__all__`:`${i.run_id}-${T}`,messages:Y,decomposition:[],assistant_mode:{status:i.status,completed_cases:i.completed_cases,total_cases:i.total_cases},annotations:[]};return{detail:$,dialog:I,caseId:T}}function nm({commented:i}){const p=i?"comment-icon-svg commented":"comment-icon-svg";return o.jsx("svg",{className:p,viewBox:"0 0 24 24","aria-hidden":"true",focusable:"false",children:o.jsx("path",{d:"M5 6.5h14v9H11.5l-4.5 3v-3H5z"})})}function Mc({resolved:i}){return o.jsxs("svg",{className:i?"resolve-icon-svg resolved":"resolve-icon-svg",viewBox:"0 0 16 16","aria-hidden":"true",focusable:"false",children:[o.jsx("circle",{cx:"8",cy:"8",r:"6.2"}),i?o.jsx("path",{d:"M5.1 8.2 7.2 10.3 11 6.5"}):null]})}function rm(){return o.jsxs("svg",{className:"autoruns-copy-icon-svg",viewBox:"0 0 24 24","aria-hidden":"true",focusable:"false",children:[o.jsx("rect",{x:"9",y:"9",width:"11",height:"11",rx:"2.2"}),o.jsx("path",{d:"M15 7V5.8a1.8 1.8 0 0 0-1.8-1.8H5.8A1.8 1.8 0 0 0 4 5.8v7.4A1.8 1.8 0 0 0 5.8 15H7"})]})}function sm({connection:i,prompts:p,assistantPromptVersion:m,decompositionPromptVersion:R,showAssistantMode:j,showDecompositionMode:T,showProgressMode:$,showCommentsMode:Y,onLog:F}){const[I,W]=x.useState({...bi,fromLocal:Nc()}),[z,U]=x.useState(""),[oe,Me]=x.useState(null),[te,se]=x.useState(null),[q,re]=x.useState(null),[Se,Pe]=x.useState([]),[Ae,De]=x.useState("all"),[$e,We]=x.useState(!1),[Ge,Ze]=x.useState(null),[rt,ie]=x.useState([]),[Te,Fe]=x.useState(""),[fe,Re]=x.useState(""),[me,D]=x.useState(""),[Q,O]=x.useState(Ji),[h,C]=x.useState(kc),[G,ae]=x.useState([]),[ce,de]=x.useState(""),[xe,ge]=x.useState([]),[ee,ke]=x.useState(null),[Ft,qn]=x.useState(null),[An,Tn]=x.useState(!1),[dr,Jt]=x.useState(!1),[Yt,Gn]=x.useState(!1),[mn,Ut]=x.useState(!1),[Xt,pn]=x.useState(!1),[fr,In]=x.useState(!1),[mr,Ln]=x.useState(!1),[Zt,en]=x.useState(!1),[pr,Bt]=x.useState(""),[hn,Be]=x.useState(""),[st,gn]=x.useState(""),[vn,tn]=x.useState([]),[nn,Ct]=x.useState([]),[Dn,rn]=x.useState(""),[bt,vt]=x.useState(null),[Jn,Ke]=x.useState(!1),[hr,yn]=x.useState(!1),[gr,sn]=x.useState(""),[vr,Nt]=x.useState(""),[Yn,yt]=x.useState(String(bi.limit)),[Jr,xt]=x.useState(String(kc.count)),[Et,zn]=x.useState(160),[ue,ot]=x.useState({open:!1,caseId:"",caseMessageIndex:-1,messageIndex:-1,rating:3,comment:"",manualCaseDecision:sl,annotationAuthor:"manual_reviewer",saving:!1,error:""}),[ve,_t]=x.useState({open:!1,messageIndex:-1,rating:3,comment:"",annotationAuthor:"manual_reviewer",saving:!1,error:""}),Pt=x.useRef(!1),we=x.useRef(null),lt=x.useMemo(()=>Q.find(a=>a.id===h.personalityId)??Q[0]??Ji[0],[h.personalityId,Q]),Rt=x.useMemo(()=>G.find(a=>a.generation_id===ce)??G[0]??null,[G,ce]),On=te?tm(te.cases,me):null,J=x.useMemo(()=>$e?Se.filter(a=>!a.resolved):Se,[Se,$e]),Ne=J.find(a=>a.annotation_id===Te)??null,$n=q?.messages.find(a=>a.message_index===ue.messageIndex)??null,Yr=x.useMemo(()=>{if(!q||ue.messageIndex<0)return null;for(let a=ue.messageIndex-1;a>=0;a-=1){const c=q.messages[a];if(c?.role==="user")return c}return null},[ue.messageIndex,q]),xn=x.useMemo(()=>{const a=new Map;for(const c of nn)c.message_id&&a.set(c.message_id,c);return a},[nn]),Ie=ve.messageIndex>=0?vn[ve.messageIndex]??null:null,Xr=x.useMemo(()=>{if(ve.messageIndex<0)return null;for(let a=ve.messageIndex-1;a>=0;a-=1){const c=vn[a];if(c?.role==="user")return c}return null},[ve.messageIndex,vn]),ut=x.useMemo(()=>{const a=J.map(y=>({source:"autorun",key:`autorun:${y.annotation_id}`,updated_at:y.updated_at,rating:y.rating,autorun:y,assistant:null})),c=nn.map(y=>({source:"assistant_live",key:`assistant:${y.annotation_id}`,updated_at:y.updated_at,rating:y.rating,autorun:null,assistant:y}));return[...a,...c].sort((y,A)=>Date.parse(A.updated_at)-Date.parse(y.updated_at))},[nn,J]),yr=x.useMemo(()=>{if(ut.length===0)return null;const a=ut.reduce((c,y)=>c+y.rating,0)/ut.length;return Number(a.toFixed(2))},[ut]),Fn=x.useMemo(()=>{const a=[...oe?.items??[]];return ee&&a.unshift(Uc(ee)),fe&&!a.some(c=>c.run_id===fe)&&te?.run&&a.unshift(te.run),a},[ee,oe?.items,te?.run,fe]),le=x.useCallback(a=>{F?.(`[autoruns] ${a}`)},[F]),Un=x.useCallback(async a=>{const c=String(a??"").trim();if(!c){Ct([]);return}try{const y=await Ce.loadAssistantAnnotations({session_id:c,limit:400});Ct(y.items??[])}catch(y){const A=y instanceof Error?y.message:String(y);le(`Assistant live annotations load error: ${A}`)}},[le]),Mt=x.useCallback(a=>{_t(c=>c.saving&&!a?.force?c:{open:!1,messageIndex:-1,rating:3,comment:"",annotationAuthor:"manual_reviewer",saving:!1,error:""})},[]),ct=x.useCallback(async(a,c)=>{a.stopPropagation(),a.preventDefault();const y=String(c??"").trim();if(y)try{if(navigator?.clipboard?.writeText)await navigator.clipboard.writeText(y);else{const A=document.createElement("textarea");A.value=y,A.setAttribute("readonly","true"),A.style.position="fixed",A.style.opacity="0",document.body.appendChild(A),A.select(),document.execCommand("copy"),document.body.removeChild(A)}le(`run id copied: ${y}`)}catch(A){const pe=A instanceof Error?A.message:String(A);Be(`Копирование run id: ${pe}`),le(`copy run id error: ${pe}`)}},[le]);function ks(){let a=0;sn(Hi[0]);const c=window.setInterval(()=>{a=Math.min(a+1,Hi.length-1),sn(Hi[a])},650);return()=>window.clearInterval(c)}const St=x.useCallback(()=>{gn(""),tn([]),Ct([]),rn(""),vt(null),sn(""),Nt(""),Mt({force:!0}),le("Live-чат ассистента в истории автопрогонов сброшен.")},[Mt,le]),Cs=x.useCallback(async()=>{const a=Jf(Dn,bt);if(!a)return;yn(!0),Nt(""),rn(""),tn(y=>[...y,{message_id:`autoruns-live-${Date.now()}`,session_id:st||"pending",role:"user",text:a,reply_type:null,created_at:new Date().toISOString(),trace_id:null,debug:null}]);const c=ks();try{const y=await Ce.sendAssistantMessage({connection:i,prompts:p,userMessage:a,sessionId:st||void 0,promptVersion:m,useMock:Jn});gn(y.session_id),tn(y.conversation),await Un(y.session_id),sn("Ответ готов"),le(`Live-ответ ассистента получен: trace=${y.debug.trace_id}`)}catch(y){const A=y instanceof Error?y.message:String(y);Nt(A),sn("Ошибка ассистента"),le(`Live-чат ассистента: ошибка отправки сообщения: ${A}`)}finally{c(),yn(!1)}},[Dn,bt,st,Jn,m,i,Un,le,p]),Zr=x.useCallback(a=>{const c=a.trim();if(!c){yt(String(I.limit));return}if(!/^\d+$/.test(c)){yt(String(I.limit));return}const y=Number.parseInt(c,10);if(!Number.isFinite(y)){yt(String(I.limit));return}const A=Math.max(1,Math.min(500,y));A!==I.limit&&W(pe=>({...pe,limit:A})),yt(String(A))},[I.limit]),es=x.useCallback(a=>{const c=a.trim();if(!c){xt(String(h.count));return}if(!/^\d+$/.test(c)){xt(String(h.count));return}const y=Number.parseInt(c,10);if(!Number.isFinite(y)){xt(String(h.count));return}const A=Math.max(1,Math.min(200,y));A!==h.count&&C(pe=>({...pe,count:A})),xt(String(A))},[h.count]),Xn=x.useCallback(a=>{zn(Cc(a))},[]),Bn=x.useCallback(a=>{const c=a.currentTarget.offsetHeight;Number.isFinite(c)&&c>0&&Xn(c)},[Xn]),At=x.useCallback(async()=>{en(!0);try{const a=await Ce.loadAutoRunAnnotations({limit:800,manual_case_decision:Ae});Pe(a.items),Ze(a.manual_case_decision_schema??null),ie(a.available_manual_case_decisions??[]),Fe(c=>a.items.length===0?"":a.items.some(y=>y.annotation_id===c)?c:a.items[0].annotation_id)}catch(a){le(`Annotations load error: ${a instanceof Error?a.message:String(a)}`)}finally{en(!1)}},[Ae,le]),wt=x.useCallback(async()=>{Ut(!0);try{const a=await Ce.loadAutoRunAutogenHistory({limit:180});ae(a.items)}catch(a){le(`Autogen history load error: ${a instanceof Error?a.message:String(a)}`)}finally{Ut(!1)}},[le]),xr=x.useCallback(async()=>{try{const c=(await Ce.loadAutoRunAutogenPersonalityCatalog()).items.map(y=>({id:String(y.id??"").trim(),label:String(y.label??"").trim(),domain:typeof y.domain=="string"?y.domain.trim():"",defaultPrompt:String(y.default_prompt??"").trim()})).filter(y=>y.id.length>0&&y.label.length>0);if(c.length===0)return;O(c.map(y=>({id:y.id,label:y.label,domain:y.domain||"",defaultPrompt:y.defaultPrompt||"Генерируй реалистичные вопросы бухгалтера по выбранному профилю. Не выдумывай непокрытые возможности."})))}catch(a){le(`Autogen personality catalog load error: ${a instanceof Error?a.message:String(a)}`)}},[le]),dt=x.useCallback(async()=>{Gn(!0);try{const a=await Ce.loadAutoRunPostAnalysis({run_id:fe&&!js(fe)?fe:void 0,limit_per_queue:30,annotation_limit:1500,from:ol(I.fromLocal),to:ol(I.toLocal),target:I.target,mode:I.mode,use_mock:I.useMock,prompt_contains:I.promptContains.trim()||void 0});qn(a)}catch(a){le(`Post-analysis load error: ${a instanceof Error?a.message:String(a)}`),qn(null)}finally{Gn(!1)}},[I.fromLocal,I.mode,I.promptContains,I.target,I.toLocal,I.useMock,le,fe]),zr=x.useCallback(async()=>{Tn(!0),Be("");try{const a=h.personalityPrompts[h.personalityId]??"",c=[p.systemPrompt,p.developerPrompt,p.domainPrompt,p.schemaNotes,p.fewShotExamples].join(` +`).slice(0,900),y=await Ce.generateAutoRunQuestions({mode:h.mode,count:h.count,domain:lt.domain||void 0,persist_to_eval_cases:h.persistToEvalCases,generated_by:h.generatedBy.trim()||void 0,llm:{llm_provider:i.llmProvider,api_key:i.apiKey,model:i.model,base_url:i.baseUrl,temperature:i.temperature,max_output_tokens:i.maxOutputTokens},context:{llm_provider:i.llmProvider,model:i.model,assistant_prompt_version:m,decomposition_prompt_version:R,prompt_fingerprint:c,autogen_personality_id:lt.id,autogen_personality_prompt:a.trim()||void 0}});le(`Generated ${y.generation.count} questions (${y.generation.mode}) id=${y.generation.generation_id}`+(y.generation.saved_case_set_file?` saved=${y.generation.saved_case_set_file}`:"")),de(y.generation.generation_id),ge([...y.generation.questions??[]]),await wt()}catch(a){const c=a instanceof Error?a.message:String(a);Be(`Автогенерация: ${c}`),le(`Autogen generate error: ${c}`)}finally{Tn(!1)}},[m,h.count,h.generatedBy,h.mode,h.personalityId,h.personalityPrompts,h.persistToEvalCases,i.apiKey,i.baseUrl,i.llmProvider,i.maxOutputTokens,i.model,i.temperature,R,wt,le,p.developerPrompt,p.domainPrompt,p.fewShotExamples,p.schemaNotes,p.systemPrompt,lt.domain,lt.id]),bn=x.useCallback(async(a,c)=>{if(js(a)){const y=Rc(a);if(ee&&ee.job_id===y){const A=no(ee,c);Re(a),D(A.caseId),re(A.dialog);return}re(null);return}Ln(!0);try{const y=await Ce.loadAutoRunCaseDialog(a,c);re(y)}catch(y){const A=y instanceof Error?y.message:String(y);Be(`Диалог кейса: ${A}`),re(null),le(`Dialog load error for ${a}/${c}: ${A}`)}finally{Ln(!1)}},[ee,le]),Tt=x.useCallback(async(a,c)=>{if(js(a)){const y=Rc(a);if(ee&&ee.job_id===y){const A=no(ee,c??gt);Re(a),D(A.caseId),se(A.detail),re(A.dialog);return}Re(a),D(""),se(null),re(null);return}In(!0);try{const y=await Ce.loadAutoRunDetail(a);se(y);const A=(c&&(c===gt||y.cases.some(pe=>pe.case_id===c))?c:"")||(y.cases.length>0?gt:"")||"";Re(a),D(A),A?await bn(a,A):re(null)}catch(y){const A=y instanceof Error?y.message:String(y);Be(`Детализация прогона: ${A}`),se(null),re(null),le(`Run detail load error for ${a}: ${A}`)}finally{In(!1)}},[ee,bn,le]),Ht=x.useCallback(async a=>{pn(!0),Be("");try{const c=await Ce.loadAutoRunsHistory({from:ol(I.fromLocal),to:ol(I.toLocal),target:I.target,mode:I.mode,use_mock:I.useMock,prompt_contains:I.promptContains.trim()||void 0,limit:I.limit});if(Me(c),c.items.length===0){Re(""),D(""),se(null),re(null);return}const y=a?.keepSelection??!0,A=a?.preferredRunId??"",pe=a?.preferredCaseId??"",be=y&&A&&c.items.some(on=>on.run_id===A)?A:c.items[0].run_id;await Tt(be,y?pe:void 0),dt()}catch(c){const y=c instanceof Error?c.message:String(c);Be(`История прогонов: ${y}`),le(`History load error: ${y}`)}finally{pn(!1)}},[I.fromLocal,I.limit,I.mode,I.promptContains,I.target,I.toLocal,I.useMock,dt,Tt,le]),Vt=x.useCallback(()=>{we.current!==null&&(window.clearTimeout(we.current),we.current=null)},[]),Zn=x.useCallback(async a=>{try{const c=await Ce.loadEvalRunAsyncStatus(a);ke(c.job);const y=il(a);if(fe===y){const A=no(c.job,me||gt);se(A.detail),re(A.dialog),D(A.caseId)}if(c.job.status==="completed"){Vt(),Jt(!1);const A=c.job.report_summary?.run_id??c.job.run_id;await Ht({keepSelection:!0,preferredRunId:A||fe,preferredCaseId:gt}),await wt(),ke(null);return}if(c.job.status==="failed"){Vt(),Jt(!1),Be(`Запуск прогонов: ${c.job.error??"неизвестная ошибка"}`),le(`Autogen async run failed: ${c.job.error??"unknown error"}`);return}Vt(),we.current=window.setTimeout(()=>{Zn(a)},500)}catch(c){Vt(),Jt(!1);const y=c instanceof Error?c.message:String(c);Be(`Запуск прогонов: ${y}`),le(`Autogen async status error: ${y}`)}},[wt,Ht,le,me,fe,Vt]),d=x.useCallback(async()=>{Vt(),Jt(!0),Be("");try{const a=Rt;if(!a)throw new Error("История автогенерации пуста. Сначала сгенерируйте пачку вопросов.");const c=xe.map(_r=>_r.trim()).filter(_r=>_r.length>0);if(c.length===0)throw new Error("Нет вопросов для запуска: список пустой после ручного редактирования.");const y=I.useMock==="true",A=Vi(z),be=(await Ce.startEvalRunAsync({connection:i,prompts:p,promptVersion:m,mode:"single-pass-strict",caseSetFile:a.saved_case_set_file??void 0,useMock:y,evalTarget:"assistant_stage1",questions:c,analysisDate:A||void 0})).job;ke(be);const on=il(be.job_id),jn=no(be,gt);Re(on),D(jn.caseId),se(jn.detail),re(jn.dialog),le(`Запущен async-прогон job=${be.job_id}, run_id=${be.run_id}, вопросов=${c.length}`+(a.saved_case_set_file?`, base_case_set=${a.saved_case_set_file}`:"")+(A?`, analysis_date=${A}`:", analysis_date=current_state")),Zn(be.job_id)}catch(a){const c=a instanceof Error?a.message:String(a);Be(`Запуск прогонов: ${c}`),le(`Autogen run error: ${c}`),Jt(!1)}},[z,m,i,xe,I.useMock,le,Zn,p,Rt,Vt]),P=x.useCallback(a=>{if(a.role!=="assistant")return;const c=a.case_id??me,y=a.case_message_index??a.message_index;ot({open:!0,caseId:c,caseMessageIndex:y,messageIndex:a.message_index,rating:a.annotation?.rating??3,comment:a.annotation?.comment??"",manualCaseDecision:a.annotation?.manual_case_decision??sl,annotationAuthor:a.annotation?.annotation_author??h.generatedBy,saving:!1,error:""})},[h.generatedBy,me]),k=x.useCallback(a=>{ot(c=>c.saving&&!a?.force?c:{open:!1,caseId:"",caseMessageIndex:-1,messageIndex:-1,rating:3,comment:"",manualCaseDecision:sl,annotationAuthor:h.generatedBy,saving:!1,error:""})},[h.generatedBy]),ye=x.useCallback(async()=>{const a=fe,c=ue.caseId,y=ue.caseMessageIndex;if(!(!a||!c||y<0)){if(js(a)){ot(A=>({...A,error:"Комментарий можно сохранить после завершения прогона."}));return}if(!ue.comment.trim()){ot(A=>({...A,error:"Добавьте комментарий."}));return}ot(A=>({...A,saving:!0,error:""}));try{await Ce.saveAutoRunAnnotation({run_id:a,case_id:c,message_index:y,rating:ue.rating,comment:ue.comment.trim(),manual_case_decision:ue.manualCaseDecision,annotation_author:ue.annotationAuthor.trim()||void 0}),k({force:!0}),Promise.all([Tt(a,me),At(),dt()]).catch(A=>{const pe=A instanceof Error?A.message:String(A);Be(`Обновление после комментария: ${pe}`),le(`Comment refresh error: ${pe}`)})}catch(A){ot(pe=>({...pe,saving:!1,error:A instanceof Error?A.message:String(A)}))}}},[k,ue.annotationAuthor,ue.caseId,ue.caseMessageIndex,ue.comment,ue.manualCaseDecision,ue.rating,At,dt,Tt,le,me,fe]),er=x.useCallback(a=>a.role==="assistant",[]),Hn=x.useCallback(a=>a.role==="assistant"&&xn.has(a.message_id),[xn]),ro=x.useCallback((a,c)=>{if(a.role!=="assistant")return;const y=st.trim(),A=String(a.session_id??"").trim();if(!(y||A)){Nt("Сначала получите ответ ассистента в активной сессии.");return}!y&&A&&gn(A);const be=xn.get(a.message_id)??null;Nt(""),_t({open:!0,messageIndex:c,rating:be?.rating??3,comment:be?.comment??"",annotationAuthor:be?.annotation_author??"manual_reviewer",saving:!1,error:""})},[xn,st]),Ns=x.useCallback(async()=>{if(ve.messageIndex<0)return;if(!ve.comment.trim()){_t(y=>({...y,error:"Добавьте комментарий."}));return}const a=vn[ve.messageIndex]??null,c=st.trim()||(a?.role==="assistant"?String(a.session_id??"").trim():"");if(!c){_t(y=>({...y,error:"Сессия ассистента не найдена."}));return}_t(y=>({...y,saving:!0,error:""}));try{const y=await Ce.saveAssistantAnnotation({session_id:c,message_index:ve.messageIndex,rating:ve.rating,comment:ve.comment.trim(),annotation_author:ve.annotationAuthor.trim()||void 0});Ct(A=>{const pe=[...A],be=pe.findIndex(on=>on.annotation_id===y.annotation.annotation_id);return be>=0?pe[be]=y.annotation:pe.unshift(y.annotation),pe.sort((on,jn)=>Date.parse(jn.updated_at)-Date.parse(on.updated_at))}),Mt({force:!0})}catch(y){const A=y instanceof Error?y.message:String(y);_t(pe=>({...pe,saving:!1,error:A}))}},[ve.annotationAuthor,ve.comment,ve.messageIndex,ve.rating,vn,st,Mt]),Or=x.useCallback(a=>{Pe(c=>c.map(y=>y.annotation_id===a.annotation_id?{...y,...a}:y)),re(c=>c&&{...c,annotations:c.annotations.map(y=>y.annotation_id===a.annotation_id?a:y),messages:c.messages.map(y=>!y.annotation||y.annotation.annotation_id!==a.annotation_id?y:{...y,commented:!0,annotation:a})})},[]),_n=x.useCallback(async(a,c)=>{if(a.annotation_id){if(js(a.run_id)){Be("Статус выполнения можно менять только для завершённых прогонов.");return}Bt(a.annotation_id);try{const y=await Ce.updateAutoRunAnnotation({annotation_id:a.annotation_id,resolved:c,resolved_by:h.generatedBy||void 0});Or(y.annotation),dt()}catch(y){const A=y instanceof Error?y.message:String(y);Be(`Смена статуса кейса: ${A}`),le(`Annotation resolve toggle error: ${A}`)}finally{Bt("")}}},[Or,h.generatedBy,dt,le]),Sn=x.useCallback(async a=>{Fe(a.annotation_id),await Tt(a.run_id,a.case_id),oe?.items.some(c=>c.run_id===a.run_id)||Be("Комментарий относится к прогону вне текущего фильтра. Детали загружены напрямую.")},[oe?.items,Tt]);x.useEffect(()=>{Pt.current||(Pt.current=!0,Ht({keepSelection:!1}),wt(),xr(),dt())},[wt,xr,Ht,dt]),x.useEffect(()=>{Pt.current&&At()},[Ae,At]),x.useEffect(()=>{Fe(a=>J.length===0?"":J.some(c=>c.annotation_id===a)?a:J[0].annotation_id)},[J]),x.useEffect(()=>{de(a=>G.length===0?"":a&&G.some(c=>c.generation_id===a)?a:G[0].generation_id)},[G]),x.useEffect(()=>{if(!Rt){ge([]);return}ge([...Rt.questions])},[Rt?.generation_id]),x.useEffect(()=>{yt(String(I.limit))},[I.limit]),x.useEffect(()=>{xt(String(h.count))},[h.count]),x.useEffect(()=>{if(!st.trim()){Ct([]);return}Un(st)},[st,Un]),x.useEffect(()=>{if(!ee)return;const a=il(ee.job_id);if(fe!==a)return;const c=no(ee,me||gt);se(c.detail),re(c.dialog),D(c.caseId)},[ee,me,fe]),x.useEffect(()=>()=>{Vt()},[Vt]),x.useEffect(()=>{Q.length!==0&&C(a=>{let c=!1;const y={...a.personalityPrompts};for(const pe of Q)(typeof y[pe.id]!="string"||y[pe.id].trim().length===0)&&(y[pe.id]=pe.defaultPrompt,c=!0);let A=a.personalityId;return Q.some(pe=>pe.id===a.personalityId)||(A=Q[0].id,c=!0),c?{...a,personalityId:A,personalityPrompts:y}:a})},[Q]),x.useEffect(()=>{const a=localStorage.getItem(wc);if(a)try{const c=JSON.parse(a);if(c.filters){const y=c.filters;W(A=>({...A,...y,limit:typeof y.limit=="number"?Math.max(1,Math.min(500,y.limit)):A.limit}))}typeof c.analysisDate=="string"&&U(Vi(c.analysisDate)),typeof c.autogenPersonalityPromptHeight=="number"&&zn(Cc(c.autogenPersonalityPromptHeight)),c.autoGenSettings&&C(y=>{const A={...y.personalityPrompts},pe=c.autoGenSettings?.personalityPrompts??{};for(const[on,jn]of Object.entries(pe))typeof jn=="string"&&on.trim().length>0&&(A[on.trim()]=jn);const be=typeof c.autoGenSettings?.personalityId=="string"&&c.autoGenSettings.personalityId.trim().length>0?c.autoGenSettings.personalityId.trim():y.personalityId;return{...y,mode:c.autoGenSettings?.mode==="codex_creative"||c.autoGenSettings?.mode==="qwen_seed"?c.autoGenSettings.mode:y.mode,count:typeof c.autoGenSettings?.count=="number"?Math.max(1,Math.min(200,c.autoGenSettings.count)):y.count,personalityId:be,personalityPrompts:A,persistToEvalCases:typeof c.autoGenSettings?.persistToEvalCases=="boolean"?c.autoGenSettings.persistToEvalCases:y.persistToEvalCases,generatedBy:typeof c.autoGenSettings?.generatedBy=="string"?c.autoGenSettings.generatedBy:y.generatedBy}}),(c.annotationDecisionFilter==="all"||typeof c.annotationDecisionFilter=="string"&&c.annotationDecisionFilter.length>0)&&De(c.annotationDecisionFilter),typeof c.hideResolvedAnnotations=="boolean"&&We(c.hideResolvedAnnotations)}catch{}},[]);const wn=x.useCallback(()=>{const a={filters:I,analysisDate:z,autogenPersonalityPromptHeight:Et,autoGenSettings:{mode:h.mode,count:h.count,personalityId:h.personalityId,personalityPrompts:h.personalityPrompts,persistToEvalCases:h.persistToEvalCases,generatedBy:h.generatedBy},annotationDecisionFilter:Ae,hideResolvedAnnotations:$e};localStorage.setItem(wc,JSON.stringify(a))},[z,Ae,h,Et,I,$e]);return x.useEffect(()=>{const a=()=>{wn(),le("Сохранены настройки панели автопрогонов.")};return window.addEventListener(jc,a),()=>{window.removeEventListener(jc,a)}},[le,wn]),o.jsxs(Mn,{className:"autoruns-frame",title:"",hideHeader:!0,children:[o.jsxs("div",{className:"autoruns-columns",children:[o.jsxs("section",{className:"autoruns-col",children:[o.jsx("div",{className:"autoruns-col-header",children:o.jsx("h3",{children:"Настройки"})}),o.jsx("h4",{children:"Настройки выборки"}),o.jsxs("div",{className:"autoruns-form-grid",children:[o.jsxs("label",{children:["Дата с",o.jsx("input",{type:"datetime-local",value:I.fromLocal,onChange:a=>W(c=>({...c,fromLocal:a.target.value}))})]}),o.jsxs("label",{children:["Дата по",o.jsx("input",{type:"datetime-local",value:I.toLocal,onChange:a=>W(c=>({...c,toLocal:a.target.value}))})]}),o.jsxs("label",{children:["Целевой контур",o.jsxs("select",{value:I.target,onChange:a=>W(c=>({...c,target:a.target.value})),children:[o.jsx("option",{value:"all",children:"все"}),(oe?.available.targets??[]).map(a=>o.jsx("option",{value:a,children:a},a))]})]}),o.jsxs("label",{children:["Режим",o.jsxs("select",{value:I.mode,onChange:a=>W(c=>({...c,mode:a.target.value})),children:[o.jsx("option",{value:"all",children:"все"}),(oe?.available.modes??[]).map(a=>o.jsx("option",{value:a,children:a},a))]})]}),o.jsxs("label",{children:["Использовать mock",o.jsxs("select",{value:I.useMock,onChange:a=>W(c=>({...c,useMock:a.target.value})),children:[o.jsx("option",{value:"any",children:"любой"}),o.jsx("option",{value:"true",children:"да"}),o.jsx("option",{value:"false",children:"нет"})]})]}),o.jsxs("label",{children:["Лимит",o.jsx("input",{type:"number",min:1,max:500,value:Yn,onChange:a=>{const c=a.target.value;(c===""||/^\d+$/.test(c))&&yt(c)},onBlur:a=>Zr(a.target.value),onKeyDown:a=>{a.key==="Enter"&&Zr(a.target.value)}})]}),o.jsxs("label",{className:"full-width",children:["Версия промпта содержит",o.jsx("input",{value:I.promptContains,onChange:a=>W(c=>({...c,promptContains:a.target.value})),placeholder:"normalizer_v2_0_2 / address_query_runtime_v1",list:"autoruns-prompt-versions"})]})]}),o.jsx("datalist",{id:"autoruns-prompt-versions",children:(oe?.available.prompt_versions??[]).map(a=>o.jsx("option",{value:a},a))}),o.jsxs("div",{className:"button-row",children:[o.jsx("button",{type:"button",disabled:Xt,onClick:()=>{Ht({keepSelection:!1})},children:Xt?"Обновляю...":"Применить"}),o.jsx("button",{type:"button",className:"tab",onClick:()=>{W({...bi,fromLocal:Nc()}),Be("")},children:"Сбросить фильтры"})]}),o.jsx("h4",{children:"Контур генерации"}),o.jsxs("div",{className:"autoruns-meta-list",children:[o.jsxs("div",{children:[o.jsx("span",{children:"Провайдер:"}),o.jsx("strong",{children:i.llmProvider})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Модель:"}),o.jsx("strong",{children:i.model||"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Промпт ассистента:"}),o.jsx("strong",{children:m})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Промпт декомпозиции:"}),o.jsx("strong",{children:R})]})]}),o.jsx("h4",{children:"Автогенерация вопросов"}),o.jsxs("div",{className:"autoruns-form-grid",children:[o.jsxs("label",{children:["Режим генерации",o.jsxs("select",{value:h.mode,onChange:a=>C(c=>({...c,mode:a.target.value})),children:[o.jsx("option",{value:"codex_creative",children:"codex_creative"}),o.jsx("option",{value:"qwen_seed",children:"qwen_seed"})]})]}),o.jsxs("label",{children:["Кол-во",o.jsx("input",{type:"number",min:1,max:200,value:Jr,onChange:a=>{const c=a.target.value;(c===""||/^\d+$/.test(c))&&xt(c)},onBlur:a=>es(a.target.value),onKeyDown:a=>{a.key==="Enter"&&es(a.target.value)}})]}),o.jsxs("label",{children:["Личность автогенерации",o.jsx("select",{value:h.personalityId,onChange:a=>C(c=>({...c,personalityId:a.target.value})),children:Q.map(a=>o.jsx("option",{value:a.id,children:a.label},a.id))})]}),o.jsxs("label",{children:["Кто генерирует",o.jsx("input",{value:h.generatedBy,onChange:a=>C(c=>({...c,generatedBy:a.target.value})),placeholder:"manual_reviewer"})]}),o.jsxs("label",{className:"full-width",children:["Промпт личности",o.jsx("textarea",{className:"autoruns-personality-prompt",value:h.personalityPrompts[h.personalityId]??"",onChange:a=>C(c=>({...c,personalityPrompts:{...c.personalityPrompts,[c.personalityId]:a.target.value}})),placeholder:"Текст промпта для выбранной личности автогенерации",style:{height:`${Et}px`},onMouseUp:Bn,onTouchEnd:Bn})]}),o.jsxs("label",{className:"checkbox-row",children:[o.jsx("input",{type:"checkbox",checked:h.persistToEvalCases,onChange:a=>C(c=>({...c,persistToEvalCases:a.target.checked}))}),"Сохранять кейс-сет в `eval_cases`"]})]}),o.jsxs("div",{className:"autoruns-form-grid",children:[o.jsxs("label",{children:["Дата анализа (срез)",o.jsx("input",{type:"date",value:z,onChange:a=>U(Vi(a.target.value))})]}),o.jsx("div",{className:"button-row",children:o.jsx("button",{type:"button",className:"tab",disabled:!z,onClick:()=>U(""),children:"Сбросить дату среза"})})]}),o.jsxs("div",{className:"button-row",children:[o.jsx("button",{type:"button",disabled:An,onClick:()=>{zr()},children:An?"Генерирую...":"Сгенерировать пачку"}),o.jsx("button",{type:"button",className:"tab",disabled:mn,onClick:()=>{wt()},children:mn?"Обновляю...":"Обновить историю"}),o.jsx("button",{type:"button",className:"autoruns-run-launch-btn",disabled:dr||xe.length===0,onClick:()=>{d()},children:dr?"Запускаю...":"Запустить прогоны"})]}),o.jsx("div",{className:"autoruns-form-grid",children:o.jsxs("label",{className:"full-width",children:["Кейс-сет для запуска",o.jsxs("select",{value:ce,onChange:a=>de(a.target.value),disabled:G.length===0,children:[G.length===0?o.jsx("option",{value:"",children:"нет генераций"}):null,G.map(a=>o.jsxs("option",{value:a.generation_id,children:[ur(a.created_at)," | ",a.mode," | ",a.count," | ",a.saved_case_set_file??"без файла"]},a.generation_id))]})]})}),o.jsxs("div",{className:"autoruns-generated-questions",children:[o.jsxs("div",{className:"autoruns-generated-questions-head",children:[o.jsxs("strong",{children:["Вопросы к запуску: ",xe.length]}),o.jsx("button",{type:"button",className:"tab",onClick:()=>ge([...Rt?.questions??[]]),disabled:!Rt,children:"Восстановить"})]}),xe.length===0?o.jsx("p",{className:"muted",children:"Список вопросов пуст. Сгенерируйте пачку или восстановите из выбранной генерации."}):o.jsx("div",{className:"autoruns-generated-questions-list",children:xe.map((a,c)=>o.jsxs("div",{className:"autoruns-generated-question-item",children:[o.jsxs("span",{children:[c+1,". ",a]}),o.jsx("button",{type:"button",className:"autoruns-remove-question-btn",onClick:()=>ge(y=>y.filter((A,pe)=>pe!==c)),title:"Удалить вопрос из запуска","aria-label":"Удалить вопрос из запуска",children:"+"})]},`${c}-${a.slice(0,24)}`))})]}),o.jsx("p",{className:"muted",children:"Запуск выполняет `assistant_stage1` eval по выбранному кейс-сету."}),o.jsxs("div",{className:"autoruns-autogen-list",children:[mn?o.jsx("p",{className:"muted",children:"Загружаю историю автогенераций..."}):null,!mn&&G.length===0?o.jsx("p",{className:"muted",children:"История автогенераций пока пустая."}):null,G.slice(0,30).map(a=>o.jsxs("article",{className:ce===a.generation_id?"autoruns-autogen-item selected":"autoruns-autogen-item",onClick:()=>de(a.generation_id),children:[o.jsxs("header",{children:[o.jsx("strong",{children:ur(a.created_at)}),o.jsx("span",{children:a.mode})]}),o.jsxs("div",{className:"autoruns-run-meta",children:["id=",a.generation_id," | count=",a.count]}),o.jsxs("div",{className:"autoruns-run-meta",children:["домен=",a.domain??"общий",a.generated_by?` | автор=${a.generated_by}`:""]}),a.saved_case_set_file?o.jsxs("div",{className:"autoruns-run-meta",children:["кейс-сет=",a.saved_case_set_file]}):null,(a.questions??[]).length>0?o.jsx("p",{children:a.questions[0]}):null]},a.generation_id))]}),o.jsxs("details",{className:"autoruns-prompt-details",children:[o.jsx("summary",{children:"Копия активного промпта (только чтение)"}),o.jsxs("label",{children:["Системный",o.jsx("textarea",{readOnly:!0,value:p.systemPrompt})]}),o.jsxs("label",{children:["Разработчика",o.jsx("textarea",{readOnly:!0,value:p.developerPrompt})]}),o.jsxs("label",{children:["Доменный",o.jsx("textarea",{readOnly:!0,value:p.domainPrompt})]}),o.jsxs("label",{children:["Заметки по схеме",o.jsx("textarea",{readOnly:!0,value:p.schemaNotes})]}),o.jsxs("label",{children:["Примеры few-shot",o.jsx("textarea",{readOnly:!0,value:p.fewShotExamples})]})]}),hn?o.jsx("p",{className:"error-text",children:hn}):null]}),o.jsxs("section",{className:"autoruns-col",children:[o.jsx("div",{className:"autoruns-col-header",children:o.jsx("h3",{children:"Выдача прогонов"})}),o.jsxs("div",{className:"autoruns-stats-grid",children:[o.jsxs("div",{children:[o.jsx("span",{children:"Всего"}),o.jsx("strong",{children:(oe?.stats.runs_total??0)+(ee?1:0)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Средний score"}),o.jsx("strong",{children:ll(oe?.stats.avg_score_index??null)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Тренд"}),o.jsx("strong",{children:oe?Ec(oe.stats.trend):"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Блокеры"}),o.jsx("strong",{children:oe?.stats.blocking_runs??0})]})]}),o.jsxs("div",{className:"autoruns-run-list",children:[Fn.map(a=>o.jsxs("button",{type:"button",className:fe===a.run_id?"autoruns-run-item selected":"autoruns-run-item",onClick:()=>{Tt(a.run_id)},children:[o.jsxs("div",{className:"autoruns-run-head",children:[o.jsx("strong",{children:ur(a.run_timestamp)}),o.jsx("span",{children:em(a.eval_target)})]}),o.jsxs("div",{className:"autoruns-run-meta autoruns-run-id-row",children:[o.jsx("span",{children:a.run_id}),o.jsx("span",{role:"button",tabIndex:0,className:"autoruns-copy-run-id-btn",onClick:c=>{ct(c,a.run_id)},onKeyDown:c=>{(c.key==="Enter"||c.key===" ")&&(c.preventDefault(),ct(c,a.run_id))},title:"Скопировать run id","aria-label":`Скопировать run id ${a.run_id}`,children:o.jsx(rm,{})})]}),o.jsxs("div",{className:"autoruns-run-meta",children:["режим=",a.mode??"нет данных"," | mock=",String(a.use_mock)]}),o.jsxs("div",{className:"autoruns-run-meta",children:["analysis_date=",a.analysis_date??"current_state"]}),a.llm_provider||a.model?o.jsxs("div",{className:"autoruns-run-meta",children:["llm=",a.llm_provider??"нет данных"," | модель=",a.model??"нет данных"]}):null,o.jsxs("div",{className:"autoruns-run-meta",children:["промпт=",a.prompt_version??"нет данных"]}),o.jsxs("div",{className:"autoruns-run-foot",children:[o.jsxs("span",{children:["оценка: ",ll(a.score_index)]}),o.jsxs("span",{children:["закрыто/открыто: ",a.closed_cases,"/",a.open_cases]})]}),o.jsxs("div",{className:"autoruns-run-foot",children:[o.jsxs("span",{children:["блокеры: ",a.blocking_failures]}),o.jsxs("span",{children:["качество: ",a.quality_failures]})]})]},a.run_id)),Fn.length===0?o.jsx("p",{className:"muted",children:"За выбранный диапазон прогонов нет."}):null]})]}),o.jsxs("section",{className:"autoruns-col",children:[o.jsxs("div",{className:"autoruns-col-header",children:[o.jsx("h3",{children:"Диалог прогона"}),o.jsxs("div",{className:"autoruns-dialog-toolbar",children:[o.jsxs("label",{children:["Прогон",o.jsx("select",{value:fe,onChange:a=>{const c=a.target.value;Tt(c)},children:Fn.map(a=>o.jsxs("option",{value:a.run_id,children:[ur(a.run_timestamp)," | ",a.run_id]},a.run_id))})]}),o.jsxs("label",{children:["Кейс",o.jsxs("select",{value:me,onChange:a=>{const c=a.target.value;D(c),fe&&c&&bn(fe,c)},children:[(te?.cases.length??0)>0?o.jsx("option",{value:gt,children:"ВСЕ кейсы подряд"}):null,(te?.cases??[]).map(a=>o.jsxs("option",{value:a.case_id,children:[a.case_id," | ",a.status]},a.case_id))]})]})]})]}),o.jsxs("div",{className:"autoruns-case-list",children:[(te?.cases.length??0)>0?o.jsxs("button",{type:"button",className:me===gt?"autoruns-case-item selected":"autoruns-case-item",onClick:()=>{D(gt),fe&&bn(fe,gt)},children:[o.jsx("span",{children:"ВСЕ кейсы подряд"}),o.jsx("span",{children:te?.cases.length})]},gt):null,(te?.cases??[]).map(a=>o.jsxs("button",{type:"button",className:me===a.case_id?"autoruns-case-item selected":"autoruns-case-item",onClick:()=>{D(a.case_id),fe&&bn(fe,a.case_id)},children:[o.jsx("span",{children:a.case_id}),o.jsxs("span",{children:[a.status,a.commented_count>0?` | комм=${a.commented_count}`:""]})]},a.case_id))]}),o.jsxs("div",{className:"autoruns-dialog-view",children:[mr||fr?o.jsx("p",{className:"muted",children:"Загружаю диалог..."}):null,!mr&&!fr&&(q?.messages.length??0)===0?o.jsx("p",{className:"muted",children:"Диалог для этого прогона не найден."}):null,(q?.messages??[]).map((a,c)=>{const y=a.role==="assistant"?"assistant":"user";return o.jsxs("article",{className:`autoruns-msg ${y}`,children:[o.jsxs("header",{children:[o.jsx("strong",{children:y==="assistant"?"Система":"Модель/вопрос"}),o.jsxs("div",{className:"autoruns-msg-head-actions",children:[a.case_id?o.jsx("span",{className:"autoruns-msg-case-tag",children:a.case_id}):null,o.jsx("span",{children:a.created_at?ur(a.created_at):"нет данных"}),y==="assistant"&&!js(fe)?o.jsxs(o.Fragment,{children:[o.jsx("button",{type:"button",className:a.commented?"autoruns-comment-icon commented":"autoruns-comment-icon",onClick:()=>P(a),title:"\\u041a\\u043e\\u043c\\u043c\\u0435\\u043d\\u0442\\u0438\\u0440\\u043e\\u0432\\u0430\\u0442\\u044c \\u043e\\u0442\\u0432\\u0435\\u0442 \\u0441\\u0438\\u0441\\u0442\\u0435\\u043c\\u044b","aria-label":"\\u041a\\u043e\\u043c\\u043c\\u0435\\u043d\\u0442\\u0438\\u0440\\u043e\\u0432\\u0430\\u0442\\u044c \\u043e\\u0442\\u0432\\u0435\\u0442 \\u0441\\u0438\\u0441\\u0442\\u0435\\u043c\\u044b",children:o.jsx(nm,{commented:a.commented})}),a.annotation?o.jsx("button",{type:"button",className:a.annotation.resolved?"autoruns-resolve-toggle resolved":"autoruns-resolve-toggle",onClick:()=>{_n(a.annotation,!a.annotation.resolved)},disabled:pr===a.annotation.annotation_id,title:a.annotation.resolved?"Отметить кейс как невыполненный":"Отметить кейс как выполненный","aria-label":a.annotation.resolved?"Отметить кейс как невыполненный":"Отметить кейс как выполненный",children:o.jsx(Mc,{resolved:a.annotation.resolved})}):null]}):null]})]}),o.jsx("p",{children:a.text}),y==="assistant"&&a.annotation?o.jsxs("div",{className:"autoruns-msg-annotation",children:[o.jsx("strong",{children:Qi(a.annotation.rating)}),o.jsx("span",{children:a.annotation.comment}),o.jsxs("span",{className:"muted",children:[a.annotation.manual_case_decision,a.annotation.annotation_author?` | ${a.annotation.annotation_author}`:""]})]}):null,(a.trace_id||a.reply_type)&&o.jsxs("footer",{children:[a.trace_id?o.jsxs("span",{children:["trace=",a.trace_id]}):null,a.reply_type?o.jsxs("span",{children:["reply_type=",a.reply_type]}):null]})]},a.message_id??`${y}-${c}`)})]})]}),j?o.jsx("div",{className:"autoruns-col autoruns-assistant-live-col",children:o.jsx(Fc,{sessionId:st,conversation:vn,inputValue:Dn,onInputChange:rn,selectedContextChip:bt,onSelectContextChip:vt,onClearContextChip:()=>vt(null),useMock:Jn,onUseMockChange:Ke,onSend:Cs,onClear:St,busy:hr,statusText:gr,errorMessage:vr,showCommentAction:!0,onCommentAssistantMessage:ro,isAssistantMessageCommented:Hn,canCommentAssistantMessage:er})}):null,T?o.jsxs("section",{className:"autoruns-col",children:[o.jsx("div",{className:"autoruns-col-header",children:o.jsx("h3",{children:"Режим декомпозиции"})}),o.jsxs("div",{className:"autoruns-meta-list",children:[o.jsxs("div",{children:[o.jsx("span",{children:"кейс:"}),o.jsx("strong",{children:On?.case_id??"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"домен:"}),o.jsx("strong",{children:On?.domain??"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"класс запроса:"}),o.jsx("strong",{children:On?.query_class??"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"trace:"}),o.jsx("strong",{children:On?.trace_id??"нет данных"})]})]}),o.jsx("h4",{children:"Шаги декомпозиции"}),(q?.decomposition.length??0)>0?o.jsx("ol",{className:"autoruns-decomposition-list",children:(q?.decomposition??[]).map((a,c)=>o.jsx("li",{children:a},`${c}-${a.slice(0,24)}`))}):o.jsx("p",{className:"muted",children:"В логах кейса нет явной декомпозиции."})]}):null,$?o.jsxs("section",{className:"autoruns-col",children:[o.jsx("div",{className:"autoruns-col-header",children:o.jsx("h3",{children:"Прогресс / регресс"})}),o.jsxs("div",{className:"autoruns-stats-grid",children:[o.jsxs("div",{children:[o.jsx("span",{children:"Последний score"}),o.jsx("strong",{children:ll(oe?.stats.latest_score_index??null)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Предыдущий"}),o.jsx("strong",{children:ll(oe?.stats.previous_score_index??null)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Тренд"}),o.jsx("strong",{children:oe?Ec(oe.stats.trend):"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Пробелы качества"}),o.jsx("strong",{children:oe?.stats.quality_gap_runs??0})]})]}),o.jsx("h4",{children:"Покрытие доменов (история)"}),Pc(oe?.stats.domain_coverage??[]),o.jsx("h4",{style:{marginTop:14},children:"Покрытие доменов (выбранный прогон)"}),Pc(te?.coverage.domain_coverage??[]),o.jsx("h4",{style:{marginTop:14},children:"Очереди фиксов пост-анализа"}),Yt?o.jsx("p",{className:"muted",children:"Собираю пост-анализ..."}):null,Yt?null:o.jsx("div",{className:"autoruns-stats-grid",children:Object.entries(Ft?.post_analysis.stats.by_queue??{}).map(([a,c])=>o.jsxs("div",{children:[o.jsx("span",{children:a}),o.jsx("strong",{children:c})]},a))}),o.jsxs("div",{className:"autoruns-autogen-list",children:[(Ft?.post_analysis.recommended_regression_candidates??[]).slice(0,12).map(a=>o.jsxs("article",{className:"autoruns-autogen-item",children:[o.jsxs("header",{children:[o.jsx("strong",{children:a.manual_case_decision}),o.jsxs("span",{children:[a.rating,"/5"]})]}),o.jsxs("div",{className:"autoruns-run-meta",children:[a.domain??"неизвестно"," / ",a.query_class??"неизвестно"]}),o.jsx("p",{children:a.comment})]},a.annotation_id)),!Yt&&(Ft?.post_analysis.recommended_regression_candidates.length??0)===0?o.jsx("p",{className:"muted",children:"Рекомендованных кандидатов пока нет."}):null]})]}):null,Y?o.jsxs("section",{className:"autoruns-col",children:[o.jsx("div",{className:"autoruns-col-header",children:o.jsx("h3",{children:"Комментарии"})}),o.jsx("h4",{children:"Размеченные ответы"}),o.jsxs("div",{className:"autoruns-comment-filter-row",children:[o.jsxs("label",{children:["Фильтр решений",o.jsxs("select",{value:Ae,onChange:a=>De(a.target.value),children:[o.jsx("option",{value:"all",children:"все"}),(rt.length>0?rt:Ge?.enum??[]).map(a=>o.jsx("option",{value:a,children:String(Ge?.labels?.[a]??a)},a))]})]}),o.jsx("button",{type:"button",className:"tab autoruns-resolved-filter-toggle",onClick:()=>We(a=>!a),children:$e?"Показать выполненные":"Скрыть выполненные"})]}),o.jsxs("div",{className:"autoruns-stats-grid",children:[o.jsxs("div",{children:[o.jsx("span",{children:"Комментариев"}),o.jsx("strong",{children:ut.length})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Средний рейтинг"}),o.jsx("strong",{children:yr===null?"нет данных":`${yr.toFixed(2)} / 5`})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Последний"}),o.jsx("strong",{children:ut.length>0?ur(ut[0].updated_at):"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Статус"}),o.jsx("strong",{children:Zt?"обновляю":"готово"})]})]}),o.jsxs("div",{className:"button-row",children:[o.jsx("button",{type:"button",disabled:Zt,onClick:()=>{At()},children:Zt?"Обновляю...":"Обновить список"}),o.jsx("button",{type:"button",className:"tab",disabled:Yt,onClick:()=>{dt()},children:Yt?"Идет пост-анализ...":"Обновить пост-анализ"})]}),o.jsxs("div",{className:"autoruns-comments-list",children:[Zt?o.jsx("p",{className:"muted",children:"Загружаю комментарии..."}):null,!Zt&&ut.length===0?o.jsx("p",{className:"muted",children:Se.length===0&&nn.length===0?"Пока нет откомментированных ответов.":"Нет открытых кейсов по текущему фильтру."}):null,ut.map(a=>{if(a.source==="assistant_live"){const y=a.assistant;return o.jsxs("article",{className:"autoruns-comment-item",children:[o.jsxs("div",{className:"autoruns-comment-head",children:[o.jsx("strong",{children:Qi(y.rating)}),o.jsx("div",{className:"autoruns-comment-head-actions",children:o.jsx("span",{children:ur(y.updated_at)})})]}),o.jsxs("div",{className:"autoruns-run-meta",children:["live-session: ",y.session_id]}),o.jsxs("div",{className:"autoruns-run-meta",children:["msg=",y.message_index]}),o.jsxs("div",{className:"autoruns-run-meta",children:["source=assistant_live",y.annotation_author?` | author=${y.annotation_author}`:""]}),y.context.question_text?o.jsxs("p",{children:["Q: ",y.context.question_text]}):null,y.context.answer_text?o.jsxs("p",{children:["A: ",y.context.answer_text]}):null,o.jsx("p",{children:y.comment})]},a.key)}const c=a.autorun;return o.jsxs("article",{className:Te===c.annotation_id?"autoruns-comment-item selected":"autoruns-comment-item",onClick:()=>{Sn(c)},role:"button",tabIndex:0,onKeyDown:y=>{(y.key==="Enter"||y.key===" ")&&(y.preventDefault(),Sn(c))},children:[o.jsxs("div",{className:"autoruns-comment-head",children:[o.jsx("strong",{children:Qi(c.rating)}),o.jsxs("div",{className:"autoruns-comment-head-actions",children:[o.jsx("span",{children:ur(c.updated_at)}),o.jsx("button",{type:"button",className:c.resolved?"autoruns-resolve-toggle resolved":"autoruns-resolve-toggle",onClick:y=>{y.preventDefault(),y.stopPropagation(),_n(c,!c.resolved)},disabled:pr===c.annotation_id,title:c.resolved?"Отметить кейс как невыполненный":"Отметить кейс как выполненный","aria-label":c.resolved?"Отметить кейс как невыполненный":"Отметить кейс как выполненный",children:o.jsx(Mc,{resolved:c.resolved})})]})]}),o.jsx("div",{className:"autoruns-run-meta",children:c.run_id}),o.jsxs("div",{className:"autoruns-run-meta",children:["case=",c.case_id," | msg=",c.message_index]}),o.jsxs("div",{className:"autoruns-run-meta",children:["decision=",c.manual_case_decision,c.annotation_author?` | author=${c.annotation_author}`:""]}),c.resolved_at?o.jsxs("div",{className:"autoruns-run-meta",children:["выполнено",": ",ur(c.resolved_at),c.resolved_by?` | by=${c.resolved_by}`:""]}):null,c.context.question_text?o.jsxs("p",{children:["Q: ",c.context.question_text]}):null,c.context.answer_text?o.jsxs("p",{children:["A: ",c.context.answer_text]}):null,o.jsx("p",{children:c.comment})]},a.key)})]}),Ne?o.jsxs(o.Fragment,{children:[o.jsx("h4",{children:"Тех-контекст брака"}),o.jsxs("div",{className:"autoruns-meta-list",children:[o.jsxs("div",{children:[o.jsx("span",{children:"trace:"}),o.jsx("strong",{children:Ne.technical_context.trace_id??"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"reply_type:"}),o.jsx("strong",{children:Ne.technical_context.reply_type??"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"domain:"}),o.jsx("strong",{children:Ne.technical_context.domain??"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"query_class:"}),o.jsx("strong",{children:Ne.technical_context.query_class??"нет данных"})]})]}),o.jsx("h4",{children:"JSON разбор"}),o.jsx(Gt,{value:{annotation_id:Ne.annotation_id,run_id:Ne.run_id,case_id:Ne.case_id,message_index:Ne.message_index,rating:Ne.rating,comment:Ne.comment,manual_case_decision:Ne.manual_case_decision,annotation_author:Ne.annotation_author,resolved:Ne.resolved,resolved_at:Ne.resolved_at,resolved_by:Ne.resolved_by,context:Ne.context,technical_context:Ne.technical_context,case_summary:Ne.case_summary?{case_id:Ne.case_summary.case_id,domain:Ne.case_summary.domain,query_class:Ne.case_summary.query_class,checks:Ne.case_summary.checks,metric_subscores:Ne.case_summary.metric_subscores}:null}})]}):null]}):null]}),ve.open?o.jsx("div",{className:"autoruns-comment-modal-backdrop",onClick:a=>{a.target===a.currentTarget&&Mt()},children:o.jsxs("div",{className:"autoruns-comment-modal",children:[o.jsx("h3",{children:"Комментарий к ответу ассистента"}),o.jsx("p",{className:"muted",children:"Комментарий будет добавлен в общий список комментариев справа с меткой `assistant_live`."}),Xr?o.jsxs("details",{className:"autoruns-prompt-details",open:!0,children:[o.jsx("summary",{children:"Вопрос пользователя"}),o.jsx("p",{className:"autoruns-comment-quote",children:Xr.text})]}):null,Ie?o.jsxs("details",{className:"autoruns-prompt-details",open:!0,children:[o.jsx("summary",{children:"Ответ ассистента"}),o.jsx("p",{className:"autoruns-comment-quote",children:Ie.text})]}):null,o.jsx("div",{className:"autoruns-rating-row",role:"group","aria-label":"Рейтинг ответа ассистента",children:[1,2,3,4,5].map(a=>o.jsx("button",{type:"button",className:ve.rating>=a?"autoruns-rating-dot active":"autoruns-rating-dot",onClick:()=>_t(c=>({...c,rating:a})),disabled:ve.saving,"aria-label":`Оценка ${a}`,children:ve.rating>=a?"●":"○"},a))}),o.jsx("div",{className:"autoruns-form-grid",children:o.jsxs("label",{children:["Автор комментария",o.jsx("input",{value:ve.annotationAuthor,onChange:a=>_t(c=>({...c,annotationAuthor:a.target.value})),placeholder:"manual_reviewer",disabled:ve.saving})]})}),o.jsxs("label",{children:["Комментарий",o.jsx("textarea",{value:ve.comment,onChange:a=>_t(c=>({...c,comment:a.target.value})),placeholder:"Что именно не так в ответе и что нужно исправить.",rows:4,disabled:ve.saving})]}),ve.error?o.jsx("p",{className:"error-text",children:ve.error}):null,o.jsxs("div",{className:"button-row",children:[o.jsx("button",{type:"button",onClick:()=>{Ns()},disabled:ve.saving,children:ve.saving?"Сохраняю...":"Готово"}),o.jsx("button",{type:"button",className:"tab",onClick:()=>Mt(),disabled:ve.saving,children:"Отмена"})]})]})}):null,ue.open?o.jsx("div",{className:"autoruns-comment-modal-backdrop",onClick:a=>{a.target===a.currentTarget&&k()},children:o.jsxs("div",{className:"autoruns-comment-modal",children:[o.jsx("h3",{children:"Комментарий к ответу системы"}),o.jsx("p",{className:"muted",children:"Оцените ответ по 5-балльной шкале и добавьте комментарий по браку."}),$n?o.jsxs(o.Fragment,{children:[o.jsxs("details",{className:"autoruns-prompt-details",open:!0,children:[o.jsx("summary",{children:"Вопрос пользователя"}),o.jsx("p",{className:"autoruns-comment-quote",children:Yr?.text??"Вопрос в диалоге не найден."})]}),o.jsxs("details",{className:"autoruns-prompt-details",open:!0,children:[o.jsx("summary",{children:"Ответ системы"}),o.jsx("p",{className:"autoruns-comment-quote",children:$n.text})]})]}):null,o.jsx("div",{className:"autoruns-rating-row",role:"group","aria-label":"Рейтинг ответа",children:[1,2,3,4,5].map(a=>o.jsx("button",{type:"button",className:ue.rating>=a?"autoruns-rating-dot active":"autoruns-rating-dot",onClick:()=>ot(c=>({...c,rating:a})),disabled:ue.saving,"aria-label":`Оценка ${a}`,children:ue.rating>=a?"●":"○"},a))}),o.jsxs("div",{className:"autoruns-form-grid",children:[o.jsxs("label",{children:["Решение по кейсу",o.jsx("select",{value:ue.manualCaseDecision,onChange:a=>ot(c=>({...c,manualCaseDecision:a.target.value})),disabled:ue.saving,children:(rt.length>0?rt:Ge?.enum??[sl]).map(a=>o.jsx("option",{value:a,children:String(Ge?.labels?.[a]??a)},a))})]}),o.jsxs("label",{children:["Автор комментария",o.jsx("input",{value:ue.annotationAuthor,onChange:a=>ot(c=>({...c,annotationAuthor:a.target.value})),placeholder:"manual_reviewer",disabled:ue.saving})]})]}),o.jsxs("label",{children:["Комментарий",o.jsx("textarea",{value:ue.comment,onChange:a=>ot(c=>({...c,comment:a.target.value})),placeholder:"Почему ответ бракованный, что именно пошло не так, какие технические детали проверить.",rows:4,disabled:ue.saving})]}),ue.error?o.jsx("p",{className:"error-text",children:ue.error}):null,o.jsxs("div",{className:"button-row",children:[o.jsx("button",{type:"button",onClick:()=>{ye()},disabled:ue.saving,children:ue.saving?"Сохраняю...":"Готово"}),o.jsx("button",{type:"button",className:"tab",onClick:()=>k(),disabled:ue.saving,children:"Отмена"})]})]})}):null]})}function Ac({value:i,modelOptions:p,modelsBusy:m,onChange:R,onReloadModels:j,onTestConnection:T,onSaveLocalConfig:$,lastStatus:Y,busy:F}){const I=i.llmProvider==="local",W=p.includes(i.model),[z,U]=x.useState(String(i.temperature)),[oe,Me]=x.useState(String(i.maxOutputTokens));x.useEffect(()=>{U(String(i.temperature))},[i.temperature]),x.useEffect(()=>{Me(String(i.maxOutputTokens))},[i.maxOutputTokens]);const te=q=>{const re=q.replace(",",".").trim();if(!re){U(String(i.temperature));return}const Se=Number(re);if(!Number.isFinite(Se)){U(String(i.temperature));return}R({...i,temperature:Se}),U(String(Se))},se=q=>{const re=q.trim();if(!re){Me(String(i.maxOutputTokens));return}const Se=Number.parseInt(re,10);if(!Number.isFinite(Se)||Se<=0){Me(String(i.maxOutputTokens));return}R({...i,maxOutputTokens:Se}),Me(String(Se))};return o.jsxs(Mn,{title:"LLM Connection",subtitle:"Switch between OpenAI cloud and local OpenAI-compatible server.",actions:o.jsx("span",{className:"status-chip",children:Y||"Status: not checked"}),children:[o.jsxs("div",{className:"grid-two",children:[o.jsxs("label",{children:["Provider",o.jsxs("select",{value:i.llmProvider,onChange:q=>{const re=q.target.value==="local"?"local":"openai";R({...i,llmProvider:re,baseUrl:re==="local"?"http://127.0.0.1:1234/v1":"https://api.openai.com/v1"})},children:[o.jsx("option",{value:"openai",children:"OpenAI (token)"}),o.jsx("option",{value:"local",children:"Local (LM Studio / OpenAI-compatible)"})]})]}),o.jsxs("label",{children:["Model",o.jsxs("select",{value:W?i.model:"__manual__",onChange:q=>{const re=q.target.value;re!=="__manual__"&&R({...i,model:re})},children:[o.jsx("option",{value:"__manual__",children:"Manual input"}),p.map(q=>o.jsx("option",{value:q,children:q},q))]})]}),o.jsxs("label",{children:["Model ID (manual)",o.jsx("input",{value:i.model,onChange:q=>R({...i,model:q.target.value}),placeholder:"qwen2.5-14b-instruct or lmstudio loaded model id"})]}),I?null:o.jsxs("label",{className:"full-width",children:["OpenAI API Key",o.jsx("input",{type:"password",value:i.apiKey,onChange:q=>R({...i,apiKey:q.target.value}),placeholder:"sk-..."})]}),o.jsxs("label",{className:I?"full-width":void 0,children:[I?"Local server base URL":"Base URL",o.jsx("input",{value:i.baseUrl,onChange:q=>R({...i,baseUrl:q.target.value}),placeholder:I?"http://127.0.0.1:1234/v1":"https://api.openai.com/v1"})]}),o.jsxs("label",{children:["Temperature",o.jsx("input",{type:"number",step:"0.1",value:z,onChange:q=>U(q.target.value),onBlur:q=>te(q.target.value),onKeyDown:q=>{q.key==="Enter"&&te(q.target.value)}})]}),o.jsxs("label",{children:["Max output tokens",o.jsx("input",{type:"number",value:oe,onChange:q=>Me(q.target.value),onBlur:q=>se(q.target.value),onKeyDown:q=>{q.key==="Enter"&&se(q.target.value)}})]})]}),o.jsxs("div",{className:"button-row",children:[o.jsx("button",{type:"button",onClick:()=>$(),children:"Save local config"}),o.jsx("button",{type:"button",onClick:()=>j(),disabled:F||m,children:m?"Loading models...":"Load model list"}),o.jsx("button",{type:"button",onClick:()=>T(),disabled:F,children:F?"Checking...":"Test connection"})]})]})}function om({items:i,onRefresh:p,onOpenTrace:m}){return o.jsx(Mn,{title:"История нормализаций",subtitle:"Короткий вопрос, confidence, route hint и статус валидации.",actions:o.jsx("button",{type:"button",onClick:()=>p(),children:"Обновить"}),children:o.jsxs("div",{className:"history-list",children:[i.length===0?o.jsx("p",{className:"muted",children:"История пока пустая."}):null,i.map(R=>o.jsxs("button",{type:"button",className:"history-item",onClick:()=>m(R.trace_id),children:[o.jsxs("div",{className:"history-row",children:[o.jsx("strong",{children:R.route_hint??"route: n/a"}),o.jsx("span",{children:R.validation_passed?"schema: ok":"schema: fail"})]}),o.jsx("p",{children:R.question_short}),o.jsxs("div",{className:"history-row",children:[o.jsx("span",{children:R.model}),o.jsx("span",{children:new Date(R.timestamp).toLocaleString("ru-RU")})]})]},R.trace_id))]})})}function cr(i){return i==null||i===""?"—":String(i)}function lm({result:i}){return o.jsx(Mn,{title:"Runtime метрики",subtitle:"trace_id, токены, latency и статус валидации.",children:o.jsxs("div",{className:"metrics-grid",children:[o.jsxs("div",{children:[o.jsx("span",{children:"trace_id"}),o.jsx("strong",{children:cr(i?.trace_id)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"request_started_at"}),o.jsx("strong",{children:cr(i?new Date(Date.now()-i.latency_ms).toISOString():null)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"request_finished_at"}),o.jsx("strong",{children:cr(i?new Date().toISOString():null)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"latency_ms"}),o.jsx("strong",{children:cr(i?.latency_ms)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"input_tokens"}),o.jsx("strong",{children:cr(i?.usage?.input_tokens)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"output_tokens"}),o.jsx("strong",{children:cr(i?.usage?.output_tokens)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"total_tokens"}),o.jsx("strong",{children:cr(i?.usage?.total_tokens)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"validation_status"}),o.jsx("strong",{children:i?.validation?.passed?"passed":"failed"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"prompt_version"}),o.jsx("strong",{children:cr(i?.prompt_version)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"schema_version"}),o.jsx("strong",{children:cr(i?.schema_version)})]})]})})}const im={normalized:"Normalized JSON",fragments:"Fragment View",scope:"Scope View",flags:"Flags View",route:"Route Simulation",raw:"Raw model output",validation:"Validation",logs:"Logs"};function am(i){return i&&typeof i=="object"?i:null}function um({tab:i,onTabChange:p,result:m,appLogs:R}){const j=["normalized","fragments","scope","flags","route","raw","validation","logs"],T=am(m?.normalized),$=String(T?.schema_version??""),Y=$==="normalized_query_v2"||$==="normalized_query_v2_0_1"||$==="normalized_query_v2_0_2",F=Y?{fragments:T?.fragments??[],discarded_fragments:T?.discarded_fragments??[]}:{note:"Fragment View доступен для normalized_query_v2."},I=Y?{message_in_scope:T?.message_in_scope??null,scope_confidence:T?.scope_confidence??null,contains_multiple_tasks:T?.contains_multiple_tasks??null,global_notes:T?.global_notes??null}:{note:"Scope View доступен для normalized_query_v2."},W=Y?Array.isArray(T?.fragments)?(T?.fragments).map(z=>({fragment_id:z.fragment_id??null,domain_relevance:z.domain_relevance??null,candidate_labels:z.candidate_labels??[],execution_readiness:z.execution_readiness??null,clarification_reason:z.clarification_reason??null,soft_assumption_used:z.soft_assumption_used??[],route_status:z.route_status??null,no_route_reason:z.no_route_reason??null,flags:z.flags??{}})):[]:{note:"Flags View доступен для normalized_query_v2."};return o.jsxs(Mn,{title:"Выходные данные",subtitle:"Structured output и диагностические вкладки.",children:[o.jsx("div",{className:"tab-row",children:j.map(z=>o.jsx("button",{type:"button",className:i===z?"tab active":"tab",onClick:()=>p(z),children:im[z]},z))}),i==="normalized"?o.jsx(Gt,{value:m?.normalized??{note:"Нет данных."}}):null,i==="fragments"?o.jsx(Gt,{value:F}):null,i==="scope"?o.jsx(Gt,{value:I}):null,i==="flags"?o.jsx(Gt,{value:W}):null,i==="route"?o.jsx(Gt,{value:m?.route_hint_summary??{note:"Нет данных."}}):null,i==="raw"?o.jsx(Gt,{value:m?.raw_model_output??{note:"Нет данных."}}):null,i==="validation"?o.jsx(Gt,{value:m?.validation??{note:"Нет данных."}}):null,i==="logs"?o.jsx(Gt,{value:R}):null]})}function Tc({value:i,onChange:p,presets:m,selectedPresetId:R,onSelectPreset:j,onLoadPreset:T,onSavePreset:$,onResetDefaults:Y,onDiffPrevious:F,presetName:I,onPresetNameChange:W,diffSummary:z}){return o.jsxs(Mn,{title:"Prompt Manager",subtitle:"Системный, developer и domain уровни управляются отдельно.",children:[o.jsxs("div",{className:"prompt-manager-grid",children:[o.jsxs("label",{children:["Системный prompt",o.jsx("textarea",{value:i.systemPrompt,onChange:U=>p({...i,systemPrompt:U.target.value}),rows:6})]}),o.jsxs("label",{children:["Developer / Instruction prompt",o.jsx("textarea",{value:i.developerPrompt,onChange:U=>p({...i,developerPrompt:U.target.value}),rows:6})]}),o.jsxs("label",{children:["Domain prompt",o.jsx("textarea",{value:i.domainPrompt,onChange:U=>p({...i,domainPrompt:U.target.value}),rows:6})]}),o.jsxs("label",{children:["Schema notes",o.jsx("textarea",{value:i.schemaNotes,onChange:U=>p({...i,schemaNotes:U.target.value}),rows:6})]}),o.jsxs("label",{className:"full-width",children:["Few-shot examples",o.jsx("textarea",{value:i.fewShotExamples,onChange:U=>p({...i,fewShotExamples:U.target.value}),rows:8})]})]}),o.jsxs("div",{className:"button-row",children:[o.jsxs("select",{value:R,onChange:U=>j(U.target.value),children:[o.jsx("option",{value:"",children:"Выберите preset..."}),m.map(U=>o.jsx("option",{value:U.id,children:U.name},U.id))]}),o.jsx("button",{type:"button",onClick:()=>T(),children:"Загрузить preset"}),o.jsx("input",{value:I,onChange:U=>W(U.target.value),placeholder:"Имя для сохранения"}),o.jsx("button",{type:"button",onClick:()=>$(),children:"Сохранить preset"}),o.jsx("button",{type:"button",onClick:()=>F(),children:"Diff с предыдущим"}),o.jsx("button",{type:"button",onClick:()=>Y(),children:"Сбросить к default"})]}),z?o.jsx("p",{className:"diff-summary",children:z}):null]})}function cm({value:i,onChange:p,onApplyBatchFormat:m,onNormalize:R,busy:j,useMock:T,onUseMockChange:$,errorMessage:Y}){return o.jsxs(Mn,{title:"Запрос пользователя",subtitle:"NDC semantic front-end: нормализуем, но не отвечаем за бухгалтерскую суть.",children:[o.jsxs("div",{className:"grid-two",children:[o.jsxs("label",{className:"full-width",children:["Raw user question",o.jsx("textarea",{value:i.userQuestion,onChange:F=>p({...i,userQuestion:F.target.value}),rows:6,placeholder:"Например: По каким покупателям у нас на конец июня висят отгрузки без оплаты..."})]}),o.jsxs("label",{className:"full-width",children:["Batch queries (`;` separator)",o.jsx("textarea",{value:i.batchQuestionsRaw,onChange:F=>p({...i,batchQuestionsRaw:F.target.value}),onBlur:()=>m(),rows:8,placeholder:"Вопрос 1; Вопрос 2; Вопрос 3"})]}),o.jsxs("label",{children:["Optional period context",o.jsx("input",{value:i.periodHint,onChange:F=>p({...i,periodHint:F.target.value})})]}),o.jsxs("label",{children:["Optional business context",o.jsx("input",{value:i.businessContext,onChange:F=>p({...i,businessContext:F.target.value})})]}),o.jsxs("label",{children:["Optional expected route (eval)",o.jsx("input",{value:i.expectedRoute,onChange:F=>p({...i,expectedRoute:F.target.value})})]})]}),o.jsxs("div",{className:"button-row",children:[o.jsxs("label",{className:"checkbox-row",children:[o.jsx("input",{type:"checkbox",checked:T,onChange:F=>$(F.target.checked)}),"Mock-режим (без вызова OpenAI)"]}),o.jsx("button",{type:"button",onClick:()=>m(),disabled:j||!i.batchQuestionsRaw.trim(),children:"Применить `;` в переносы"}),o.jsx("button",{type:"button",onClick:()=>R(!1),disabled:j||!i.userQuestion.trim(),children:j?"Нормализуем...":"Normalize"}),o.jsx("button",{type:"button",onClick:()=>R(!0),disabled:j||!i.userQuestion.trim(),children:j?"Сохраняем...":"Normalize + Save as test case"})]}),Y?o.jsx("p",{className:"error-text",children:Y}):null]})}function dm({runs:i,selectedRunId:p,onSelectRun:m,onStartRun:R,onFinishRun:j,onRefreshRuns:T,onRunEval:$,onCopyEvalReport:Y,evalBusy:F,traceItems:I,evalReport:W}){return o.jsxs(Mn,{title:"NDC Run Monitor",subtitle:"Важно: кнопка Запустить run создает только run-сущность. Кнопка eval запускает batch-проверку normalizer v2.0.2.",children:[o.jsxs("div",{className:"button-row",children:[o.jsx("button",{type:"button",onClick:()=>R(),children:"Запустить run"}),o.jsx("button",{type:"button",onClick:()=>j(),disabled:!p,children:"Завершить выбранный run"}),o.jsx("button",{type:"button",onClick:()=>T(),children:"Обновить runs"}),o.jsx("button",{type:"button",onClick:()=>$(),disabled:F,children:F?"Идет eval v2.0.2...":"Запустить eval v2.0.2"})]}),o.jsxs("div",{className:"runtime-stack",children:[o.jsxs("div",{className:"runtime-runs",children:[i.map(z=>o.jsxs("button",{type:"button",className:p===z.runId?"history-item selected":"history-item",onClick:()=>m(z.runId),children:[o.jsxs("div",{className:"history-row",children:[o.jsx("strong",{children:z.status}),o.jsx("span",{children:z.runId})]}),o.jsxs("div",{className:"history-row",children:[o.jsx("span",{children:z.sessionId}),o.jsx("span",{children:new Date(z.updatedAt).toLocaleString("ru-RU")})]})]},z.runId)),i.length===0?o.jsx("p",{className:"muted",children:"Нет активных запусков."}):null]}),o.jsxs("div",{className:"runtime-details",children:[o.jsx("h3",{children:"Trace выбранного run"}),o.jsx(Gt,{value:I}),o.jsxs("div",{className:"eval-report-wrap",children:[o.jsx("h3",{style:{marginTop:12},children:"Отчет eval"}),o.jsx(Gt,{value:W??{note:"Eval пока не запускался"}}),o.jsx("button",{type:"button",className:"copy-cube-button",title:"Скопировать отчет eval",onClick:()=>Y(),children:"⧉"})]})]})]})]})}const fm={llmProvider:"openai",apiKey:"",model:"gpt-4o-mini",baseUrl:"https://api.openai.com/v1",temperature:0,maxOutputTokens:700},Ic={systemPrompt:"Ты semantic-normalizer для бухгалтерского ассистента NDC. Возвращай только JSON по схеме normalized_query_v2_0_2.",developerPrompt:"Сначала делай decomposition сообщения на task fragments, затем определяй domain scope и route-critical flags. Для каждого fragment заполняй execution_readiness + route_status + no_route_reason. Если fragment routable, не оставляй его в no_route.",domainPrompt:"Контур: данные текущего предприятия в 1С/NDC. In-scope: документы, проводки, взаиморасчеты, остатки, периодное закрытие, аномалии и контрольные проверки. Out-of-scope: общая теория, законы и оффтоп.",schemaNotes:"schema_version: normalized_query_v2_0_2. Строгий JSON без дополнительных полей.",fewShotExamples:"Q: Проверь по поставщикам хвосты и разложи цепочку документов/оплат. => fragment in_scope, flags: multi_entity + chain_explanation. Q: Как вообще по ФСБУ? => out_of_scope/generic_accounting."},mm={userQuestion:"",batchQuestionsRaw:"",periodHint:"",businessContext:"",expectedRoute:""},Wi={colors:{backgroundRgb:"18, 18, 18",mainSurfaceRgb:"25, 25, 25",horizontalSurfaceRgb:"30, 30, 30",focusSurfaceRgb:"35, 35, 35",assistantChipRgb:"18, 18, 18",assistantChipHoverRgb:"44, 44, 44",assistantChipSelectedRgb:"167, 59, 255",assistantChipSelectedTextRgb:"240, 240, 240",activeRgb:"167, 59, 255",activeTextRgb:"240, 240, 240",textMainRgb:"240, 240, 240",textMutedRgb:"166, 166, 166",dangerRgb:"126, 126, 126",scrollbarTrackRgb:"20, 20, 20",scrollbarThumbRgb:"30, 30, 30",scrollbarThumbHoverRgb:"30, 50, 30"},layout:{modeColumnWidthPx:406,modeToggleWidthPx:188}},Lc="ndc_normalizer_session_config_v1",Dc="ndc_autoruns_layout_config_v1",pm="ndc-autoruns-save",Ki=["Анализ запроса","Получение данных","Подготовка ответа"],hm="assistant",qi="normalizer_v2_0_2",zc="address_query_runtime_v1",gm=["normalized","fragments","scope","flags","route","raw","validation","logs"],Gi="manual_reviewer";function vm(i){return`[${new Date().toLocaleTimeString("ru-RU")}] ${i}`}function ym(i,p){if(!p)return"Previous preset is not selected.";const R=["systemPrompt","developerPrompt","domainPrompt","schemaNotes","fewShotExamples"].filter(j=>i[j]!==p[j]).map(j=>`${j}: ${Math.abs(i[j].length-p[j].length)} chars delta`);return R.length===0?"No changes against previous preset.":`Changed fields: ${R.length}. ${R.join(" | ")}`}function xm(i,p){const m=i.trim();if(!m)return"";if(!p)return m;const R=m.toLowerCase(),j=p.anchor_text.trim(),T=j.toLowerCase();return T&&R.includes(T)?m:`По выбранному объекту "${j}": ${m}`}function _m(){const[i,p]=x.useState(fm),[m,R]=x.useState(Ic),[j,T]=x.useState(mm),[$,Y]=x.useState(null),[F,I]=x.useState([]),[W,z]=x.useState([]),[U,oe]=x.useState("normalized"),[Me,te]=x.useState(!1),[se,q]=x.useState(!1),[re,Se]=x.useState([]),[Pe,Ae]=x.useState(""),[De,$e]=x.useState([]),[We,Ge]=x.useState(""),[Ze,rt]=x.useState("NDC custom preset"),[ie,Te]=x.useState(null),[Fe,fe]=x.useState(""),[Re,me]=x.useState(!1),[D,Q]=x.useState([]),[O,h]=x.useState(""),[C,G]=x.useState([]),[ae,ce]=x.useState(!1),[de,xe]=x.useState(null),[ge,ee]=x.useState(""),[ke,Ft]=x.useState(hm),[qn,An]=x.useState(!0),[Tn,dr]=x.useState(!0),[Jt,Yt]=x.useState(!0),[Gn,mn]=x.useState(!0),[Ut,Xt]=x.useState(!0),[pn,fr]=x.useState(!0),[In,mr]=x.useState(!0),[Ln,Zt]=x.useState(!0),[en,pr]=x.useState(!0),[Bt,hn]=x.useState(!0),[Be,st]=x.useState(!0),[gn,vn]=x.useState(!0),[tn,nn]=x.useState(!0),[Ct,Dn]=x.useState(!0),[rn,bt]=x.useState(!0),[vt,Jn]=x.useState(!0),[Ke,hr]=x.useState(""),[yn,gr]=x.useState([]),[sn,vr]=x.useState(""),[Nt,Yn]=x.useState(null),[yt,Jr]=x.useState(!1),[xt,Et]=x.useState(""),[zn,ue]=x.useState(""),[ot,ve]=x.useState([]),[_t,Pt]=x.useState(!1),[we,lt]=x.useState({open:!1,messageIndex:-1,rating:3,comment:"",annotationAuthor:Gi,saving:!1,error:""}),Rt=x.useRef(!1),On=x.useRef(!1);x.useEffect(()=>{const d=document.documentElement,{colors:P}=Wi;d.style.setProperty("--rgb-background",P.backgroundRgb),d.style.setProperty("--rgb-surface-main",P.mainSurfaceRgb),d.style.setProperty("--rgb-surface-horizontal",P.horizontalSurfaceRgb),d.style.setProperty("--rgb-surface-focus",P.focusSurfaceRgb),d.style.setProperty("--rgb-assistant-chip",P.assistantChipRgb),d.style.setProperty("--rgb-assistant-chip-hover",P.assistantChipHoverRgb),d.style.setProperty("--rgb-assistant-chip-selected",P.assistantChipSelectedRgb),d.style.setProperty("--rgb-assistant-chip-selected-text",P.assistantChipSelectedTextRgb),d.style.setProperty("--rgb-active",P.activeRgb),d.style.setProperty("--rgb-active-text",P.activeTextRgb),d.style.setProperty("--rgb-text-main",P.textMainRgb),d.style.setProperty("--rgb-text-muted",P.textMutedRgb),d.style.setProperty("--rgb-danger",P.dangerRgb),d.style.setProperty("--rgb-scrollbar-track",P.scrollbarTrackRgb),d.style.setProperty("--rgb-scrollbar-thumb",P.scrollbarThumbRgb),d.style.setProperty("--rgb-scrollbar-thumb-hover",P.scrollbarThumbHoverRgb),d.style.setProperty("--mode-column-width",`${Wi.layout.modeColumnWidthPx}px`),d.style.setProperty("--mode-toggle-width",`${Wi.layout.modeToggleWidthPx}px`)},[]);const J=d=>{z(P=>[vm(d),...P].slice(0,300))};function Ne(){let d=0;Et(Ki[0]);const P=window.setInterval(()=>{d=Math.min(d+1,Ki.length-1),Et(Ki[d])},650);return()=>window.clearInterval(P)}x.useEffect(()=>{const d=localStorage.getItem(Lc);if(d)try{const k=JSON.parse(d);p(ye=>({...ye,llmProvider:k.llmProvider==="local"?"local":"openai",model:k.model??ye.model,baseUrl:k.baseUrl??ye.baseUrl,temperature:k.temperature??ye.temperature,maxOutputTokens:k.maxOutputTokens??ye.maxOutputTokens}))}catch{}const P=localStorage.getItem(Dc);if(P)try{const k=JSON.parse(P);(k.uiMode==="assistant"||k.uiMode==="decomposition"||k.uiMode==="autoruns")&&Ft(k.uiMode),k.activeTab&&gm.includes(k.activeTab)&&oe(k.activeTab),typeof k.showAutorunsAssistantMode=="boolean"&&An(k.showAutorunsAssistantMode),typeof k.showAutorunsDecompositionMode=="boolean"&&dr(k.showAutorunsDecompositionMode),typeof k.showAutorunsProgressMode=="boolean"&&Yt(k.showAutorunsProgressMode),typeof k.showAutorunsCommentsMode=="boolean"&&mn(k.showAutorunsCommentsMode),typeof k.showAssistantConnectionMode=="boolean"&&Xt(k.showAssistantConnectionMode),typeof k.showAssistantPromptMode=="boolean"&&fr(k.showAssistantPromptMode),typeof k.showAssistantChatMode=="boolean"&&mr(k.showAssistantChatMode),typeof k.showAssistantCommentsMode=="boolean"&&Zt(k.showAssistantCommentsMode),typeof k.showAssistantSamMode=="boolean"&&pr(k.showAssistantSamMode),typeof k.showDecompositionConnectionMode=="boolean"&&hn(k.showDecompositionConnectionMode),typeof k.showDecompositionPromptMode=="boolean"&&st(k.showDecompositionPromptMode),typeof k.showDecompositionQueryMode=="boolean"&&vn(k.showDecompositionQueryMode),typeof k.showDecompositionOutputMode=="boolean"&&nn(k.showDecompositionOutputMode),typeof k.showDecompositionMetricsMode=="boolean"&&Dn(k.showDecompositionMetricsMode),typeof k.showDecompositionHistoryMode=="boolean"&&bt(k.showDecompositionHistoryMode),typeof k.showDecompositionRuntimeMode=="boolean"&&Jn(k.showDecompositionRuntimeMode),k.prompts&&(R(ye=>({...ye,...k.prompts})),On.current=!0)}catch{}$n(),Yr(),xn()},[]);async function $n(){try{const d=await Ce.loadHistory();I(d.items??[])}catch(d){J(`History load error: ${d instanceof Error?d.message:String(d)}`)}}async function Yr(){try{const P=(await Ce.loadPresets()).presets??[];if($e(P),On.current){Rt.current=!0;return}if(Rt.current)return;const k=P.find(ye=>ye.prompt_version===qi)??P.find(ye=>ye.id==="default-normalizer-v2_0_2");if(!k){Rt.current=!0,J(`Preset autoload skipped: ${qi} not found.`);return}Ge(k.id),Te(m),R({systemPrompt:k.systemPrompt,developerPrompt:k.developerPrompt,domainPrompt:k.domainPrompt,schemaNotes:k.schemaNotes??"",fewShotExamples:k.fewShotExamples??""}),Rt.current=!0,J(`Preset autoloaded: ${k.name} (${k.prompt_version}).`)}catch(d){J(`Presets load error: ${d instanceof Error?d.message:String(d)}`)}}async function xn(){try{const d=await Ce.listRuns();Q(d.items??[])}catch(d){J(`Runs load error: ${d instanceof Error?d.message:String(d)}`)}}function Ie(){localStorage.setItem(Lc,JSON.stringify({model:i.model,llmProvider:i.llmProvider,baseUrl:i.baseUrl,temperature:i.temperature,maxOutputTokens:i.maxOutputTokens})),J("Local config saved (without API key).")}function Xr(){localStorage.setItem(Dc,JSON.stringify({uiMode:ke,activeTab:U,showAutorunsAssistantMode:qn,showAutorunsDecompositionMode:Tn,showAutorunsProgressMode:Jt,showAutorunsCommentsMode:Gn,showAssistantConnectionMode:Ut,showAssistantPromptMode:pn,showAssistantChatMode:In,showAssistantCommentsMode:Ln,showAssistantSamMode:en,showDecompositionConnectionMode:Bt,showDecompositionPromptMode:Be,showDecompositionQueryMode:gn,showDecompositionOutputMode:tn,showDecompositionMetricsMode:Ct,showDecompositionHistoryMode:rn,showDecompositionRuntimeMode:vt,prompts:m})),window.dispatchEvent(new CustomEvent(pm)),J("UI layout and prompts saved.")}async function ut(){te(!0),ee("");try{const d=await Ce.testConnection(i);d.provider==="local"?d.model_found===!0?(Ae(`LOCAL OK - ${d.model}`),J(`Local model is available: ${d.model} (catalog size=${d.models_count??"n/a"}).`)):d.model_found===!1?(Ae(`LOCAL OK, model not loaded - ${d.model}`),J(`Local server is reachable, but model '${d.model}' is not in loaded catalog. Use 'Load model list' and select one of loaded models.`)):(Ae(`LOCAL OK (model list unavailable) - ${d.model}`),J("Local server is reachable, but model catalog could not be verified.")):(Ae(`OPENAI OK - ${d.model}`),J(`OpenAI connection ok: ${d.model}`))}catch(d){const P=d instanceof Error?d.message:String(d);Ae("Connection error"),ee(`Test connection: ${P}`),J(`Test connection error: ${P}`)}finally{te(!1)}}async function yr(){q(!0);try{const P=(await Ce.listModels(i)).models??[];Se(P),P.length>0&&p(k=>k.model&&P.includes(k.model)?k:{...k,model:P[0]}),J(`Model catalog loaded (${i.llmProvider}): ${P.length} items.`)}catch(d){const P=d instanceof Error?d.message:String(d);J(`Load model list error: ${P}`)}finally{q(!1)}}x.useEffect(()=>{Se([])},[i.llmProvider,i.baseUrl]);async function Fn(d){te(!0),ee("");try{const P=await Ce.normalize({connection:i,prompts:m,promptVersion:"normalizer_v2_0_2",query:{userQuestion:j.userQuestion,periodHint:j.periodHint,businessContext:j.businessContext,expectedRoute:j.expectedRoute},saveAsTestCase:d,useMock:Re});Y(P),oe("normalized"),J(`Normalize done: trace=${P.trace_id}, validation=${P.validation.passed?"passed":"failed"}`),$n()}catch(P){const k=P instanceof Error?P.message:String(P);ee(`Normalize: ${k}`),J(`Normalize error: ${k}`)}finally{te(!1)}}function le(){const d=De.find(P=>P.id===We);if(!d){J("Preset is not selected.");return}Te(m),R({systemPrompt:d.systemPrompt,developerPrompt:d.developerPrompt,domainPrompt:d.domainPrompt,schemaNotes:d.schemaNotes??"",fewShotExamples:d.fewShotExamples??""}),J(`Preset loaded: ${d.name}`)}async function Un(){try{await Ce.savePreset({name:Ze||"NDC preset",prompt_version:"normalizer_v2_0_2",systemPrompt:m.systemPrompt,developerPrompt:m.developerPrompt,domainPrompt:m.domainPrompt,schemaNotes:m.schemaNotes,fewShotExamples:m.fewShotExamples}),J("Preset saved."),await Yr()}catch(d){J(`Preset save error: ${d instanceof Error?d.message:String(d)}`)}}function Mt(){R(Ic),J("Prompt panel reset to defaults.")}function ct(){const d=ym(m,ie);fe(d),J(d)}function ks(){const d=j.batchQuestionsRaw.split(";").map(P=>P.trim()).filter(Boolean).join(` + +`);d&&(T(P=>({...P,batchQuestionsRaw:d})),J("Batch field formatted: `;` converted to blank-line separators."))}async function St(d){try{const k=(await Ce.loadTrace(d)).trace,ye=k.parsed_normalized_json??null;Y({trace_id:String(k.trace_id??d),ok:!!k.validation_result?.passed,normalized:ye,route_hint_summary:k.route_hint_summary??(ye?{route_hint:ye.route_hint??null,confidence:ye.confidence?.route_hint??null}:null),raw_model_output:k.raw_model_response??{},validation:k.validation_result??{passed:!1,errors:["validation not found"]},usage:k.usage??{input_tokens:0,output_tokens:0,total_tokens:0},latency_ms:Number(k.latency_ms??0),prompt_version:String(k.prompt_version??"unknown"),schema_version:String(k.schema_version??"unknown")}),oe("raw"),ee(""),J(`Trace opened: ${d}`)}catch(P){const k=P instanceof Error?P.message:String(P);ee(`Trace: ${k}`),J(`Trace open error ${d}: ${k}`)}}async function Cs(){try{const d=await Ce.startRun();h(d.run.runId),J(`Run started: ${d.run.runId}`),J("Tip: start run does not execute normalize by itself. Use 'Run eval v2.0.2' button."),await xn()}catch(d){J(`Run start error: ${d instanceof Error?d.message:String(d)}`)}}async function Zr(){if(O)try{await Ce.finishRun(O),J(`Run finished: ${O}`),await xn()}catch(d){J(`Run finish error: ${d instanceof Error?d.message:String(d)}`)}}async function es(){ce(!0),ee("");try{J("Starting eval in v2 contour.");const d=j.batchQuestionsRaw.trim()||j.userQuestion.trim();if(!d)throw new Error("Fill batch field or Raw user question first.");const P=await Ce.runEval({connection:i,prompts:m,promptVersion:"normalizer_v2_0_2",mode:"single-pass-strict",rawQuestions:d,useMock:Re});xe(P.report),J("Eval v2.0.2 run finished.");const k=P.report;if(k.run_id&&J(`Eval run id: ${k.run_id}`),k.metrics){const ye=k.metrics;J(`Eval metrics v2.0.2: schema=${ye.schema_validation_pass_rate??"n/a"}%, route_accuracy=${ye.route_resolution_accuracy??"n/a"}%, no_route_precision=${ye.no_route_precision??"n/a"}%, state_consistency=${ye.execution_state_consistency_rate??"n/a"}%`)}await $n()}catch(d){const P=d instanceof Error?d.message:String(d);P.includes("Legacy eval runner supports normalized_query_v1 only")?(xe({status:"plan_only",prompt_version:"normalizer_v2",reason:"backend eval runner is still legacy-v1 only",plan_file:"reports/v2_pilot_eval_plan.md",next_steps:["run cheap mock sanity for schema/fragment/scope","run small real batch (10-15 messages, temperature=0)","run challenge-30 replay with v2 metrics"]}),J("Backend is legacy-only for eval right now. Showing v2 pilot plan.")):(ee(`Eval: ${P}`),J(`Eval run error: ${P}`))}finally{ce(!1)}}async function Xn(){try{const d=JSON.stringify(de??{},null,2);await navigator.clipboard.writeText(d),J("Eval report copied to clipboard.")}catch(d){J(`Eval report copy error: ${d instanceof Error?d.message:String(d)}`)}}const Bn=x.useMemo(()=>{const d=new Map;for(const P of ot)P.message_id&&d.set(P.message_id,P);return d},[ot]),At=we.messageIndex>=0?yn[we.messageIndex]??null:null,wt=x.useMemo(()=>{if(we.messageIndex<0)return null;for(let d=we.messageIndex-1;d>=0;d-=1){const P=yn[d];if(P?.role==="user")return P}return null},[we.messageIndex,yn]);async function xr(d){if(!d.trim()){ve([]);return}Pt(!0);try{const P=await Ce.loadAssistantAnnotations({session_id:d,limit:400});ve(P.items??[])}catch(P){const k=P instanceof Error?P.message:String(P);J(`Assistant annotations load error: ${k}`)}finally{Pt(!1)}}function dt(d){lt(P=>P.saving&&!d?.force?P:{open:!1,messageIndex:-1,rating:3,comment:"",annotationAuthor:Gi,saving:!1,error:""})}function zr(d,P){if(d.role!=="assistant")return;const k=Ke.trim(),ye=String(d.session_id??"").trim();if(!(k||ye)){ue("Сначала получите ответ ассистента в активной сессии.");return}!k&&ye&&hr(ye);const Hn=Bn.get(d.message_id)??null;lt({open:!0,messageIndex:P,rating:Hn?.rating??3,comment:Hn?.comment??"",annotationAuthor:Hn?.annotation_author??Gi,saving:!1,error:""})}function bn(d){return d.role==="assistant"}function Tt(d){return d.role==="assistant"&&Bn.has(d.message_id)}async function Ht(){if(!Ke.trim()){lt(d=>({...d,error:"Сессия ассистента не найдена."}));return}if(!(we.messageIndex<0)){if(!we.comment.trim()){lt(d=>({...d,error:"Добавьте комментарий."}));return}lt(d=>({...d,saving:!0,error:""}));try{const d=await Ce.saveAssistantAnnotation({session_id:Ke,message_index:we.messageIndex,rating:we.rating,comment:we.comment.trim(),annotation_author:we.annotationAuthor.trim()||void 0});ve(P=>{const k=[...P],ye=k.findIndex(er=>er.annotation_id===d.annotation.annotation_id);return ye>=0?k[ye]=d.annotation:k.unshift(d.annotation),k.sort((er,Hn)=>Date.parse(Hn.updated_at)-Date.parse(er.updated_at))}),dt({force:!0})}catch(d){const P=d instanceof Error?d.message:String(d);lt(k=>({...k,saving:!1,error:P}))}}}function Vt(){hr(""),gr([]),vr(""),Yn(null),Et(""),ue(""),ve([]),dt({force:!0}),J("Assistant session reset.")}async function Zn(){const d=xm(sn,Nt);if(!d)return;Jr(!0),ue(""),vr(""),gr(k=>[...k,{message_id:`local-${Date.now()}`,session_id:Ke||"pending",role:"user",text:d,reply_type:null,created_at:new Date().toISOString(),trace_id:null,debug:null}]);const P=Ne();try{const k=await Ce.sendAssistantMessage({connection:i,prompts:m,userMessage:d,sessionId:Ke||void 0,promptVersion:zc,useMock:Re});hr(k.session_id),gr(k.conversation),Et("Ответ готов"),await xr(k.session_id),J(`Assistant reply received: trace=${k.debug.trace_id}`)}catch(k){const ye=k instanceof Error?k.message:String(k);ue(ye),Et("Ошибка ассистента"),J(`Assistant error: ${ye}`)}finally{P(),Jr(!1)}}return x.useEffect(()=>{if(!Ke.trim()){ve([]);return}xr(Ke)},[Ke]),x.useEffect(()=>{if(!O){G([]);return}Ce.runTrace(O).then(d=>G(d.items)).catch(d=>J(`Run trace error: ${d instanceof Error?d.message:String(d)}`))},[O]),o.jsxs("main",{className:`app-root ${ke==="assistant"||ke==="decomposition"||ke==="autoruns"?"app-root-autoruns":""}`,children:[o.jsxs("header",{className:"app-topbar",children:[o.jsxs("div",{className:"mode-switch-row",children:[o.jsx("button",{type:"button",className:ke==="assistant"?"tab active":"tab",onClick:()=>Ft("assistant"),children:"Ассистент"}),o.jsx("button",{type:"button",className:ke==="decomposition"?"tab active":"tab",onClick:()=>Ft("decomposition"),children:"Декомпозиция"}),o.jsx("button",{type:"button",className:ke==="autoruns"?"tab active":"tab",onClick:()=>Ft("autoruns"),children:"История автопрогонов"}),o.jsx("button",{type:"button",className:"tab",onClick:Xr,children:"Сохранить"})]}),ke==="assistant"?o.jsxs("div",{className:"mode-switch-row mode-switch-row-right",children:[o.jsx("button",{type:"button",className:Ut?"tab active":"tab",onClick:()=>Xt(d=>!d),children:"LLM Connector"}),o.jsx("button",{type:"button",className:pn?"tab active":"tab",onClick:()=>fr(d=>!d),children:"Prompt Manager"}),o.jsx("button",{type:"button",className:In?"tab active":"tab",onClick:()=>mr(d=>!d),children:"Режим ассистента"}),o.jsx("button",{type:"button",className:Ln?"tab active":"tab",onClick:()=>Zt(d=>!d),children:"Комментарии ассистента"}),o.jsx("button",{type:"button",className:en?"tab active":"tab",onClick:()=>pr(d=>!d),children:"SAM"})]}):ke==="decomposition"?o.jsxs("div",{className:"mode-switch-row mode-switch-row-right",children:[o.jsx("button",{type:"button",className:Bt?"tab active":"tab",onClick:()=>hn(d=>!d),children:"LLM"}),o.jsx("button",{type:"button",className:Be?"tab active":"tab",onClick:()=>st(d=>!d),children:"Prompt"}),o.jsx("button",{type:"button",className:gn?"tab active":"tab",onClick:()=>vn(d=>!d),children:"Запрос"}),o.jsx("button",{type:"button",className:tn?"tab active":"tab",onClick:()=>nn(d=>!d),children:"Выход"}),o.jsx("button",{type:"button",className:Ct?"tab active":"tab",onClick:()=>Dn(d=>!d),children:"Метрики"}),o.jsx("button",{type:"button",className:rn?"tab active":"tab",onClick:()=>bt(d=>!d),children:"История"}),o.jsx("button",{type:"button",className:vt?"tab active":"tab",onClick:()=>Jn(d=>!d),children:"NDC Run Monitor"})]}):ke==="autoruns"?o.jsxs("div",{className:"mode-switch-row mode-switch-row-right",children:[o.jsx("button",{type:"button",className:qn?"tab active":"tab",onClick:()=>An(d=>!d),children:"Режим ассистента"}),o.jsx("button",{type:"button",className:Tn?"tab active":"tab",onClick:()=>dr(d=>!d),children:"Режим декомпозиции"}),o.jsx("button",{type:"button",className:Jt?"tab active":"tab",onClick:()=>Yt(d=>!d),children:"Прогресс/регресс"}),o.jsx("button",{type:"button",className:Gn?"tab active":"tab",onClick:()=>mn(d=>!d),children:"Комментарии"})]}):null]}),ke==="assistant"?o.jsx("div",{className:"layout-grid layout-grid-mode-columns",children:o.jsxs("div",{className:"mode-columns",children:[Ut?o.jsx("div",{className:"mode-col",children:o.jsx(Ac,{value:i,modelOptions:re,modelsBusy:se,onChange:p,onReloadModels:yr,onSaveLocalConfig:Ie,onTestConnection:ut,lastStatus:Pe,busy:Me||yt})}):null,pn?o.jsx("div",{className:"mode-col mode-col-wide",children:o.jsx(Tc,{value:m,onChange:R,presets:De,selectedPresetId:We,onSelectPreset:Ge,onLoadPreset:le,onSavePreset:Un,onResetDefaults:Mt,onDiffPrevious:ct,presetName:Ze,onPresetNameChange:rt,diffSummary:Fe})}):null,In?o.jsx("div",{className:"mode-col mode-col-xwide",children:o.jsx(Fc,{sessionId:Ke,conversation:yn,inputValue:sn,onInputChange:vr,selectedContextChip:Nt,onSelectContextChip:Yn,onClearContextChip:()=>Yn(null),useMock:Re,onUseMockChange:me,onSend:Zn,onClear:Vt,busy:yt,statusText:xt,errorMessage:zn,showCommentAction:!0,onCommentAssistantMessage:zr,isAssistantMessageCommented:Tt,canCommentAssistantMessage:bn})}):null,Ln?o.jsx("div",{className:"mode-col",children:o.jsx(Mn,{className:"assistant-comments-frame",title:"Комментарии ассистента",children:o.jsxs("div",{className:"assistant-comments-shell",children:[o.jsxs("div",{className:"assistant-comments-toolbar",children:[o.jsx("span",{className:"muted",children:Ke?`session: ${Ke}`:"Сессия не запущена"}),o.jsx("button",{type:"button",className:"tab",onClick:()=>{xr(Ke)},disabled:!Ke||_t,children:_t?"Обновляю...":"Обновить"})]}),o.jsxs("div",{className:"assistant-comments-list",children:[Ke?null:o.jsx("p",{className:"muted",children:"Появится после первого ответа ассистента."}),Ke&&ot.length===0&&!_t?o.jsx("p",{className:"muted",children:"Комментариев по этой сессии пока нет."}):null,ot.map(d=>o.jsxs("article",{className:"assistant-comment-item",children:[o.jsxs("div",{className:"assistant-comment-head",children:[o.jsx("strong",{children:`${"●".repeat(Math.max(1,Math.min(5,Math.round(d.rating))))}${"○".repeat(Math.max(0,5-Math.round(d.rating)))}`}),o.jsx("span",{children:new Date(d.updated_at).toLocaleString("ru-RU")})]}),d.context.question_text?o.jsxs("p",{children:["Q: ",d.context.question_text]}):null,d.context.answer_text?o.jsxs("p",{children:["A: ",d.context.answer_text]}):null,o.jsx("p",{children:d.comment}),o.jsxs("div",{className:"assistant-comment-meta",children:[d.context.trace_id?o.jsx("span",{children:`trace=${d.context.trace_id}`}):null,d.context.reply_type?o.jsx("span",{children:`reply_type=${d.context.reply_type}`}):null]})]},d.annotation_id))]})]})})}):null,en?o.jsx("div",{className:"mode-col",children:o.jsx(Af,{sessionId:Ke,conversation:yn,statusText:xt,errorMessage:zn,useMock:Re,appLogs:W})}):null,!Ut&&!pn&&!In&&!Ln&&!en?o.jsx("div",{className:"mode-columns-empty",children:"Все панели режима ассистента скрыты. Включите нужные блоки справа в шапке."}):null]})}):ke==="decomposition"?o.jsx("div",{className:"layout-grid layout-grid-mode-columns",children:o.jsxs("div",{className:"mode-columns",children:[Bt?o.jsx("div",{className:"mode-col",children:o.jsx(Ac,{value:i,modelOptions:re,modelsBusy:se,onChange:p,onReloadModels:yr,onSaveLocalConfig:Ie,onTestConnection:ut,lastStatus:Pe,busy:Me})}):null,Be?o.jsx("div",{className:"mode-col mode-col-wide",children:o.jsx(Tc,{value:m,onChange:R,presets:De,selectedPresetId:We,onSelectPreset:Ge,onLoadPreset:le,onSavePreset:Un,onResetDefaults:Mt,onDiffPrevious:ct,presetName:Ze,onPresetNameChange:rt,diffSummary:Fe})}):null,gn?o.jsx("div",{className:"mode-col",children:o.jsx(cm,{value:j,onChange:T,onApplyBatchFormat:ks,onNormalize:Fn,busy:Me,useMock:Re,onUseMockChange:me,errorMessage:ge})}):null,tn?o.jsx("div",{className:"mode-col mode-col-xwide",children:o.jsx(um,{tab:U,onTabChange:oe,result:$,appLogs:W})}):null,Ct?o.jsx("div",{className:"mode-col",children:o.jsx(lm,{result:$})}):null,rn?o.jsx("div",{className:"mode-col",children:o.jsx(om,{items:F,onRefresh:$n,onOpenTrace:St})}):null,vt?o.jsx("div",{className:"mode-col mode-col-xwide",children:o.jsx(dm,{runs:D,selectedRunId:O,onSelectRun:h,onStartRun:Cs,onFinishRun:Zr,onRefreshRuns:xn,onRunEval:es,onCopyEvalReport:Xn,evalBusy:ae,traceItems:C,evalReport:de})}):null,!Bt&&!Be&&!gn&&!tn&&!Ct&&!rn&&!vt?o.jsx("div",{className:"mode-columns-empty",children:"Все панели режима декомпозиции скрыты. Включите нужные блоки справа в шапке."}):null]})}):o.jsx("div",{className:"layout-grid layout-grid-autoruns",children:o.jsx(sm,{connection:i,prompts:m,assistantPromptVersion:zc,decompositionPromptVersion:qi,showAssistantMode:qn,showDecompositionMode:Tn,showProgressMode:Jt,showCommentsMode:Gn,onLog:J})}),we.open?o.jsx("div",{className:"autoruns-comment-modal-backdrop",onClick:d=>{d.target===d.currentTarget&&dt()},children:o.jsxs("div",{className:"autoruns-comment-modal",children:[o.jsx("h3",{children:"Комментарий к ответу ассистента"}),o.jsx("p",{className:"muted",children:"Эта разметка хранится отдельно от комментариев автопрогонов."}),wt?o.jsxs("details",{className:"autoruns-prompt-details",open:!0,children:[o.jsx("summary",{children:"Вопрос пользователя"}),o.jsx("p",{className:"autoruns-comment-quote",children:wt.text})]}):null,At?o.jsxs("details",{className:"autoruns-prompt-details",open:!0,children:[o.jsx("summary",{children:"Ответ ассистента"}),o.jsx("p",{className:"autoruns-comment-quote",children:At.text})]}):null,o.jsx("div",{className:"autoruns-rating-row",role:"group","aria-label":"Рейтинг ответа",children:[1,2,3,4,5].map(d=>o.jsx("button",{type:"button",className:we.rating>=d?"autoruns-rating-dot active":"autoruns-rating-dot",onClick:()=>lt(P=>({...P,rating:d})),disabled:we.saving,"aria-label":`Оценка ${d}`,children:we.rating>=d?"●":"○"},d))}),o.jsx("div",{className:"autoruns-form-grid",children:o.jsxs("label",{children:["Автор комментария",o.jsx("input",{value:we.annotationAuthor,onChange:d=>lt(P=>({...P,annotationAuthor:d.target.value})),placeholder:"manual_reviewer",disabled:we.saving})]})}),o.jsxs("label",{children:["Комментарий",o.jsx("textarea",{value:we.comment,onChange:d=>lt(P=>({...P,comment:d.target.value})),placeholder:"Что именно не так в ответе и что проверить.",rows:4,disabled:we.saving})]}),we.error?o.jsx("p",{className:"error-text",children:we.error}):null,o.jsxs("div",{className:"button-row",children:[o.jsx("button",{type:"button",onClick:()=>{Ht()},disabled:we.saving,children:we.saving?"Сохраняю...":"Готово"}),o.jsx("button",{type:"button",className:"tab",onClick:()=>dt(),disabled:we.saving,children:"Отмена"})]})]})}):null]})}Pf.createRoot(document.getElementById("root")).render(o.jsx(Sf.StrictMode,{children:o.jsx(_m,{})})); diff --git a/llm_normalizer/frontend/dist/assets/index-CEJTyo9A.js b/llm_normalizer/frontend/dist/assets/index-CEJTyo9A.js deleted file mode 100644 index 35d080a..0000000 --- a/llm_normalizer/frontend/dist/assets/index-CEJTyo9A.js +++ /dev/null @@ -1,20 +0,0 @@ -(function(){const h=document.createElement("link").relList;if(h&&h.supports&&h.supports("modulepreload"))return;for(const C of document.querySelectorAll('link[rel="modulepreload"]'))I(C);new MutationObserver(C=>{for(const L of C)if(L.type==="childList")for(const U of L.addedNodes)U.tagName==="LINK"&&U.rel==="modulepreload"&&I(U)}).observe(document,{childList:!0,subtree:!0});function m(C){const L={};return C.integrity&&(L.integrity=C.integrity),C.referrerPolicy&&(L.referrerPolicy=C.referrerPolicy),C.crossOrigin==="use-credentials"?L.credentials="include":C.crossOrigin==="anonymous"?L.credentials="omit":L.credentials="same-origin",L}function I(C){if(C.ep)return;C.ep=!0;const L=m(C);fetch(C.href,L)}})();function zc(i){return i&&i.__esModule&&Object.prototype.hasOwnProperty.call(i,"default")?i.default:i}var Oi={exports:{}},Xs={},zi={exports:{}},he={};var mc;function vf(){if(mc)return he;mc=1;var i=Symbol.for("react.element"),h=Symbol.for("react.portal"),m=Symbol.for("react.fragment"),I=Symbol.for("react.strict_mode"),C=Symbol.for("react.profiler"),L=Symbol.for("react.provider"),U=Symbol.for("react.context"),Z=Symbol.for("react.forward_ref"),F=Symbol.for("react.suspense"),D=Symbol.for("react.memo"),q=Symbol.for("react.lazy"),O=Symbol.iterator;function H(p){return p===null||typeof p!="object"?null:(p=O&&p[O]||p["@@iterator"],typeof p=="function"?p:null)}var ue={isMounted:function(){return!1},enqueueForceUpdate:function(){},enqueueReplaceState:function(){},enqueueSetState:function(){}},Re=Object.assign,ee={};function re(p,k,G){this.props=p,this.context=k,this.refs=ee,this.updater=G||ue}re.prototype.isReactComponent={},re.prototype.setState=function(p,k){if(typeof p!="object"&&typeof p!="function"&&p!=null)throw Error("setState(...): takes an object of state variables to update or a function which returns an object of state variables.");this.updater.enqueueSetState(this,p,k,"setState")},re.prototype.forceUpdate=function(p){this.updater.enqueueForceUpdate(this,p,"forceUpdate")};function K(){}K.prototype=re.prototype;function ie(p,k,G){this.props=p,this.context=k,this.refs=ee,this.updater=G||ue}var je=ie.prototype=new K;je.constructor=ie,Re(je,re.prototype),je.isPureReactComponent=!0;var ze=Array.isArray,Te=Object.prototype.hasOwnProperty,Ie={current:null},Le={key:!0,ref:!0,__self:!0,__source:!0};function We(p,k,G){var ce,de={},fe=null,ye=null;if(k!=null)for(ce in k.ref!==void 0&&(ye=k.ref),k.key!==void 0&&(fe=""+k.key),k)Te.call(k,ce)&&!Le.hasOwnProperty(ce)&&(de[ce]=k[ce]);var ge=arguments.length-2;if(ge===1)de.children=G;else if(1>>1,k=A[p];if(0>>1;pC(de,z))feC(ye,de)?(A[p]=ye,A[fe]=z,p=fe):(A[p]=de,A[ce]=z,p=ce);else if(feC(ye,z))A[p]=ye,A[fe]=z,p=fe;else break e}}return Q}function C(A,Q){var z=A.sortIndex-Q.sortIndex;return z!==0?z:A.id-Q.id}if(typeof performance=="object"&&typeof performance.now=="function"){var L=performance;i.unstable_now=function(){return L.now()}}else{var U=Date,Z=U.now();i.unstable_now=function(){return U.now()-Z}}var F=[],D=[],q=1,O=null,H=3,ue=!1,Re=!1,ee=!1,re=typeof setTimeout=="function"?setTimeout:null,K=typeof clearTimeout=="function"?clearTimeout:null,ie=typeof setImmediate<"u"?setImmediate:null;typeof navigator<"u"&&navigator.scheduling!==void 0&&navigator.scheduling.isInputPending!==void 0&&navigator.scheduling.isInputPending.bind(navigator.scheduling);function je(A){for(var Q=m(D);Q!==null;){if(Q.callback===null)I(D);else if(Q.startTime<=A)I(D),Q.sortIndex=Q.expirationTime,h(F,Q);else break;Q=m(D)}}function ze(A){if(ee=!1,je(A),!Re)if(m(F)!==null)Re=!0,Me(Te);else{var Q=m(D);Q!==null&&pe(ze,Q.startTime-A)}}function Te(A,Q){Re=!1,ee&&(ee=!1,K(We),We=-1),ue=!0;var z=H;try{for(je(Q),O=m(F);O!==null&&(!(O.expirationTime>Q)||A&&!Ke());){var p=O.callback;if(typeof p=="function"){O.callback=null,H=O.priorityLevel;var k=p(O.expirationTime<=Q);Q=i.unstable_now(),typeof k=="function"?O.callback=k:O===m(F)&&I(F),je(Q)}else I(F);O=m(F)}if(O!==null)var G=!0;else{var ce=m(D);ce!==null&&pe(ze,ce.startTime-Q),G=!1}return G}finally{O=null,H=z,ue=!1}}var Ie=!1,Le=null,We=-1,se=5,Fe=-1;function Ke(){return!(i.unstable_now()-FeA||125p?(A.sortIndex=z,h(D,A),m(F)===null&&A===m(D)&&(ee?(K(We),We=-1):ee=!0,pe(ze,z-p))):(A.sortIndex=k,h(F,A),Re||ue||(Re=!0,Me(Te))),A},i.unstable_shouldYield=Ke,i.unstable_wrapCallback=function(A){var Q=H;return function(){var z=H;H=Q;try{return A.apply(this,arguments)}finally{H=z}}}})(Ui)),Ui}var yc;function wf(){return yc||(yc=1,Fi.exports=Sf()),Fi.exports}var xc;function jf(){if(xc)return Lt;xc=1;var i=Ji(),h=wf();function m(e){for(var t="https://reactjs.org/docs/error-decoder.html?invariant="+e,n=1;n"u"||typeof window.document>"u"||typeof window.document.createElement>"u"),F=Object.prototype.hasOwnProperty,D=/^[:A-Z_a-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD][:A-Z_a-z\u00C0-\u00D6\u00D8-\u00F6\u00F8-\u02FF\u0370-\u037D\u037F-\u1FFF\u200C-\u200D\u2070-\u218F\u2C00-\u2FEF\u3001-\uD7FF\uF900-\uFDCF\uFDF0-\uFFFD\-.0-9\u00B7\u0300-\u036F\u203F-\u2040]*$/,q={},O={};function H(e){return F.call(O,e)?!0:F.call(q,e)?!1:D.test(e)?O[e]=!0:(q[e]=!0,!1)}function ue(e,t,n,r){if(n!==null&&n.type===0)return!1;switch(typeof t){case"function":case"symbol":return!0;case"boolean":return r?!1:n!==null?!n.acceptsBooleans:(e=e.toLowerCase().slice(0,5),e!=="data-"&&e!=="aria-");default:return!1}}function Re(e,t,n,r){if(t===null||typeof t>"u"||ue(e,t,n,r))return!0;if(r)return!1;if(n!==null)switch(n.type){case 3:return!t;case 4:return t===!1;case 5:return isNaN(t);case 6:return isNaN(t)||1>t}return!1}function ee(e,t,n,r,s,l,u){this.acceptsBooleans=t===2||t===3||t===4,this.attributeName=r,this.attributeNamespace=s,this.mustUseProperty=n,this.propertyName=e,this.type=t,this.sanitizeURL=l,this.removeEmptyString=u}var re={};"children dangerouslySetInnerHTML defaultValue defaultChecked innerHTML suppressContentEditableWarning suppressHydrationWarning style".split(" ").forEach(function(e){re[e]=new ee(e,0,!1,e,null,!1,!1)}),[["acceptCharset","accept-charset"],["className","class"],["htmlFor","for"],["httpEquiv","http-equiv"]].forEach(function(e){var t=e[0];re[t]=new ee(t,1,!1,e[1],null,!1,!1)}),["contentEditable","draggable","spellCheck","value"].forEach(function(e){re[e]=new ee(e,2,!1,e.toLowerCase(),null,!1,!1)}),["autoReverse","externalResourcesRequired","focusable","preserveAlpha"].forEach(function(e){re[e]=new ee(e,2,!1,e,null,!1,!1)}),"allowFullScreen async autoFocus autoPlay controls default defer disabled disablePictureInPicture disableRemotePlayback formNoValidate hidden loop noModule noValidate open playsInline readOnly required reversed scoped seamless itemScope".split(" ").forEach(function(e){re[e]=new ee(e,3,!1,e.toLowerCase(),null,!1,!1)}),["checked","multiple","muted","selected"].forEach(function(e){re[e]=new ee(e,3,!0,e,null,!1,!1)}),["capture","download"].forEach(function(e){re[e]=new ee(e,4,!1,e,null,!1,!1)}),["cols","rows","size","span"].forEach(function(e){re[e]=new ee(e,6,!1,e,null,!1,!1)}),["rowSpan","start"].forEach(function(e){re[e]=new ee(e,5,!1,e.toLowerCase(),null,!1,!1)});var K=/[\-:]([a-z])/g;function ie(e){return e[1].toUpperCase()}"accent-height alignment-baseline arabic-form baseline-shift cap-height clip-path clip-rule color-interpolation color-interpolation-filters color-profile color-rendering dominant-baseline enable-background fill-opacity fill-rule flood-color flood-opacity font-family font-size font-size-adjust font-stretch font-style font-variant font-weight glyph-name glyph-orientation-horizontal glyph-orientation-vertical horiz-adv-x horiz-origin-x image-rendering letter-spacing lighting-color marker-end marker-mid marker-start overline-position overline-thickness paint-order panose-1 pointer-events rendering-intent shape-rendering stop-color stop-opacity strikethrough-position strikethrough-thickness stroke-dasharray stroke-dashoffset stroke-linecap stroke-linejoin stroke-miterlimit stroke-opacity stroke-width text-anchor text-decoration text-rendering underline-position underline-thickness unicode-bidi unicode-range units-per-em v-alphabetic v-hanging v-ideographic v-mathematical vector-effect vert-adv-y vert-origin-x vert-origin-y word-spacing writing-mode xmlns:xlink x-height".split(" ").forEach(function(e){var t=e.replace(K,ie);re[t]=new ee(t,1,!1,e,null,!1,!1)}),"xlink:actuate xlink:arcrole xlink:role xlink:show xlink:title xlink:type".split(" ").forEach(function(e){var t=e.replace(K,ie);re[t]=new ee(t,1,!1,e,"http://www.w3.org/1999/xlink",!1,!1)}),["xml:base","xml:lang","xml:space"].forEach(function(e){var t=e.replace(K,ie);re[t]=new ee(t,1,!1,e,"http://www.w3.org/XML/1998/namespace",!1,!1)}),["tabIndex","crossOrigin"].forEach(function(e){re[e]=new ee(e,1,!1,e.toLowerCase(),null,!1,!1)}),re.xlinkHref=new ee("xlinkHref",1,!1,"xlink:href","http://www.w3.org/1999/xlink",!0,!1),["src","href","action","formAction"].forEach(function(e){re[e]=new ee(e,1,!1,e.toLowerCase(),null,!0,!0)});function je(e,t,n,r){var s=re.hasOwnProperty(t)?re[t]:null;(s!==null?s.type!==0:r||!(2d||s[u]!==l[d]){var g=` -`+s[u].replace(" at new "," at ");return e.displayName&&g.includes("")&&(g=g.replace("",e.displayName)),g}while(1<=u&&0<=d);break}}}finally{G=!1,Error.prepareStackTrace=n}return(e=e?e.displayName||e.name:"")?k(e):""}function de(e){switch(e.tag){case 5:return k(e.type);case 16:return k("Lazy");case 13:return k("Suspense");case 19:return k("SuspenseList");case 0:case 2:case 15:return e=ce(e.type,!1),e;case 11:return e=ce(e.type.render,!1),e;case 1:return e=ce(e.type,!0),e;default:return""}}function fe(e){if(e==null)return null;if(typeof e=="function")return e.displayName||e.name||null;if(typeof e=="string")return e;switch(e){case Le:return"Fragment";case Ie:return"Portal";case se:return"Profiler";case We:return"StrictMode";case Ye:return"Suspense";case nt:return"SuspenseList"}if(typeof e=="object")switch(e.$$typeof){case Ke:return(e.displayName||"Context")+".Consumer";case Fe:return(e._context.displayName||"Context")+".Provider";case lt:var t=e.render;return e=e.displayName,e||(e=t.displayName||t.name||"",e=e!==""?"ForwardRef("+e+")":"ForwardRef"),e;case ve:return t=e.displayName||null,t!==null?t:fe(e.type)||"Memo";case Me:t=e._payload,e=e._init;try{return fe(e(t))}catch{}}return null}function ye(e){var t=e.type;switch(e.tag){case 24:return"Cache";case 9:return(t.displayName||"Context")+".Consumer";case 10:return(t._context.displayName||"Context")+".Provider";case 18:return"DehydratedFragment";case 11:return e=t.render,e=e.displayName||e.name||"",t.displayName||(e!==""?"ForwardRef("+e+")":"ForwardRef");case 7:return"Fragment";case 5:return t;case 4:return"Portal";case 3:return"Root";case 6:return"Text";case 16:return fe(t);case 8:return t===We?"StrictMode":"Mode";case 22:return"Offscreen";case 12:return"Profiler";case 21:return"Scope";case 13:return"Suspense";case 19:return"SuspenseList";case 25:return"TracingMarker";case 1:case 0:case 17:case 2:case 14:case 15:if(typeof t=="function")return t.displayName||t.name||null;if(typeof t=="string")return t}return null}function ge(e){switch(typeof e){case"boolean":case"number":case"string":case"undefined":return e;case"object":return e;default:return""}}function te(e){var t=e.type;return(e=e.nodeName)&&e.toLowerCase()==="input"&&(t==="checkbox"||t==="radio")}function Ce(e){var t=te(e)?"checked":"value",n=Object.getOwnPropertyDescriptor(e.constructor.prototype,t),r=""+e[t];if(!e.hasOwnProperty(t)&&typeof n<"u"&&typeof n.get=="function"&&typeof n.set=="function"){var s=n.get,l=n.set;return Object.defineProperty(e,t,{configurable:!0,get:function(){return s.call(this)},set:function(u){r=""+u,l.call(this,u)}}),Object.defineProperty(e,t,{enumerable:n.enumerable}),{getValue:function(){return r},setValue:function(u){r=""+u},stopTracking:function(){e._valueTracker=null,delete e[t]}}}}function Dt(e){e._valueTracker||(e._valueTracker=Ce(e))}function bn(e){if(!e)return!1;var t=e._valueTracker;if(!t)return!0;var n=t.getValue(),r="";return e&&(r=te(e)?e.checked?"true":"false":e.value),e=r,e!==n?(t.setValue(e),!0):!1}function Rn(e){if(e=e||(typeof document<"u"?document:void 0),typeof e>"u")return null;try{return e.activeElement||e.body}catch{return e.body}}function Tn(e,t){var n=t.checked;return z({},t,{defaultChecked:void 0,defaultValue:void 0,value:void 0,checked:n??e._wrapperState.initialChecked})}function rr(e,t){var n=t.defaultValue==null?"":t.defaultValue,r=t.checked!=null?t.checked:t.defaultChecked;n=ge(t.value!=null?t.value:n),e._wrapperState={initialChecked:r,initialValue:n,controlled:t.type==="checkbox"||t.type==="radio"?t.checked!=null:t.value!=null}}function Kt(e,t){t=t.checked,t!=null&&je(e,"checked",t,!1)}function qt(e,t){Kt(e,t);var n=ge(t.value),r=t.type;if(n!=null)r==="number"?(n===0&&e.value===""||e.value!=n)&&(e.value=""+n):e.value!==""+n&&(e.value=""+n);else if(r==="submit"||r==="reset"){e.removeAttribute("value");return}t.hasOwnProperty("value")?fn(e,t.type,n):t.hasOwnProperty("defaultValue")&&fn(e,t.type,ge(t.defaultValue)),t.checked==null&&t.defaultChecked!=null&&(e.defaultChecked=!!t.defaultChecked)}function Hn(e,t,n){if(t.hasOwnProperty("value")||t.hasOwnProperty("defaultValue")){var r=t.type;if(!(r!=="submit"&&r!=="reset"||t.value!==void 0&&t.value!==null))return;t=""+e._wrapperState.initialValue,n||t===e.value||(e.value=t),e.defaultValue=t}n=e.name,n!==""&&(e.name=""),e.defaultChecked=!!e._wrapperState.initialChecked,n!==""&&(e.name=n)}function fn(e,t,n){(t!=="number"||Rn(e.ownerDocument)!==e)&&(n==null?e.defaultValue=""+e._wrapperState.initialValue:e.defaultValue!==""+n&&(e.defaultValue=""+n))}var Ot=Array.isArray;function Gt(e,t,n,r){if(e=e.options,t){t={};for(var s=0;s"+t.valueOf().toString()+"",t=Yt.firstChild;e.firstChild;)e.removeChild(e.firstChild);for(;t.firstChild;)e.appendChild(t.firstChild)}});function zt(e,t){if(t){var n=e.firstChild;if(n&&n===e.lastChild&&n.nodeType===3){n.nodeValue=t;return}}e.textContent=t}var pn={animationIterationCount:!0,aspectRatio:!0,borderImageOutset:!0,borderImageSlice:!0,borderImageWidth:!0,boxFlex:!0,boxFlexGroup:!0,boxOrdinalGroup:!0,columnCount:!0,columns:!0,flex:!0,flexGrow:!0,flexPositive:!0,flexShrink:!0,flexNegative:!0,flexOrder:!0,gridArea:!0,gridRow:!0,gridRowEnd:!0,gridRowSpan:!0,gridRowStart:!0,gridColumn:!0,gridColumnEnd:!0,gridColumnSpan:!0,gridColumnStart:!0,fontWeight:!0,lineClamp:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,tabSize:!0,widows:!0,zIndex:!0,zoom:!0,fillOpacity:!0,floodOpacity:!0,stopOpacity:!0,strokeDasharray:!0,strokeDashoffset:!0,strokeMiterlimit:!0,strokeOpacity:!0,strokeWidth:!0},Ue=["Webkit","ms","Moz","O"];Object.keys(pn).forEach(function(e){Ue.forEach(function(t){t=t+e.charAt(0).toUpperCase()+e.substring(1),pn[t]=pn[e]})});function it(e,t,n){return t==null||typeof t=="boolean"||t===""?"":n||typeof t!="number"||t===0||pn.hasOwnProperty(e)&&pn[e]?(""+t).trim():t+"px"}function hn(e,t){e=e.style;for(var n in t)if(t.hasOwnProperty(n)){var r=n.indexOf("--")===0,s=it(n,t[n],r);n==="float"&&(n="cssFloat"),r?e.setProperty(n,s):e[n]=s}}var gn=z({menuitem:!0},{area:!0,base:!0,br:!0,col:!0,embed:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0});function Xt(e,t){if(t){if(gn[e]&&(t.children!=null||t.dangerouslySetInnerHTML!=null))throw Error(m(137,e));if(t.dangerouslySetInnerHTML!=null){if(t.children!=null)throw Error(m(60));if(typeof t.dangerouslySetInnerHTML!="object"||!("__html"in t.dangerouslySetInnerHTML))throw Error(m(61))}if(t.style!=null&&typeof t.style!="object")throw Error(m(62))}}function Zt(e,t){if(e.indexOf("-")===-1)return typeof t.is=="string";switch(e){case"annotation-xml":case"color-profile":case"font-face":case"font-face-src":case"font-face-uri":case"font-face-format":case"font-face-name":case"missing-glyph":return!1;default:return!0}}var kt=null;function Ln(e){return e=e.target||e.srcElement||window,e.correspondingUseElement&&(e=e.correspondingUseElement),e.nodeType===3?e.parentNode:e}var en=null,$t=null,Ft=null;function Mr(e){if(e=zs(e)){if(typeof en!="function")throw Error(m(280));var t=e.stateNode;t&&(t=vo(t),en(e.stateNode,e.type,t))}}function He(e){$t?Ft?Ft.push(e):Ft=[e]:$t=e}function ir(){if($t){var e=$t,t=Ft;if(Ft=$t=null,Mr(e),t)for(e=0;e>>=0,e===0?32:31-(qr(e)/Gr|0)|0}var Ut=64,_t=4194304;function sn(e){switch(e&-e){case 1:return 1;case 2:return 2;case 4:return 4;case 8:return 8;case 16:return 16;case 32:return 32;case 64:case 128:case 256:case 512:case 1024:case 2048:case 4096:case 8192:case 16384:case 32768:case 65536:case 131072:case 262144:case 524288:case 1048576:case 2097152:return e&4194240;case 4194304:case 8388608:case 16777216:case 33554432:case 67108864:return e&130023424;case 134217728:return 134217728;case 268435456:return 268435456;case 536870912:return 536870912;case 1073741824:return 1073741824;default:return e}}function Xe(e,t){var n=e.pendingLanes;if(n===0)return 0;var r=0,s=e.suspendedLanes,l=e.pingedLanes,u=n&268435455;if(u!==0){var d=u&~s;d!==0?r=sn(d):(l&=u,l!==0&&(r=sn(l)))}else u=n&~s,u!==0?r=sn(u):l!==0&&(r=sn(l));if(r===0)return 0;if(t!==0&&t!==r&&(t&s)===0&&(s=r&-r,l=t&-t,s>=l||s===16&&(l&4194240)!==0))return t;if((r&4)!==0&&(r|=n&16),t=e.entangledLanes,t!==0)for(e=e.entanglements,t&=r;0n;n++)t.push(e);return t}function _n(e,t,n){e.pendingLanes|=t,t!==536870912&&(e.suspendedLanes=0,e.pingedLanes=0),e=e.eventTimes,t=31-ct(t),e[t]=n}function f(e,t){var n=e.pendingLanes&~t;e.pendingLanes=t,e.suspendedLanes=0,e.pingedLanes=0,e.expiredLanes&=t,e.mutableReadLanes&=t,e.entangledLanes&=t,t=e.entanglements;var r=e.eventTimes;for(e=e.expirationTimes;0=Ps),la=" ",ia=!1;function aa(e,t){switch(e){case"keyup":return dd.indexOf(t.keyCode)!==-1;case"keydown":return t.keyCode!==229;case"keypress":case"mousedown":case"focusout":return!0;default:return!1}}function ua(e){return e=e.detail,typeof e=="object"&&"data"in e?e.data:null}var Zr=!1;function md(e,t){switch(e){case"compositionend":return ua(t);case"keypress":return t.which!==32?null:(ia=!0,la);case"textInput":return e=t.data,e===la&&ia?null:e;default:return null}}function pd(e,t){if(Zr)return e==="compositionend"||!gl&&aa(e,t)?(e=ea(),oo=cl=pr=null,Zr=!1,e):null;switch(e){case"paste":return null;case"keypress":if(!(t.ctrlKey||t.altKey||t.metaKey)||t.ctrlKey&&t.altKey){if(t.char&&1=t)return{node:n,offset:t-e};e=r}e:{for(;n;){if(n.nextSibling){n=n.nextSibling;break e}n=n.parentNode}n=void 0}n=ga(n)}}function ya(e,t){return e&&t?e===t?!0:e&&e.nodeType===3?!1:t&&t.nodeType===3?ya(e,t.parentNode):"contains"in e?e.contains(t):e.compareDocumentPosition?!!(e.compareDocumentPosition(t)&16):!1:!1}function xa(){for(var e=window,t=Rn();t instanceof e.HTMLIFrameElement;){try{var n=typeof t.contentWindow.location.href=="string"}catch{n=!1}if(n)e=t.contentWindow;else break;t=Rn(e.document)}return t}function xl(e){var t=e&&e.nodeName&&e.nodeName.toLowerCase();return t&&(t==="input"&&(e.type==="text"||e.type==="search"||e.type==="tel"||e.type==="url"||e.type==="password")||t==="textarea"||e.contentEditable==="true")}function jd(e){var t=xa(),n=e.focusedElem,r=e.selectionRange;if(t!==n&&n&&n.ownerDocument&&ya(n.ownerDocument.documentElement,n)){if(r!==null&&xl(n)){if(t=r.start,e=r.end,e===void 0&&(e=t),"selectionStart"in n)n.selectionStart=t,n.selectionEnd=Math.min(e,n.value.length);else if(e=(t=n.ownerDocument||document)&&t.defaultView||window,e.getSelection){e=e.getSelection();var s=n.textContent.length,l=Math.min(r.start,s);r=r.end===void 0?l:Math.min(r.end,s),!e.extend&&l>r&&(s=r,r=l,l=s),s=va(n,l);var u=va(n,r);s&&u&&(e.rangeCount!==1||e.anchorNode!==s.node||e.anchorOffset!==s.offset||e.focusNode!==u.node||e.focusOffset!==u.offset)&&(t=t.createRange(),t.setStart(s.node,s.offset),e.removeAllRanges(),l>r?(e.addRange(t),e.extend(u.node,u.offset)):(t.setEnd(u.node,u.offset),e.addRange(t)))}}for(t=[],e=n;e=e.parentNode;)e.nodeType===1&&t.push({element:e,left:e.scrollLeft,top:e.scrollTop});for(typeof n.focus=="function"&&n.focus(),n=0;n=document.documentMode,es=null,_l=null,As=null,Sl=!1;function _a(e,t,n){var r=n.window===n?n.document:n.nodeType===9?n:n.ownerDocument;Sl||es==null||es!==Rn(r)||(r=es,"selectionStart"in r&&xl(r)?r={start:r.selectionStart,end:r.selectionEnd}:(r=(r.ownerDocument&&r.ownerDocument.defaultView||window).getSelection(),r={anchorNode:r.anchorNode,anchorOffset:r.anchorOffset,focusNode:r.focusNode,focusOffset:r.focusOffset}),As&&Ts(As,r)||(As=r,r=po(_l,"onSelect"),0os||(e.current=Il[os],Il[os]=null,os--)}function Ae(e,t){os++,Il[os]=e.current,e.current=t}var yr={},dt=vr(yr),Mt=vr(!1),Or=yr;function ls(e,t){var n=e.type.contextTypes;if(!n)return yr;var r=e.stateNode;if(r&&r.__reactInternalMemoizedUnmaskedChildContext===t)return r.__reactInternalMemoizedMaskedChildContext;var s={},l;for(l in n)s[l]=t[l];return r&&(e=e.stateNode,e.__reactInternalMemoizedUnmaskedChildContext=t,e.__reactInternalMemoizedMaskedChildContext=s),s}function Rt(e){return e=e.childContextTypes,e!=null}function yo(){Oe(Mt),Oe(dt)}function Da(e,t,n){if(dt.current!==yr)throw Error(m(168));Ae(dt,t),Ae(Mt,n)}function Oa(e,t,n){var r=e.stateNode;if(t=t.childContextTypes,typeof r.getChildContext!="function")return n;r=r.getChildContext();for(var s in r)if(!(s in t))throw Error(m(108,ye(e)||"Unknown",s));return z({},n,r)}function xo(e){return e=(e=e.stateNode)&&e.__reactInternalMemoizedMergedChildContext||yr,Or=dt.current,Ae(dt,e),Ae(Mt,Mt.current),!0}function za(e,t,n){var r=e.stateNode;if(!r)throw Error(m(169));n?(e=Oa(e,t,Or),r.__reactInternalMemoizedMergedChildContext=e,Oe(Mt),Oe(dt),Ae(dt,e)):Oe(Mt),Ae(Mt,n)}var qn=null,_o=!1,Ll=!1;function $a(e){qn===null?qn=[e]:qn.push(e)}function Dd(e){_o=!0,$a(e)}function xr(){if(!Ll&&qn!==null){Ll=!0;var e=0,t=j;try{var n=qn;for(j=1;e>=u,s-=u,Gn=1<<32-ct(t)+s|n<ne?(ot=X,X=null):ot=X.sibling;var we=N(_,X,S[ne],T);if(we===null){X===null&&(X=ot);break}e&&X&&we.alternate===null&&t(_,X),v=l(we,v,ne),Y===null?W=we:Y.sibling=we,Y=we,X=ot}if(ne===S.length)return n(_,X),$e&&$r(_,ne),W;if(X===null){for(;nene?(ot=X,X=null):ot=X.sibling;var Pr=N(_,X,we.value,T);if(Pr===null){X===null&&(X=ot);break}e&&X&&Pr.alternate===null&&t(_,X),v=l(Pr,v,ne),Y===null?W=Pr:Y.sibling=Pr,Y=Pr,X=ot}if(we.done)return n(_,X),$e&&$r(_,ne),W;if(X===null){for(;!we.done;ne++,we=S.next())we=R(_,we.value,T),we!==null&&(v=l(we,v,ne),Y===null?W=we:Y.sibling=we,Y=we);return $e&&$r(_,ne),W}for(X=r(_,X);!we.done;ne++,we=S.next())we=$(X,_,ne,we.value,T),we!==null&&(e&&we.alternate!==null&&X.delete(we.key===null?ne:we.key),v=l(we,v,ne),Y===null?W=we:Y.sibling=we,Y=we);return e&&X.forEach(function(gf){return t(_,gf)}),$e&&$r(_,ne),W}function qe(_,v,S,T){if(typeof S=="object"&&S!==null&&S.type===Le&&S.key===null&&(S=S.props.children),typeof S=="object"&&S!==null){switch(S.$$typeof){case Te:e:{for(var W=S.key,Y=v;Y!==null;){if(Y.key===W){if(W=S.type,W===Le){if(Y.tag===7){n(_,Y.sibling),v=s(Y,S.props.children),v.return=_,_=v;break e}}else if(Y.elementType===W||typeof W=="object"&&W!==null&&W.$$typeof===Me&&Va(W)===Y.type){n(_,Y.sibling),v=s(Y,S.props),v.ref=$s(_,Y,S),v.return=_,_=v;break e}n(_,Y);break}else t(_,Y);Y=Y.sibling}S.type===Le?(v=Wr(S.props.children,_.mode,T,S.key),v.return=_,_=v):(T=qo(S.type,S.key,S.props,null,_.mode,T),T.ref=$s(_,v,S),T.return=_,_=T)}return u(_);case Ie:e:{for(Y=S.key;v!==null;){if(v.key===Y)if(v.tag===4&&v.stateNode.containerInfo===S.containerInfo&&v.stateNode.implementation===S.implementation){n(_,v.sibling),v=s(v,S.children||[]),v.return=_,_=v;break e}else{n(_,v);break}else t(_,v);v=v.sibling}v=Ti(S,_.mode,T),v.return=_,_=v}return u(_);case Me:return Y=S._init,qe(_,v,Y(S._payload),T)}if(Ot(S))return b(_,v,S,T);if(Q(S))return V(_,v,S,T);ko(_,S)}return typeof S=="string"&&S!==""||typeof S=="number"?(S=""+S,v!==null&&v.tag===6?(n(_,v.sibling),v=s(v,S),v.return=_,_=v):(n(_,v),v=Ri(S,_.mode,T),v.return=_,_=v),u(_)):n(_,v)}return qe}var cs=Qa(!0),Wa=Qa(!1),Co=vr(null),No=null,ds=null,Ul=null;function Bl(){Ul=ds=No=null}function bl(e){var t=Co.current;Oe(Co),e._currentValue=t}function Hl(e,t,n){for(;e!==null;){var r=e.alternate;if((e.childLanes&t)!==t?(e.childLanes|=t,r!==null&&(r.childLanes|=t)):r!==null&&(r.childLanes&t)!==t&&(r.childLanes|=t),e===n)break;e=e.return}}function fs(e,t){No=e,Ul=ds=null,e=e.dependencies,e!==null&&e.firstContext!==null&&((e.lanes&t)!==0&&(Tt=!0),e.firstContext=null)}function an(e){var t=e._currentValue;if(Ul!==e)if(e={context:e,memoizedValue:t,next:null},ds===null){if(No===null)throw Error(m(308));ds=e,No.dependencies={lanes:0,firstContext:e}}else ds=ds.next=e;return t}var Fr=null;function Vl(e){Fr===null?Fr=[e]:Fr.push(e)}function Ka(e,t,n,r){var s=t.interleaved;return s===null?(n.next=n,Vl(t)):(n.next=s.next,s.next=n),t.interleaved=n,Yn(e,r)}function Yn(e,t){e.lanes|=t;var n=e.alternate;for(n!==null&&(n.lanes|=t),n=e,e=e.return;e!==null;)e.childLanes|=t,n=e.alternate,n!==null&&(n.childLanes|=t),n=e,e=e.return;return n.tag===3?n.stateNode:null}var _r=!1;function Ql(e){e.updateQueue={baseState:e.memoizedState,firstBaseUpdate:null,lastBaseUpdate:null,shared:{pending:null,interleaved:null,lanes:0},effects:null}}function qa(e,t){e=e.updateQueue,t.updateQueue===e&&(t.updateQueue={baseState:e.baseState,firstBaseUpdate:e.firstBaseUpdate,lastBaseUpdate:e.lastBaseUpdate,shared:e.shared,effects:e.effects})}function Xn(e,t){return{eventTime:e,lane:t,tag:0,payload:null,callback:null,next:null}}function Sr(e,t,n){var r=e.updateQueue;if(r===null)return null;if(r=r.shared,(Se&2)!==0){var s=r.pending;return s===null?t.next=t:(t.next=s.next,s.next=t),r.pending=t,Yn(e,n)}return s=r.interleaved,s===null?(t.next=t,Vl(r)):(t.next=s.next,s.next=t),r.interleaved=t,Yn(e,n)}function Eo(e,t,n){if(t=t.updateQueue,t!==null&&(t=t.shared,(n&4194240)!==0)){var r=t.lanes;r&=e.pendingLanes,n|=r,t.lanes=n,M(e,n)}}function Ga(e,t){var n=e.updateQueue,r=e.alternate;if(r!==null&&(r=r.updateQueue,n===r)){var s=null,l=null;if(n=n.firstBaseUpdate,n!==null){do{var u={eventTime:n.eventTime,lane:n.lane,tag:n.tag,payload:n.payload,callback:n.callback,next:null};l===null?s=l=u:l=l.next=u,n=n.next}while(n!==null);l===null?s=l=t:l=l.next=t}else s=l=t;n={baseState:r.baseState,firstBaseUpdate:s,lastBaseUpdate:l,shared:r.shared,effects:r.effects},e.updateQueue=n;return}e=n.lastBaseUpdate,e===null?n.firstBaseUpdate=t:e.next=t,n.lastBaseUpdate=t}function Po(e,t,n,r){var s=e.updateQueue;_r=!1;var l=s.firstBaseUpdate,u=s.lastBaseUpdate,d=s.shared.pending;if(d!==null){s.shared.pending=null;var g=d,w=g.next;g.next=null,u===null?l=w:u.next=w,u=g;var E=e.alternate;E!==null&&(E=E.updateQueue,d=E.lastBaseUpdate,d!==u&&(d===null?E.firstBaseUpdate=w:d.next=w,E.lastBaseUpdate=g))}if(l!==null){var R=s.baseState;u=0,E=w=g=null,d=l;do{var N=d.lane,$=d.eventTime;if((r&N)===N){E!==null&&(E=E.next={eventTime:$,lane:0,tag:d.tag,payload:d.payload,callback:d.callback,next:null});e:{var b=e,V=d;switch(N=t,$=n,V.tag){case 1:if(b=V.payload,typeof b=="function"){R=b.call($,R,N);break e}R=b;break e;case 3:b.flags=b.flags&-65537|128;case 0:if(b=V.payload,N=typeof b=="function"?b.call($,R,N):b,N==null)break e;R=z({},R,N);break e;case 2:_r=!0}}d.callback!==null&&d.lane!==0&&(e.flags|=64,N=s.effects,N===null?s.effects=[d]:N.push(d))}else $={eventTime:$,lane:N,tag:d.tag,payload:d.payload,callback:d.callback,next:null},E===null?(w=E=$,g=R):E=E.next=$,u|=N;if(d=d.next,d===null){if(d=s.shared.pending,d===null)break;N=d,d=N.next,N.next=null,s.lastBaseUpdate=N,s.shared.pending=null}}while(!0);if(E===null&&(g=R),s.baseState=g,s.firstBaseUpdate=w,s.lastBaseUpdate=E,t=s.shared.interleaved,t!==null){s=t;do u|=s.lane,s=s.next;while(s!==t)}else l===null&&(s.shared.lanes=0);br|=u,e.lanes=u,e.memoizedState=R}}function Ja(e,t,n){if(e=t.effects,t.effects=null,e!==null)for(t=0;tn?n:4,e(!0);var r=Jl.transition;Jl.transition={};try{e(!1),t()}finally{j=n,Jl.transition=r}}function hu(){return un().memoizedState}function Fd(e,t,n){var r=Cr(e);if(n={lane:r,action:n,hasEagerState:!1,eagerState:null,next:null},gu(e))vu(t,n);else if(n=Ka(e,t,n,r),n!==null){var s=jt();Pn(n,e,r,s),yu(n,t,r)}}function Ud(e,t,n){var r=Cr(e),s={lane:r,action:n,hasEagerState:!1,eagerState:null,next:null};if(gu(e))vu(t,s);else{var l=e.alternate;if(e.lanes===0&&(l===null||l.lanes===0)&&(l=t.lastRenderedReducer,l!==null))try{var u=t.lastRenderedState,d=l(u,n);if(s.hasEagerState=!0,s.eagerState=d,jn(d,u)){var g=t.interleaved;g===null?(s.next=s,Vl(t)):(s.next=g.next,g.next=s),t.interleaved=s;return}}catch{}n=Ka(e,t,s,r),n!==null&&(s=jt(),Pn(n,e,r,s),yu(n,t,r))}}function gu(e){var t=e.alternate;return e===be||t!==null&&t===be}function vu(e,t){bs=To=!0;var n=e.pending;n===null?t.next=t:(t.next=n.next,n.next=t),e.pending=t}function yu(e,t,n){if((n&4194240)!==0){var r=t.lanes;r&=e.pendingLanes,n|=r,t.lanes=n,M(e,n)}}var Lo={readContext:an,useCallback:ft,useContext:ft,useEffect:ft,useImperativeHandle:ft,useInsertionEffect:ft,useLayoutEffect:ft,useMemo:ft,useReducer:ft,useRef:ft,useState:ft,useDebugValue:ft,useDeferredValue:ft,useTransition:ft,useMutableSource:ft,useSyncExternalStore:ft,useId:ft,unstable_isNewReconciler:!1},Bd={readContext:an,useCallback:function(e,t){return Un().memoizedState=[e,t===void 0?null:t],e},useContext:an,useEffect:iu,useImperativeHandle:function(e,t,n){return n=n!=null?n.concat([e]):null,Ao(4194308,4,cu.bind(null,t,e),n)},useLayoutEffect:function(e,t){return Ao(4194308,4,e,t)},useInsertionEffect:function(e,t){return Ao(4,2,e,t)},useMemo:function(e,t){var n=Un();return t=t===void 0?null:t,e=e(),n.memoizedState=[e,t],e},useReducer:function(e,t,n){var r=Un();return t=n!==void 0?n(t):t,r.memoizedState=r.baseState=t,e={pending:null,interleaved:null,lanes:0,dispatch:null,lastRenderedReducer:e,lastRenderedState:t},r.queue=e,e=e.dispatch=Fd.bind(null,be,e),[r.memoizedState,e]},useRef:function(e){var t=Un();return e={current:e},t.memoizedState=e},useState:ou,useDebugValue:ri,useDeferredValue:function(e){return Un().memoizedState=e},useTransition:function(){var e=ou(!1),t=e[0];return e=$d.bind(null,e[1]),Un().memoizedState=e,[t,e]},useMutableSource:function(){},useSyncExternalStore:function(e,t,n){var r=be,s=Un();if($e){if(n===void 0)throw Error(m(407));n=n()}else{if(n=t(),st===null)throw Error(m(349));(Br&30)!==0||eu(r,t,n)}s.memoizedState=n;var l={value:n,getSnapshot:t};return s.queue=l,iu(nu.bind(null,r,l,e),[e]),r.flags|=2048,Qs(9,tu.bind(null,r,l,n,t),void 0,null),n},useId:function(){var e=Un(),t=st.identifierPrefix;if($e){var n=Jn,r=Gn;n=(r&~(1<<32-ct(r)-1)).toString(32)+n,t=":"+t+"R"+n,n=Hs++,0<\/script>",e=e.removeChild(e.firstChild)):typeof r.is=="string"?e=u.createElement(n,{is:r.is}):(e=u.createElement(n),n==="select"&&(u=e,r.multiple?u.multiple=!0:r.size&&(u.size=r.size))):e=u.createElementNS(e,n),e[$n]=t,e[Os]=r,$u(e,t,!1,!1),t.stateNode=e;e:{switch(u=Zt(n,r),n){case"dialog":De("cancel",e),De("close",e),s=r;break;case"iframe":case"object":case"embed":De("load",e),s=r;break;case"video":case"audio":for(s=0;svs&&(t.flags|=128,r=!0,Ws(l,!1),t.lanes=4194304)}else{if(!r)if(e=Mo(u),e!==null){if(t.flags|=128,r=!0,n=e.updateQueue,n!==null&&(t.updateQueue=n,t.flags|=4),Ws(l,!0),l.tail===null&&l.tailMode==="hidden"&&!u.alternate&&!$e)return mt(t),null}else 2*_e()-l.renderingStartTime>vs&&n!==1073741824&&(t.flags|=128,r=!0,Ws(l,!1),t.lanes=4194304);l.isBackwards?(u.sibling=t.child,t.child=u):(n=l.last,n!==null?n.sibling=u:t.child=u,l.last=u)}return l.tail!==null?(t=l.tail,l.rendering=t,l.tail=t.sibling,l.renderingStartTime=_e(),t.sibling=null,n=Be.current,Ae(Be,r?n&1|2:n&1),t):(mt(t),null);case 22:case 23:return Ei(),r=t.memoizedState!==null,e!==null&&e.memoizedState!==null!==r&&(t.flags|=8192),r&&(t.mode&1)!==0?(Qt&1073741824)!==0&&(mt(t),t.subtreeFlags&6&&(t.flags|=8192)):mt(t),null;case 24:return null;case 25:return null}throw Error(m(156,t.tag))}function Gd(e,t){switch(Ol(t),t.tag){case 1:return Rt(t.type)&&yo(),e=t.flags,e&65536?(t.flags=e&-65537|128,t):null;case 3:return ms(),Oe(Mt),Oe(dt),Gl(),e=t.flags,(e&65536)!==0&&(e&128)===0?(t.flags=e&-65537|128,t):null;case 5:return Kl(t),null;case 13:if(Oe(Be),e=t.memoizedState,e!==null&&e.dehydrated!==null){if(t.alternate===null)throw Error(m(340));us()}return e=t.flags,e&65536?(t.flags=e&-65537|128,t):null;case 19:return Oe(Be),null;case 4:return ms(),null;case 10:return bl(t.type._context),null;case 22:case 23:return Ei(),null;case 24:return null;default:return null}}var $o=!1,pt=!1,Jd=typeof WeakSet=="function"?WeakSet:Set,B=null;function hs(e,t){var n=e.ref;if(n!==null)if(typeof n=="function")try{n(null)}catch(r){Qe(e,t,r)}else n.current=null}function hi(e,t,n){try{n()}catch(r){Qe(e,t,r)}}var Bu=!1;function Yd(e,t){if(El=ro,e=xa(),xl(e)){if("selectionStart"in e)var n={start:e.selectionStart,end:e.selectionEnd};else e:{n=(n=e.ownerDocument)&&n.defaultView||window;var r=n.getSelection&&n.getSelection();if(r&&r.rangeCount!==0){n=r.anchorNode;var s=r.anchorOffset,l=r.focusNode;r=r.focusOffset;try{n.nodeType,l.nodeType}catch{n=null;break e}var u=0,d=-1,g=-1,w=0,E=0,R=e,N=null;t:for(;;){for(var $;R!==n||s!==0&&R.nodeType!==3||(d=u+s),R!==l||r!==0&&R.nodeType!==3||(g=u+r),R.nodeType===3&&(u+=R.nodeValue.length),($=R.firstChild)!==null;)N=R,R=$;for(;;){if(R===e)break t;if(N===n&&++w===s&&(d=u),N===l&&++E===r&&(g=u),($=R.nextSibling)!==null)break;R=N,N=R.parentNode}R=$}n=d===-1||g===-1?null:{start:d,end:g}}else n=null}n=n||{start:0,end:0}}else n=null;for(Pl={focusedElem:e,selectionRange:n},ro=!1,B=t;B!==null;)if(t=B,e=t.child,(t.subtreeFlags&1028)!==0&&e!==null)e.return=t,B=e;else for(;B!==null;){t=B;try{var b=t.alternate;if((t.flags&1024)!==0)switch(t.tag){case 0:case 11:case 15:break;case 1:if(b!==null){var V=b.memoizedProps,qe=b.memoizedState,_=t.stateNode,v=_.getSnapshotBeforeUpdate(t.elementType===t.type?V:Cn(t.type,V),qe);_.__reactInternalSnapshotBeforeUpdate=v}break;case 3:var S=t.stateNode.containerInfo;S.nodeType===1?S.textContent="":S.nodeType===9&&S.documentElement&&S.removeChild(S.documentElement);break;case 5:case 6:case 4:case 17:break;default:throw Error(m(163))}}catch(T){Qe(t,t.return,T)}if(e=t.sibling,e!==null){e.return=t.return,B=e;break}B=t.return}return b=Bu,Bu=!1,b}function Ks(e,t,n){var r=t.updateQueue;if(r=r!==null?r.lastEffect:null,r!==null){var s=r=r.next;do{if((s.tag&e)===e){var l=s.destroy;s.destroy=void 0,l!==void 0&&hi(t,n,l)}s=s.next}while(s!==r)}}function Fo(e,t){if(t=t.updateQueue,t=t!==null?t.lastEffect:null,t!==null){var n=t=t.next;do{if((n.tag&e)===e){var r=n.create;n.destroy=r()}n=n.next}while(n!==t)}}function gi(e){var t=e.ref;if(t!==null){var n=e.stateNode;e.tag,e=n,typeof t=="function"?t(e):t.current=e}}function bu(e){var t=e.alternate;t!==null&&(e.alternate=null,bu(t)),e.child=null,e.deletions=null,e.sibling=null,e.tag===5&&(t=e.stateNode,t!==null&&(delete t[$n],delete t[Os],delete t[Al],delete t[Id],delete t[Ld])),e.stateNode=null,e.return=null,e.dependencies=null,e.memoizedProps=null,e.memoizedState=null,e.pendingProps=null,e.stateNode=null,e.updateQueue=null}function Hu(e){return e.tag===5||e.tag===3||e.tag===4}function Vu(e){e:for(;;){for(;e.sibling===null;){if(e.return===null||Hu(e.return))return null;e=e.return}for(e.sibling.return=e.return,e=e.sibling;e.tag!==5&&e.tag!==6&&e.tag!==18;){if(e.flags&2||e.child===null||e.tag===4)continue e;e.child.return=e,e=e.child}if(!(e.flags&2))return e.stateNode}}function vi(e,t,n){var r=e.tag;if(r===5||r===6)e=e.stateNode,t?n.nodeType===8?n.parentNode.insertBefore(e,t):n.insertBefore(e,t):(n.nodeType===8?(t=n.parentNode,t.insertBefore(e,n)):(t=n,t.appendChild(e)),n=n._reactRootContainer,n!=null||t.onclick!==null||(t.onclick=go));else if(r!==4&&(e=e.child,e!==null))for(vi(e,t,n),e=e.sibling;e!==null;)vi(e,t,n),e=e.sibling}function yi(e,t,n){var r=e.tag;if(r===5||r===6)e=e.stateNode,t?n.insertBefore(e,t):n.appendChild(e);else if(r!==4&&(e=e.child,e!==null))for(yi(e,t,n),e=e.sibling;e!==null;)yi(e,t,n),e=e.sibling}var at=null,Nn=!1;function wr(e,t,n){for(n=n.child;n!==null;)Qu(e,t,n),n=n.sibling}function Qu(e,t,n){if(Nt&&typeof Nt.onCommitFiberUnmount=="function")try{Nt.onCommitFiberUnmount(mr,n)}catch{}switch(n.tag){case 5:pt||hs(n,t);case 6:var r=at,s=Nn;at=null,wr(e,t,n),at=r,Nn=s,at!==null&&(Nn?(e=at,n=n.stateNode,e.nodeType===8?e.parentNode.removeChild(n):e.removeChild(n)):at.removeChild(n.stateNode));break;case 18:at!==null&&(Nn?(e=at,n=n.stateNode,e.nodeType===8?Tl(e.parentNode,n):e.nodeType===1&&Tl(e,n),Cs(e)):Tl(at,n.stateNode));break;case 4:r=at,s=Nn,at=n.stateNode.containerInfo,Nn=!0,wr(e,t,n),at=r,Nn=s;break;case 0:case 11:case 14:case 15:if(!pt&&(r=n.updateQueue,r!==null&&(r=r.lastEffect,r!==null))){s=r=r.next;do{var l=s,u=l.destroy;l=l.tag,u!==void 0&&((l&2)!==0||(l&4)!==0)&&hi(n,t,u),s=s.next}while(s!==r)}wr(e,t,n);break;case 1:if(!pt&&(hs(n,t),r=n.stateNode,typeof r.componentWillUnmount=="function"))try{r.props=n.memoizedProps,r.state=n.memoizedState,r.componentWillUnmount()}catch(d){Qe(n,t,d)}wr(e,t,n);break;case 21:wr(e,t,n);break;case 22:n.mode&1?(pt=(r=pt)||n.memoizedState!==null,wr(e,t,n),pt=r):wr(e,t,n);break;default:wr(e,t,n)}}function Wu(e){var t=e.updateQueue;if(t!==null){e.updateQueue=null;var n=e.stateNode;n===null&&(n=e.stateNode=new Jd),t.forEach(function(r){var s=lf.bind(null,e,r);n.has(r)||(n.add(r),r.then(s,s))})}}function En(e,t){var n=t.deletions;if(n!==null)for(var r=0;rs&&(s=u),r&=~l}if(r=s,r=_e()-r,r=(120>r?120:480>r?480:1080>r?1080:1920>r?1920:3e3>r?3e3:4320>r?4320:1960*Zd(r/1960))-r,10e?16:e,kr===null)var r=!1;else{if(e=kr,kr=null,Vo=0,(Se&6)!==0)throw Error(m(331));var s=Se;for(Se|=4,B=e.current;B!==null;){var l=B,u=l.child;if((B.flags&16)!==0){var d=l.deletions;if(d!==null){for(var g=0;g_e()-Si?Vr(e,0):_i|=n),It(e,t)}function oc(e,t){t===0&&((e.mode&1)===0?t=1:(t=_t,_t<<=1,(_t&130023424)===0&&(_t=4194304)));var n=jt();e=Yn(e,t),e!==null&&(_n(e,t,n),It(e,n))}function of(e){var t=e.memoizedState,n=0;t!==null&&(n=t.retryLane),oc(e,n)}function lf(e,t){var n=0;switch(e.tag){case 13:var r=e.stateNode,s=e.memoizedState;s!==null&&(n=s.retryLane);break;case 19:r=e.stateNode;break;default:throw Error(m(314))}r!==null&&r.delete(t),oc(e,n)}var lc;lc=function(e,t,n){if(e!==null)if(e.memoizedProps!==t.pendingProps||Mt.current)Tt=!0;else{if((e.lanes&n)===0&&(t.flags&128)===0)return Tt=!1,Kd(e,t,n);Tt=(e.flags&131072)!==0}else Tt=!1,$e&&(t.flags&1048576)!==0&&Fa(t,wo,t.index);switch(t.lanes=0,t.tag){case 2:var r=t.type;zo(e,t),e=t.pendingProps;var s=ls(t,dt.current);fs(t,n),s=Xl(null,t,r,e,s,n);var l=Zl();return t.flags|=1,typeof s=="object"&&s!==null&&typeof s.render=="function"&&s.$$typeof===void 0?(t.tag=1,t.memoizedState=null,t.updateQueue=null,Rt(r)?(l=!0,xo(t)):l=!1,t.memoizedState=s.state!==null&&s.state!==void 0?s.state:null,Ql(t),s.updater=Do,t.stateNode=s,s._reactInternals=t,oi(t,r,e,n),t=ui(null,t,r,!0,l,n)):(t.tag=0,$e&&l&&Dl(t),wt(null,t,s,n),t=t.child),t;case 16:r=t.elementType;e:{switch(zo(e,t),e=t.pendingProps,s=r._init,r=s(r._payload),t.type=r,s=t.tag=uf(r),e=Cn(r,e),s){case 0:t=ai(null,t,r,e,n);break e;case 1:t=Au(null,t,r,e,n);break e;case 11:t=Eu(null,t,r,e,n);break e;case 14:t=Pu(null,t,r,Cn(r.type,e),n);break e}throw Error(m(306,r,""))}return t;case 0:return r=t.type,s=t.pendingProps,s=t.elementType===r?s:Cn(r,s),ai(e,t,r,s,n);case 1:return r=t.type,s=t.pendingProps,s=t.elementType===r?s:Cn(r,s),Au(e,t,r,s,n);case 3:e:{if(Iu(t),e===null)throw Error(m(387));r=t.pendingProps,l=t.memoizedState,s=l.element,qa(e,t),Po(t,r,null,n);var u=t.memoizedState;if(r=u.element,l.isDehydrated)if(l={element:r,isDehydrated:!1,cache:u.cache,pendingSuspenseBoundaries:u.pendingSuspenseBoundaries,transitions:u.transitions},t.updateQueue.baseState=l,t.memoizedState=l,t.flags&256){s=ps(Error(m(423)),t),t=Lu(e,t,r,n,s);break e}else if(r!==s){s=ps(Error(m(424)),t),t=Lu(e,t,r,n,s);break e}else for(Vt=gr(t.stateNode.containerInfo.firstChild),Ht=t,$e=!0,kn=null,n=Wa(t,null,r,n),t.child=n;n;)n.flags=n.flags&-3|4096,n=n.sibling;else{if(us(),r===s){t=Zn(e,t,n);break e}wt(e,t,r,n)}t=t.child}return t;case 5:return Ya(t),e===null&&$l(t),r=t.type,s=t.pendingProps,l=e!==null?e.memoizedProps:null,u=s.children,Ml(r,s)?u=null:l!==null&&Ml(r,l)&&(t.flags|=32),Tu(e,t),wt(e,t,u,n),t.child;case 6:return e===null&&$l(t),null;case 13:return Du(e,t,n);case 4:return Wl(t,t.stateNode.containerInfo),r=t.pendingProps,e===null?t.child=cs(t,null,r,n):wt(e,t,r,n),t.child;case 11:return r=t.type,s=t.pendingProps,s=t.elementType===r?s:Cn(r,s),Eu(e,t,r,s,n);case 7:return wt(e,t,t.pendingProps,n),t.child;case 8:return wt(e,t,t.pendingProps.children,n),t.child;case 12:return wt(e,t,t.pendingProps.children,n),t.child;case 10:e:{if(r=t.type._context,s=t.pendingProps,l=t.memoizedProps,u=s.value,Ae(Co,r._currentValue),r._currentValue=u,l!==null)if(jn(l.value,u)){if(l.children===s.children&&!Mt.current){t=Zn(e,t,n);break e}}else for(l=t.child,l!==null&&(l.return=t);l!==null;){var d=l.dependencies;if(d!==null){u=l.child;for(var g=d.firstContext;g!==null;){if(g.context===r){if(l.tag===1){g=Xn(-1,n&-n),g.tag=2;var w=l.updateQueue;if(w!==null){w=w.shared;var E=w.pending;E===null?g.next=g:(g.next=E.next,E.next=g),w.pending=g}}l.lanes|=n,g=l.alternate,g!==null&&(g.lanes|=n),Hl(l.return,n,t),d.lanes|=n;break}g=g.next}}else if(l.tag===10)u=l.type===t.type?null:l.child;else if(l.tag===18){if(u=l.return,u===null)throw Error(m(341));u.lanes|=n,d=u.alternate,d!==null&&(d.lanes|=n),Hl(u,n,t),u=l.sibling}else u=l.child;if(u!==null)u.return=l;else for(u=l;u!==null;){if(u===t){u=null;break}if(l=u.sibling,l!==null){l.return=u.return,u=l;break}u=u.return}l=u}wt(e,t,s.children,n),t=t.child}return t;case 9:return s=t.type,r=t.pendingProps.children,fs(t,n),s=an(s),r=r(s),t.flags|=1,wt(e,t,r,n),t.child;case 14:return r=t.type,s=Cn(r,t.pendingProps),s=Cn(r.type,s),Pu(e,t,r,s,n);case 15:return Mu(e,t,t.type,t.pendingProps,n);case 17:return r=t.type,s=t.pendingProps,s=t.elementType===r?s:Cn(r,s),zo(e,t),t.tag=1,Rt(r)?(e=!0,xo(t)):e=!1,fs(t,n),_u(t,r,s),oi(t,r,s,n),ui(null,t,r,!0,e,n);case 19:return zu(e,t,n);case 22:return Ru(e,t,n)}throw Error(m(156,t.tag))};function ic(e,t){return Rr(e,t)}function af(e,t,n,r){this.tag=e,this.key=n,this.sibling=this.child=this.return=this.stateNode=this.type=this.elementType=null,this.index=0,this.ref=null,this.pendingProps=t,this.dependencies=this.memoizedState=this.updateQueue=this.memoizedProps=null,this.mode=r,this.subtreeFlags=this.flags=0,this.deletions=null,this.childLanes=this.lanes=0,this.alternate=null}function dn(e,t,n,r){return new af(e,t,n,r)}function Mi(e){return e=e.prototype,!(!e||!e.isReactComponent)}function uf(e){if(typeof e=="function")return Mi(e)?1:0;if(e!=null){if(e=e.$$typeof,e===lt)return 11;if(e===ve)return 14}return 2}function Er(e,t){var n=e.alternate;return n===null?(n=dn(e.tag,t,e.key,e.mode),n.elementType=e.elementType,n.type=e.type,n.stateNode=e.stateNode,n.alternate=e,e.alternate=n):(n.pendingProps=t,n.type=e.type,n.flags=0,n.subtreeFlags=0,n.deletions=null),n.flags=e.flags&14680064,n.childLanes=e.childLanes,n.lanes=e.lanes,n.child=e.child,n.memoizedProps=e.memoizedProps,n.memoizedState=e.memoizedState,n.updateQueue=e.updateQueue,t=e.dependencies,n.dependencies=t===null?null:{lanes:t.lanes,firstContext:t.firstContext},n.sibling=e.sibling,n.index=e.index,n.ref=e.ref,n}function qo(e,t,n,r,s,l){var u=2;if(r=e,typeof e=="function")Mi(e)&&(u=1);else if(typeof e=="string")u=5;else e:switch(e){case Le:return Wr(n.children,s,l,t);case We:u=8,s|=8;break;case se:return e=dn(12,n,t,s|2),e.elementType=se,e.lanes=l,e;case Ye:return e=dn(13,n,t,s),e.elementType=Ye,e.lanes=l,e;case nt:return e=dn(19,n,t,s),e.elementType=nt,e.lanes=l,e;case pe:return Go(n,s,l,t);default:if(typeof e=="object"&&e!==null)switch(e.$$typeof){case Fe:u=10;break e;case Ke:u=9;break e;case lt:u=11;break e;case ve:u=14;break e;case Me:u=16,r=null;break e}throw Error(m(130,e==null?e:typeof e,""))}return t=dn(u,n,t,s),t.elementType=e,t.type=r,t.lanes=l,t}function Wr(e,t,n,r){return e=dn(7,e,r,t),e.lanes=n,e}function Go(e,t,n,r){return e=dn(22,e,r,t),e.elementType=pe,e.lanes=n,e.stateNode={isHidden:!1},e}function Ri(e,t,n){return e=dn(6,e,null,t),e.lanes=n,e}function Ti(e,t,n){return t=dn(4,e.children!==null?e.children:[],e.key,t),t.lanes=n,t.stateNode={containerInfo:e.containerInfo,pendingChildren:null,implementation:e.implementation},t}function cf(e,t,n,r,s){this.tag=t,this.containerInfo=e,this.finishedWork=this.pingCache=this.current=this.pendingChildren=null,this.timeoutHandle=-1,this.callbackNode=this.pendingContext=this.context=null,this.callbackPriority=0,this.eventTimes=St(0),this.expirationTimes=St(-1),this.entangledLanes=this.finishedLanes=this.mutableReadLanes=this.expiredLanes=this.pingedLanes=this.suspendedLanes=this.pendingLanes=0,this.entanglements=St(0),this.identifierPrefix=r,this.onRecoverableError=s,this.mutableSourceEagerHydrationData=null}function Ai(e,t,n,r,s,l,u,d,g){return e=new cf(e,t,n,d,g),t===1?(t=1,l===!0&&(t|=8)):t=0,l=dn(3,null,null,t),e.current=l,l.stateNode=e,l.memoizedState={element:r,isDehydrated:n,cache:null,transitions:null,pendingSuspenseBoundaries:null},Ql(l),e}function df(e,t,n){var r=3"u"||typeof __REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE!="function"))try{__REACT_DEVTOOLS_GLOBAL_HOOK__.checkDCE(i)}catch(h){console.error(h)}}return i(),$i.exports=jf(),$i.exports}var Sc;function Cf(){if(Sc)return nl;Sc=1;var i=kf();return nl.createRoot=i.createRoot,nl.hydrateRoot=i.hydrateRoot,nl}var Nf=Cf();const Ef=zc(Nf),Pf="/api";async function Pe(i,h){const m=await fetch(`${Pf}${i}`,{...h,headers:{"Content-Type":"application/json",...h?.headers??{}}}),I=await m.json();if(!m.ok){const C=I.error?.message??"Ошибка запроса";throw new Error(C)}return I}const Ne={async listModels(i){return Pe("/llm/models",{method:"POST",body:JSON.stringify({llmProvider:i.llmProvider,apiKey:i.apiKey,model:i.model,baseUrl:i.baseUrl})})},async testConnection(i){return Pe("/llm/test-connection",{method:"POST",body:JSON.stringify({llmProvider:i.llmProvider,apiKey:i.apiKey,model:i.model,baseUrl:i.baseUrl})})},async normalize(i){return Pe("/normalize",{method:"POST",body:JSON.stringify({llmProvider:i.connection.llmProvider,apiKey:i.connection.apiKey,model:i.connection.model,baseUrl:i.connection.baseUrl,temperature:i.connection.temperature,maxOutputTokens:i.connection.maxOutputTokens,promptVersion:i.promptVersion,systemPrompt:i.prompts.systemPrompt,developerPrompt:i.prompts.developerPrompt,domainPrompt:i.prompts.domainPrompt,fewShotExamples:i.prompts.fewShotExamples,userQuestion:i.query.userQuestion,context:{period_hint:i.query.periodHint??"",business_context:i.query.businessContext??"",expected_route:i.query.expectedRoute??""},saveAsTestCase:!!i.saveAsTestCase,useMock:!!i.useMock})})},async loadHistory(){return Pe("/history")},async loadTrace(i){return Pe(`/history/${i}`)},async loadPresets(){return Pe("/presets")},async savePreset(i){return Pe("/presets/save",{method:"POST",body:JSON.stringify(i)})},async runEval(i){return Pe("/eval/run",{method:"POST",body:JSON.stringify({normalizeConfig:{llmProvider:i.connection.llmProvider,apiKey:i.connection.apiKey,model:i.connection.model,baseUrl:i.connection.baseUrl,temperature:i.connection.temperature,maxOutputTokens:i.connection.maxOutputTokens,promptVersion:i.promptVersion,systemPrompt:i.prompts.systemPrompt,developerPrompt:i.prompts.developerPrompt,domainPrompt:i.prompts.domainPrompt,fewShotExamples:i.prompts.fewShotExamples},caseIds:i.caseIds,useMock:!!i.useMock,mode:i.mode??"standard",caseSetFile:i.caseSetFile,rawQuestions:i.rawQuestions,eval_target:i.evalTarget,compare_with_report_file:i.compareWithReportFile,analysis_date:i.analysisDate})})},async startEvalRunAsync(i){return Pe("/eval/run-async/start",{method:"POST",body:JSON.stringify({normalizeConfig:{llmProvider:i.connection.llmProvider,apiKey:i.connection.apiKey,model:i.connection.model,baseUrl:i.connection.baseUrl,temperature:i.connection.temperature,maxOutputTokens:i.connection.maxOutputTokens,promptVersion:i.promptVersion,systemPrompt:i.prompts.systemPrompt,developerPrompt:i.prompts.developerPrompt,domainPrompt:i.prompts.domainPrompt,fewShotExamples:i.prompts.fewShotExamples},caseIds:i.caseIds,useMock:!!i.useMock,mode:i.mode??"standard",caseSetFile:i.caseSetFile,rawQuestions:i.rawQuestions,eval_target:i.evalTarget,compare_with_report_file:i.compareWithReportFile,questions:i.questions,analysis_date:i.analysisDate})})},async loadEvalRunAsyncStatus(i){return Pe(`/eval/run-async/${encodeURIComponent(i)}`)},async startRun(){return Pe("/accounting-agent/v1/runs/start",{method:"POST",body:JSON.stringify({initiator:"ndc_operator",source:"gui"})})},async finishRun(i){return Pe("/accounting-agent/v1/runs/finish",{method:"POST",body:JSON.stringify({runId:i,status:"DONE",source:"gui",reason:"Остановлено оператором из GUI"})})},async listRuns(){return Pe("/accounting-agent/v1/runs")},async listResults(){return Pe("/accounting-agent/v1/results")},async runTrace(i){return Pe(`/accounting-agent/v1/trace/run/${i}`)},async sendAssistantMessage(i){return Pe("/assistant/message",{method:"POST",body:JSON.stringify({session_id:i.sessionId??"",mode:"assistant",message:i.userMessage,user_message:i.userMessage,llmProvider:i.connection.llmProvider,apiKey:i.connection.apiKey,model:i.connection.model,baseUrl:i.connection.baseUrl,temperature:i.connection.temperature,maxOutputTokens:i.connection.maxOutputTokens,promptVersion:i.promptVersion??"address_query_runtime_v1",systemPrompt:i.prompts.systemPrompt,developerPrompt:i.prompts.developerPrompt,domainPrompt:i.prompts.domainPrompt,fewShotExamples:i.prompts.fewShotExamples,context:{period_hint:i.context?.periodHint??"",business_context:i.context?.businessContext??""},useMock:!!i.useMock})})},async loadAssistantSession(i){return Pe(`/assistant/session/${i}`)},async loadAssistantAnnotations(i){const h=new URLSearchParams;i?.session_id&&h.set("session_id",i.session_id),typeof i?.limit=="number"&&h.set("limit",String(i.limit));const m=h.toString();return Pe(`/assistant/annotations${m?`?${m}`:""}`)},async saveAssistantAnnotation(i){return Pe("/assistant/annotations",{method:"POST",body:JSON.stringify(i)})},async loadAutoRunsHistory(i){const h=new URLSearchParams;i?.from&&h.set("from",i.from),i?.to&&h.set("to",i.to),i?.target&&h.set("target",i.target),i?.mode&&h.set("mode",i.mode),i?.use_mock&&h.set("use_mock",i.use_mock),i?.prompt_contains&&h.set("prompt_contains",i.prompt_contains),typeof i?.limit=="number"&&h.set("limit",String(i.limit)),typeof i?.scan_limit=="number"&&h.set("scan_limit",String(i.scan_limit));const m=h.toString();return Pe(`/autoruns/history${m?`?${m}`:""}`)},async loadAutoRunDetail(i){return Pe(`/autoruns/history/${encodeURIComponent(i)}`)},async loadAutoRunCaseDialog(i,h){return Pe(`/autoruns/history/${encodeURIComponent(i)}/case/${encodeURIComponent(h)}/dialog`)},async loadAutoRunAnnotations(i){const h=new URLSearchParams;i?.run_id&&h.set("run_id",i.run_id),i?.case_id&&h.set("case_id",i.case_id),typeof i?.min_rating=="number"&&h.set("min_rating",String(i.min_rating)),i?.manual_case_decision&&h.set("manual_case_decision",i.manual_case_decision),typeof i?.limit=="number"&&h.set("limit",String(i.limit));const m=h.toString();return Pe(`/autoruns/annotations${m?`?${m}`:""}`)},async saveAutoRunAnnotation(i){return Pe("/autoruns/annotations",{method:"POST",body:JSON.stringify(i)})},async updateAutoRunAnnotation(i){return Pe(`/autoruns/annotations/${encodeURIComponent(i.annotation_id)}`,{method:"PATCH",body:JSON.stringify({resolved:i.resolved,resolved_by:i.resolved_by})})},async loadAutoRunPostAnalysis(i){const h=new URLSearchParams;i?.run_id&&h.set("run_id",i.run_id),typeof i?.limit_per_queue=="number"&&h.set("limit_per_queue",String(i.limit_per_queue)),typeof i?.annotation_limit=="number"&&h.set("annotation_limit",String(i.annotation_limit)),typeof i?.scan_limit=="number"&&h.set("scan_limit",String(i.scan_limit)),i?.from&&h.set("from",i.from),i?.to&&h.set("to",i.to),i?.target&&h.set("target",i.target),i?.mode&&h.set("mode",i.mode),i?.use_mock&&h.set("use_mock",i.use_mock),i?.prompt_contains&&h.set("prompt_contains",i.prompt_contains);const m=h.toString();return Pe(`/autoruns/post-analysis${m?`?${m}`:""}`)},async loadAutoRunAutogenHistory(i){const h=new URLSearchParams;i?.mode&&h.set("mode",i.mode),typeof i?.limit=="number"&&h.set("limit",String(i.limit));const m=h.toString();return Pe(`/autoruns/autogen/history${m?`?${m}`:""}`)},async loadAutoRunAutogenPersonalityCatalog(){return Pe("/autoruns/autogen/personality-catalog")},async generateAutoRunQuestions(i){return Pe("/autoruns/autogen/generate",{method:"POST",body:JSON.stringify(i)})}};function Wt({value:i}){return o.jsx("pre",{className:"json-view",children:JSON.stringify(i??{},null,2)})}function Mn({title:i,subtitle:h,actions:m,className:I,hideHeader:C,children:L}){return o.jsxs("section",{className:I?`panel-frame ${I}`:"panel-frame",children:[C?null:o.jsxs("header",{className:"panel-header",children:[o.jsxs("div",{children:[o.jsx("h2",{children:i}),h?o.jsx("p",{children:h}):null]}),m?o.jsx("div",{className:"panel-actions",children:m}):null]}),o.jsx("div",{className:"panel-body",children:L})]})}function Mf(i){const h=new Date(i);return Number.isNaN(h.getTime())?i:h.toLocaleString("ru-RU")}function Rf({sessionId:i,conversation:h,statusText:m,errorMessage:I,useMock:C,appLogs:L}){const U=h.filter(D=>D.role==="assistant").length,Z=h.filter(D=>D.role==="user").length,F=h.length>0?h[h.length-1]:null;return o.jsxs(Mn,{title:"SAM",subtitle:"System Assistant Monitor: срез по текущей сессии и логам.",children:[o.jsxs("div",{className:"metrics-grid",children:[o.jsxs("div",{children:[o.jsx("span",{children:"session_id"}),o.jsx("strong",{children:i||"новая сессия"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"mock_mode"}),o.jsx("strong",{children:C?"on":"off"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"сообщений пользователя"}),o.jsx("strong",{children:Z})]}),o.jsxs("div",{children:[o.jsx("span",{children:"ответов ассистента"}),o.jsx("strong",{children:U})]}),o.jsxs("div",{children:[o.jsx("span",{children:"статус"}),o.jsx("strong",{children:m||"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"ошибка"}),o.jsx("strong",{children:I||"нет"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"последнее сообщение"}),o.jsx("strong",{children:F?.created_at?Mf(F.created_at):"нет данных"})]})]}),o.jsx("h3",{style:{marginTop:12},children:"Последние системные логи"}),o.jsx(Wt,{value:L.slice(0,120)})]})}const Tf=/(?:^|\n)\s*#{0,6}\s*(?:debug_payload_json|technical_breakdown_json|route_summary_json|debug_payload|technical_breakdown)\b/i,Af=[/\b(?:debug_payload_json|technical_breakdown_json)\b/i,/\b(?:route_summary|semantic_profile|domain_scope|relation_patterns|account_scope)\b/i,/\b(?:coverage_report|retrieval_status|problem_unit_state|candidate_evidence)\b/i,/\b(?:graph_domain_scope|graph_runtime|selection_reason|why_included)\b/i];function If(i){try{return JSON.stringify(i,null,2)}catch{return String(i)}}function Lf(i){const h=String(i??""),m=h.match(Tf);return(m?h.slice(0,m.index):h).replace(/###\s*(?:debug_payload_json|technical_breakdown_json|route_summary_json)[\s\S]*?(?:```[\s\S]*?```|$)/gi,"").replace(/(?:^|\n)\s*#{0,6}\s*(?:debug_payload_json|technical_breakdown_json|route_summary_json)\b[\s\S]*$/gi,"").split(/\r?\n/g).map(U=>U.trimEnd()).filter(U=>U.trim().length>0).filter(U=>!Af.some(Z=>Z.test(U))).join(` -`).trim()}function Df(i,h,m="default"){const I=m==="technical",C=[];C.push("# Assistant conversation export"),C.push(`session_id: ${i||"n/a"}`),C.push(`export_mode: ${m}`),C.push(`exported_at: ${new Date().toISOString()}`),C.push("");for(let L=0;L{C.length!==0&&(I.push(C.join(` -`)),C=[])};for(const U of m){const Z=U.trimEnd(),F=Z.trim();if(!F){L();continue}const D=/^Блок\s+\d+\./i.test(F),q=/^\d+\.\s/.test(F);(D||q)&&C.length>0&&L(),C.push(Z)}return L(),I.length>0?I:[i]}function bf(i,h){const m=[],I=/\*\*(.+?)\*\*/g;let C=0,L=0,U;for(;(U=I.exec(i))!==null;)U.index>C&&(m.push(o.jsx("span",{children:i.slice(C,U.index)},`${h}-t-${L}`)),L+=1),m.push(o.jsx("strong",{children:U[1]},`${h}-b-${L}`)),L+=1,C=I.lastIndex;return C0?m:[o.jsx("span",{children:i},`${h}-raw`)]}function Hf(i){const h=i.trimStart();return/^Блок\s+\d+\./i.test(h)?"assistant-msg-line heading":/^\d+\.\s/.test(h)?"assistant-msg-line numbered":/^-\s/.test(h)?"assistant-msg-line bullet":"assistant-msg-line"}function Vf(i){return Bf(i).map((m,I)=>{const C=m.split(` -`);return o.jsx("div",{className:"assistant-msg-block",children:C.map((L,U)=>o.jsx("p",{className:Hf(L),children:bf(L,`line-${I}-${U}`)},`line-${I}-${U}`))},`block-${I}`)})}function $c({sessionId:i,conversation:h,inputValue:m,onInputChange:I,useMock:C,onUseMockChange:L,onSend:U,onClear:Z,busy:F,statusText:D,errorMessage:q,showCommentAction:O=!1,onCommentAssistantMessage:H,isAssistantMessageCommented:ue,canCommentAssistantMessage:Re}){const ee=x.useRef(null),re=x.useRef(!0),K=x.useRef(null),[ie,je]=x.useState("idle"),[ze,Te]=x.useState("чат");function Ie(se=!1){ee.current&&(se&&(re.current=!0),ee.current.scrollTop=ee.current.scrollHeight)}x.useEffect(()=>{re.current&&Ie()},[h]),x.useEffect(()=>()=>{K.current!==null&&window.clearTimeout(K.current)},[]);async function Le(se){if(h.length===0)return;const Fe=Df(i,h,se),Ke=await $f(Fe);Te(se==="technical"?"тех":"чат"),je(Ke?"success":"error"),K.current!==null&&window.clearTimeout(K.current),K.current=window.setTimeout(()=>{je("idle")},2200)}function We(){if(!ee.current)return;const se=ee.current,Fe=se.scrollHeight-se.scrollTop-se.clientHeight;re.current=Fe<16}return o.jsx(Mn,{className:"assistant-panel-frame",title:"Режим ассистента",children:o.jsxs("div",{className:"assistant-live-shell",children:[o.jsxs("div",{className:"assistant-toolbar",children:[o.jsxs("div",{className:"assistant-toolbar-actions",children:[o.jsx("button",{type:"button",className:"assistant-copy-btn",onClick:()=>{Le("default")},disabled:h.length===0,title:"Экспорт только user-facing чата",children:"Скопировать чат"}),o.jsx("button",{type:"button",className:"assistant-copy-btn",onClick:()=>{Le("technical")},disabled:h.length===0,title:"Технический экспорт с debug payload",children:"Скопировать техчат"}),o.jsx("button",{type:"button",className:"assistant-copy-btn",onClick:()=>Z(),disabled:F&&h.length===0,children:"Сбросить сессию"})]}),o.jsxs("div",{className:"assistant-toolbar-meta",children:[i?o.jsx("span",{className:"status-chip",children:`session: ${i}`}):null,o.jsxs("div",{className:"assistant-toolbar-meta-right",children:[D?o.jsx("span",{className:"assistant-live-status",children:D}):null,ie==="success"?o.jsxs("span",{className:"assistant-copy-feedback success",children:["Скопировано (",ze,")"]}):null,ie==="error"?o.jsx("span",{className:"assistant-copy-feedback error",children:"Ошибка копирования"}):null]})]}),q?o.jsx("p",{className:"error-text assistant-toolbar-error",children:q}):null]}),o.jsx("div",{ref:ee,className:"assistant-chat-list",onScroll:We,children:h.map((se,Fe)=>{const Ke=se.role==="assistant"&&O&&typeof H=="function"&&(typeof Re=="function"?Re(se,Fe):!0),lt=se.role==="assistant"&&typeof ue=="function"?ue(se,Fe):!1;return o.jsxs("article",{className:`assistant-msg ${se.role}`,children:[o.jsxs("header",{className:"assistant-msg-head",children:[o.jsxs("div",{className:"assistant-msg-head-main",children:[o.jsx("strong",{children:Of(se.role)}),o.jsx("span",{children:zf(se.created_at)})]}),se.role==="assistant"&&O?o.jsx("div",{className:"assistant-msg-head-actions",children:o.jsx("button",{type:"button",className:lt?"autoruns-comment-icon assistant-comment-btn commented":"autoruns-comment-icon assistant-comment-btn",onClick:()=>H?.(se,Fe),disabled:!Ke,title:Ke?"Комментировать ответ ассистента":"Комментарий недоступен для этого сообщения","aria-label":Ke?"Комментировать ответ ассистента":"Комментарий недоступен для этого сообщения",children:o.jsx(Ff,{commented:lt})})}):null]}),o.jsx("div",{className:"assistant-msg-body",children:Vf(se.text)}),se.role==="assistant"&&se.debug?o.jsxs("details",{className:"assistant-debug",children:[o.jsx("summary",{children:"Показать технический разбор"}),o.jsx(Wt,{value:se.debug})]}):null]},se.message_id)})}),o.jsxs("div",{className:"assistant-compose",children:[o.jsxs("label",{className:"full-width",children:["Сообщение",o.jsx("textarea",{className:"assistant-input-textarea",value:m,onChange:se=>I(se.target.value),rows:4,placeholder:"Введите вопрос к данным компании..."})]}),o.jsxs("div",{className:"button-row assistant-send-row",children:[o.jsxs("label",{className:"checkbox-row",children:[o.jsx("input",{type:"checkbox",checked:C,onChange:se=>L(se.target.checked)}),"Mock-режим"]}),o.jsx("button",{type:"button",className:"assistant-send-btn",onClick:()=>{Ie(!0),U()},disabled:F||!m.trim(),children:F?"Выполняю...":"Отправить"})]})]})]})})}const Bi={fromLocal:"",toLocal:"",target:"all",mode:"all",useMock:"any",promptContains:"",limit:120},rl="needs_dialog_policy_fix",ht="__all__",il="__live__:",wc="ndc_autoruns_ui_config_v1",jc="ndc-autoruns-save",bi=["Анализ запроса","Получение данных","Подготовка ответа"],Gi=[{id:"general",label:"Общий контур",domain:"",defaultPrompt:"Генерируй реалистичные живые вопросы бухгалтера по 1С. Добавляй разговорные формулировки и опечатки, но сохраняй бизнес-смысл."}];function Qf(i=Gi){return i.reduce((h,m)=>(h[m.id]=m.defaultPrompt,h),{})}const kc={mode:"codex_creative",count:24,personalityId:"general",personalityPrompts:Qf(),persistToEvalCases:!0,generatedBy:"manual_reviewer"};function Hi(i){const h=String(i??"").trim();return/^\d{4}-\d{2}-\d{2}$/.test(h)?h:""}function Cc(i){const h=typeof i=="number"&&Number.isFinite(i)?Math.trunc(i):160;return Math.max(110,Math.min(520,h))}function Wf(i){const h=i.getFullYear(),m=String(i.getMonth()+1).padStart(2,"0"),I=String(i.getDate()).padStart(2,"0"),C=String(i.getHours()).padStart(2,"0"),L=String(i.getMinutes()).padStart(2,"0");return`${h}-${m}-${I}T${C}:${L}`}function Nc(){const i=new Date;return i.setDate(i.getDate()-14),Wf(i)}function sl(i){if(!i.trim())return;const h=Date.parse(i);if(Number.isFinite(h))return new Date(h).toISOString()}function tr(i){if(!i)return"нет данных";const h=Date.parse(i);return Number.isFinite(h)?new Date(h).toLocaleString("ru-RU"):i}function Kf(i,h){return h<=0?0:Math.max(0,Math.min(100,Number((i/h*100).toFixed(1))))}function ol(i){return typeof i!="number"?"нет данных":`${i.toFixed(1)}%`}function qf(i){return i==="assistant_stage1"?"assistant/s1":i==="assistant_stage2"?"assistant/s2":i==="assistant_p0"?"assistant/p0":i}function Ec(i){return i==="up"?"Рост":i==="down"?"Регресс":"Без изменений"}function Gf(i,h){return i.find(m=>m.case_id===h)??null}function Vi(i){const h=Math.max(1,Math.min(5,Math.round(i)));return`${"●".repeat(h)}${"○".repeat(5-h)}`}function Pc(i){return i.length===0?o.jsx("p",{className:"muted",children:"Покрытие доменов пока не сформировано."}):o.jsx("div",{className:"autoruns-coverage-list",children:i.map(h=>{const m=Kf(h.closed_cases,h.total_cases);return o.jsxs("div",{className:"autoruns-coverage-item",children:[o.jsxs("div",{className:"autoruns-coverage-head",children:[o.jsx("strong",{children:h.domain}),o.jsxs("span",{children:[h.closed_cases,"/",h.total_cases," (",m,"%)"]})]}),o.jsx("div",{className:"autoruns-coverage-bar",children:o.jsx("div",{style:{width:`${m}%`}})})]},h.domain)})})}function ll(i){return`${il}${i}`}function xs(i){return i.startsWith(il)}function Mc(i){return i.startsWith(il)?i.slice(il.length):""}function Fc(i){const h=i.report_summary?.run_timestamp??i.created_at,m=Math.max(0,i.total_cases-i.completed_cases);return{run_id:ll(i.job_id),eval_target:i.eval_target,run_timestamp:h,mode:"single-pass-strict",llm_provider:null,model:null,use_mock:null,analysis_date:i.report_summary?.analysis_date??i.analysis_date??null,prompt_version:null,schema_version:null,suite_id:i.case_set_file,cases_total:i.total_cases,requests_total:null,report_path:`async_job:${i.job_id}`,score_index:i.report_summary?.score_index??null,blocking_failures:0,quality_failures:0,closed_cases:i.completed_cases,open_cases:m,domain_coverage:[{domain:"runtime",total_cases:i.total_cases,closed_cases:i.completed_cases}]}}function Zs(i,h){const m=Fc(i),I=i.cases.map(q=>({case_id:q.case_id,domain:null,query_class:null,status:q.status==="completed"?"closed":q.status==="failed"?"open":"unknown",score_index:null,trace_id:null,reply_type:null,session_id:`${i.run_id}-${q.case_id}`,dialog_available:q.messages.length>0,commented_count:0,latest_annotation_at:null,avg_rating:null,checks:null,metric_subscores:null})),L=h!==ht&&I.some(q=>q.case_id===h)?h:I.length>0?ht:"",U={ok:!0,run:m,coverage:{closed_cases:i.completed_cases,open_cases:Math.max(0,i.total_cases-i.completed_cases),domain_coverage:[{domain:"runtime",total_cases:i.total_cases,closed_cases:i.completed_cases}]},cases:I,annotations_summary:{total:0},report:i.report_summary?{run_id:i.report_summary.run_id,run_timestamp:i.report_summary.run_timestamp,score_index:i.report_summary.score_index,cases_total:i.report_summary.cases_total,analysis_date:i.report_summary.analysis_date??i.analysis_date??null}:{}},Z=[];let F=0;if(L===ht)for(const q of i.cases)for(let O=0;OO.case_id===L)??null;for(let O=0;O<(q?.messages.length??0);O+=1){const H=q?.messages[O];H&&Z.push({...H,message_index:O,case_id:L,case_message_index:O,commented:!1,annotation:null})}}const D={ok:!0,run_id:m.run_id,case_id:L,source:"assistant_session",session_id:L===ht?`${i.run_id}::__all__`:`${i.run_id}-${L}`,messages:Z,decomposition:[],assistant_mode:{status:i.status,completed_cases:i.completed_cases,total_cases:i.total_cases},annotations:[]};return{detail:U,dialog:D,caseId:L}}function Jf({commented:i}){const h=i?"comment-icon-svg commented":"comment-icon-svg";return o.jsx("svg",{className:h,viewBox:"0 0 24 24","aria-hidden":"true",focusable:"false",children:o.jsx("path",{d:"M5 6.5h14v9H11.5l-4.5 3v-3H5z"})})}function Rc({resolved:i}){return o.jsxs("svg",{className:i?"resolve-icon-svg resolved":"resolve-icon-svg",viewBox:"0 0 16 16","aria-hidden":"true",focusable:"false",children:[o.jsx("circle",{cx:"8",cy:"8",r:"6.2"}),i?o.jsx("path",{d:"M5.1 8.2 7.2 10.3 11 6.5"}):null]})}function Yf(){return o.jsxs("svg",{className:"autoruns-copy-icon-svg",viewBox:"0 0 24 24","aria-hidden":"true",focusable:"false",children:[o.jsx("rect",{x:"9",y:"9",width:"11",height:"11",rx:"2.2"}),o.jsx("path",{d:"M15 7V5.8a1.8 1.8 0 0 0-1.8-1.8H5.8A1.8 1.8 0 0 0 4 5.8v7.4A1.8 1.8 0 0 0 5.8 15H7"})]})}function Xf({connection:i,prompts:h,assistantPromptVersion:m,decompositionPromptVersion:I,showAssistantMode:C,showDecompositionMode:L,showProgressMode:U,showCommentsMode:Z,onLog:F}){const[D,q]=x.useState({...Bi,fromLocal:Nc()}),[O,H]=x.useState(""),[ue,Re]=x.useState(null),[ee,re]=x.useState(null),[K,ie]=x.useState(null),[je,ze]=x.useState([]),[Te,Ie]=x.useState("all"),[Le,We]=x.useState(!1),[se,Fe]=x.useState(null),[Ke,lt]=x.useState([]),[Ye,nt]=x.useState(""),[ve,Me]=x.useState(""),[pe,A]=x.useState(""),[Q,z]=x.useState(Gi),[p,k]=x.useState(kc),[G,ce]=x.useState([]),[de,fe]=x.useState(""),[ye,ge]=x.useState([]),[te,Ce]=x.useState(null),[Dt,bn]=x.useState(null),[Rn,Tn]=x.useState(!1),[rr,Kt]=x.useState(!1),[qt,Hn]=x.useState(!1),[fn,Ot]=x.useState(!1),[Gt,mn]=x.useState(!1),[sr,An]=x.useState(!1),[or,In]=x.useState(!1),[Jt,Yt]=x.useState(!1),[lr,zt]=x.useState(""),[pn,Ue]=x.useState(""),[it,hn]=x.useState(""),[gn,Xt]=x.useState([]),[Zt,kt]=x.useState([]),[Ln,en]=x.useState(""),[$t,Ft]=x.useState(!1),[Mr,He]=x.useState(!1),[ir,Ct]=x.useState(""),[ar,tn]=x.useState(""),[ur,gt]=x.useState(String(Bi.limit)),[cr,vt]=x.useState(String(kc.count)),[vn,yn]=x.useState(160),[ae,Ge]=x.useState({open:!1,caseId:"",caseMessageIndex:-1,messageIndex:-1,rating:3,comment:"",manualCaseDecision:rl,annotationAuthor:"manual_reviewer",saving:!1,error:""}),[me,yt]=x.useState({open:!1,messageIndex:-1,rating:3,comment:"",annotationAuthor:"manual_reviewer",saving:!1,error:""}),dr=x.useRef(!1),ke=x.useRef(null),Ve=x.useMemo(()=>Q.find(a=>a.id===p.personalityId)??Q[0]??Gi[0],[p.personalityId,Q]),xt=x.useMemo(()=>G.find(a=>a.generation_id===de)??G[0]??null,[G,de]),Dn=ee?Gf(ee.cases,pe):null,J=x.useMemo(()=>Le?je.filter(a=>!a.resolved):je,[je,Le]),Ee=J.find(a=>a.annotation_id===Ye)??null,On=K?.messages.find(a=>a.message_index===ae.messageIndex)??null,Rr=x.useMemo(()=>{if(!K||ae.messageIndex<0)return null;for(let a=ae.messageIndex-1;a>=0;a-=1){const c=K.messages[a];if(c?.role==="user")return c}return null},[ae.messageIndex,K]),nn=x.useMemo(()=>{const a=new Map;for(const c of Zt)c.message_id&&a.set(c.message_id,c);return a},[Zt]),Tr=me.messageIndex>=0?gn[me.messageIndex]??null:null,Kr=x.useMemo(()=>{if(me.messageIndex<0)return null;for(let a=me.messageIndex-1;a>=0;a-=1){const c=gn[a];if(c?.role==="user")return c}return null},[me.messageIndex,gn]),_e=x.useMemo(()=>{const a=J.map(y=>({source:"autorun",key:`autorun:${y.annotation_id}`,updated_at:y.updated_at,rating:y.rating,autorun:y,assistant:null})),c=Zt.map(y=>({source:"assistant_live",key:`assistant:${y.annotation_id}`,updated_at:y.updated_at,rating:y.rating,autorun:null,assistant:y}));return[...a,...c].sort((y,P)=>Date.parse(P.updated_at)-Date.parse(y.updated_at))},[Zt,J]),Ar=x.useMemo(()=>{if(_e.length===0)return null;const a=_e.reduce((c,y)=>c+y.rating,0)/_e.length;return Number(a.toFixed(2))},[_e]),Vn=x.useMemo(()=>{const a=[...ue?.items??[]];return te&&a.unshift(Fc(te)),ve&&!a.some(c=>c.run_id===ve)&&ee?.run&&a.unshift(ee.run),a},[te,ue?.items,ee?.run,ve]),oe=x.useCallback(a=>{F?.(`[autoruns] ${a}`)},[F]),rn=x.useCallback(async a=>{const c=String(a??"").trim();if(!c){kt([]);return}try{const y=await Ne.loadAssistantAnnotations({session_id:c,limit:400});kt(y.items??[])}catch(y){const P=y instanceof Error?y.message:String(y);oe(`Assistant live annotations load error: ${P}`)}},[oe]),xn=x.useCallback(a=>{yt(c=>c.saving&&!a?.force?c:{open:!1,messageIndex:-1,rating:3,comment:"",annotationAuthor:"manual_reviewer",saving:!1,error:""})},[]),fr=x.useCallback(async(a,c)=>{a.stopPropagation(),a.preventDefault();const y=String(c??"").trim();if(y)try{if(navigator?.clipboard?.writeText)await navigator.clipboard.writeText(y);else{const P=document.createElement("textarea");P.value=y,P.setAttribute("readonly","true"),P.style.position="fixed",P.style.opacity="0",document.body.appendChild(P),P.select(),document.execCommand("copy"),document.body.removeChild(P)}oe(`run id copied: ${y}`)}catch(P){const le=P instanceof Error?P.message:String(P);Ue(`Копирование run id: ${le}`),oe(`copy run id error: ${le}`)}},[oe]);function mr(){let a=0;Ct(bi[0]);const c=window.setInterval(()=>{a=Math.min(a+1,bi.length-1),Ct(bi[a])},650);return()=>window.clearInterval(c)}const Nt=x.useCallback(()=>{hn(""),Xt([]),kt([]),en(""),Ct(""),tn(""),xn({force:!0}),oe("Live-чат ассистента в истории автопрогонов сброшен.")},[xn,oe]),_s=x.useCallback(async()=>{const a=Ln.trim();if(!a)return;He(!0),tn(""),en(""),Xt(y=>[...y,{message_id:`autoruns-live-${Date.now()}`,session_id:it||"pending",role:"user",text:a,reply_type:null,created_at:new Date().toISOString(),trace_id:null,debug:null}]);const c=mr();try{const y=await Ne.sendAssistantMessage({connection:i,prompts:h,userMessage:a,sessionId:it||void 0,promptVersion:m,useMock:$t});hn(y.session_id),Xt(y.conversation),await rn(y.session_id),Ct("Ответ готов"),oe(`Live-ответ ассистента получен: trace=${y.debug.trace_id}`)}catch(y){const P=y instanceof Error?y.message:String(y);tn(P),Ct("Ошибка ассистента"),oe(`Live-чат ассистента: ошибка отправки сообщения: ${P}`)}finally{c(),He(!1)}},[Ln,it,$t,m,i,rn,oe,h]),ct=x.useCallback(a=>{const c=a.trim();if(!c){gt(String(D.limit));return}if(!/^\d+$/.test(c)){gt(String(D.limit));return}const y=Number.parseInt(c,10);if(!Number.isFinite(y)){gt(String(D.limit));return}const P=Math.max(1,Math.min(500,y));P!==D.limit&&q(le=>({...le,limit:P})),gt(String(P))},[D.limit]),qr=x.useCallback(a=>{const c=a.trim();if(!c){vt(String(p.count));return}if(!/^\d+$/.test(c)){vt(String(p.count));return}const y=Number.parseInt(c,10);if(!Number.isFinite(y)){vt(String(p.count));return}const P=Math.max(1,Math.min(200,y));P!==p.count&&k(le=>({...le,count:P})),vt(String(P))},[p.count]),Gr=x.useCallback(a=>{yn(Cc(a))},[]),Ir=x.useCallback(a=>{const c=a.currentTarget.offsetHeight;Number.isFinite(c)&&c>0&&Gr(c)},[Gr]),Ut=x.useCallback(async()=>{Yt(!0);try{const a=await Ne.loadAutoRunAnnotations({limit:800,manual_case_decision:Te});ze(a.items),Fe(a.manual_case_decision_schema??null),lt(a.available_manual_case_decisions??[]),nt(c=>a.items.length===0?"":a.items.some(y=>y.annotation_id===c)?c:a.items[0].annotation_id)}catch(a){oe(`Annotations load error: ${a instanceof Error?a.message:String(a)}`)}finally{Yt(!1)}},[Te,oe]),_t=x.useCallback(async()=>{Ot(!0);try{const a=await Ne.loadAutoRunAutogenHistory({limit:180});ce(a.items)}catch(a){oe(`Autogen history load error: ${a instanceof Error?a.message:String(a)}`)}finally{Ot(!1)}},[oe]),sn=x.useCallback(async()=>{try{const c=(await Ne.loadAutoRunAutogenPersonalityCatalog()).items.map(y=>({id:String(y.id??"").trim(),label:String(y.label??"").trim(),domain:typeof y.domain=="string"?y.domain.trim():"",defaultPrompt:String(y.default_prompt??"").trim()})).filter(y=>y.id.length>0&&y.label.length>0);if(c.length===0)return;z(c.map(y=>({id:y.id,label:y.label,domain:y.domain||"",defaultPrompt:y.defaultPrompt||"Генерируй реалистичные вопросы бухгалтера по выбранному профилю. Не выдумывай непокрытые возможности."})))}catch(a){oe(`Autogen personality catalog load error: ${a instanceof Error?a.message:String(a)}`)}},[oe]),Xe=x.useCallback(async()=>{Hn(!0);try{const a=await Ne.loadAutoRunPostAnalysis({run_id:ve&&!xs(ve)?ve:void 0,limit_per_queue:30,annotation_limit:1500,from:sl(D.fromLocal),to:sl(D.toLocal),target:D.target,mode:D.mode,use_mock:D.useMock,prompt_contains:D.promptContains.trim()||void 0});bn(a)}catch(a){oe(`Post-analysis load error: ${a instanceof Error?a.message:String(a)}`),bn(null)}finally{Hn(!1)}},[D.fromLocal,D.mode,D.promptContains,D.target,D.toLocal,D.useMock,oe,ve]),Ss=x.useCallback(async()=>{Tn(!0),Ue("");try{const a=p.personalityPrompts[p.personalityId]??"",c=[h.systemPrompt,h.developerPrompt,h.domainPrompt,h.schemaNotes,h.fewShotExamples].join(` -`).slice(0,900),y=await Ne.generateAutoRunQuestions({mode:p.mode,count:p.count,domain:Ve.domain||void 0,persist_to_eval_cases:p.persistToEvalCases,generated_by:p.generatedBy.trim()||void 0,llm:{llm_provider:i.llmProvider,api_key:i.apiKey,model:i.model,base_url:i.baseUrl,temperature:i.temperature,max_output_tokens:i.maxOutputTokens},context:{llm_provider:i.llmProvider,model:i.model,assistant_prompt_version:m,decomposition_prompt_version:I,prompt_fingerprint:c,autogen_personality_id:Ve.id,autogen_personality_prompt:a.trim()||void 0}});oe(`Generated ${y.generation.count} questions (${y.generation.mode}) id=${y.generation.generation_id}`+(y.generation.saved_case_set_file?` saved=${y.generation.saved_case_set_file}`:"")),fe(y.generation.generation_id),ge([...y.generation.questions??[]]),await _t()}catch(a){const c=a instanceof Error?a.message:String(a);Ue(`Автогенерация: ${c}`),oe(`Autogen generate error: ${c}`)}finally{Tn(!1)}},[m,p.count,p.generatedBy,p.mode,p.personalityId,p.personalityPrompts,p.persistToEvalCases,i.apiKey,i.baseUrl,i.llmProvider,i.maxOutputTokens,i.model,i.temperature,I,_t,oe,h.developerPrompt,h.domainPrompt,h.fewShotExamples,h.schemaNotes,h.systemPrompt,Ve.domain,Ve.id]),Qn=x.useCallback(async(a,c)=>{if(xs(a)){const y=Mc(a);if(te&&te.job_id===y){const P=Zs(te,c);Me(a),A(P.caseId),ie(P.dialog);return}ie(null);return}In(!0);try{const y=await Ne.loadAutoRunCaseDialog(a,c);ie(y)}catch(y){const P=y instanceof Error?y.message:String(y);Ue(`Диалог кейса: ${P}`),ie(null),oe(`Dialog load error for ${a}/${c}: ${P}`)}finally{In(!1)}},[te,oe]),Et=x.useCallback(async(a,c)=>{if(xs(a)){const y=Mc(a);if(te&&te.job_id===y){const P=Zs(te,c??ht);Me(a),A(P.caseId),re(P.detail),ie(P.dialog);return}Me(a),A(""),re(null),ie(null);return}An(!0);try{const y=await Ne.loadAutoRunDetail(a);re(y);const P=(c&&(c===ht||y.cases.some(le=>le.case_id===c))?c:"")||(y.cases.length>0?ht:"")||"";Me(a),A(P),P?await Qn(a,P):ie(null)}catch(y){const P=y instanceof Error?y.message:String(y);Ue(`Детализация прогона: ${P}`),re(null),ie(null),oe(`Run detail load error for ${a}: ${P}`)}finally{An(!1)}},[te,Qn,oe]),zn=x.useCallback(async a=>{mn(!0),Ue("");try{const c=await Ne.loadAutoRunsHistory({from:sl(D.fromLocal),to:sl(D.toLocal),target:D.target,mode:D.mode,use_mock:D.useMock,prompt_contains:D.promptContains.trim()||void 0,limit:D.limit});if(Re(c),c.items.length===0){Me(""),A(""),re(null),ie(null);return}const y=a?.keepSelection??!0,P=a?.preferredRunId??"",le=a?.preferredCaseId??"",Ze=y&&P&&c.items.some(Bt=>Bt.run_id===P)?P:c.items[0].run_id;await Et(Ze,y?le:void 0),Xe()}catch(c){const y=c instanceof Error?c.message:String(c);Ue(`История прогонов: ${y}`),oe(`History load error: ${y}`)}finally{mn(!1)}},[D.fromLocal,D.limit,D.mode,D.promptContains,D.target,D.toLocal,D.useMock,Xe,Et,oe]),St=x.useCallback(()=>{ke.current!==null&&(window.clearTimeout(ke.current),ke.current=null)},[]),_n=x.useCallback(async a=>{try{const c=await Ne.loadEvalRunAsyncStatus(a);Ce(c.job);const y=ll(a);if(ve===y){const P=Zs(c.job,pe||ht);re(P.detail),ie(P.dialog),A(P.caseId)}if(c.job.status==="completed"){St(),Kt(!1);const P=c.job.report_summary?.run_id??c.job.run_id;await zn({keepSelection:!0,preferredRunId:P||ve,preferredCaseId:ht}),await _t(),Ce(null);return}if(c.job.status==="failed"){St(),Kt(!1),Ue(`Запуск прогонов: ${c.job.error??"неизвестная ошибка"}`),oe(`Autogen async run failed: ${c.job.error??"unknown error"}`);return}St(),ke.current=window.setTimeout(()=>{_n(a)},500)}catch(c){St(),Kt(!1);const y=c instanceof Error?c.message:String(c);Ue(`Запуск прогонов: ${y}`),oe(`Autogen async status error: ${y}`)}},[_t,zn,oe,pe,ve,St]),f=x.useCallback(async()=>{St(),Kt(!0),Ue("");try{const a=xt;if(!a)throw new Error("История автогенерации пуста. Сначала сгенерируйте пачку вопросов.");const c=ye.map(js=>js.trim()).filter(js=>js.length>0);if(c.length===0)throw new Error("Нет вопросов для запуска: список пустой после ручного редактирования.");const y=D.useMock==="true",P=Hi(O),Ze=(await Ne.startEvalRunAsync({connection:i,prompts:h,promptVersion:m,mode:"single-pass-strict",caseSetFile:a.saved_case_set_file??void 0,useMock:y,evalTarget:"assistant_stage1",questions:c,analysisDate:P||void 0})).job;Ce(Ze);const Bt=ll(Ze.job_id),Pt=Zs(Ze,ht);Me(Bt),A(Pt.caseId),re(Pt.detail),ie(Pt.dialog),oe(`Запущен async-прогон job=${Ze.job_id}, run_id=${Ze.run_id}, вопросов=${c.length}`+(a.saved_case_set_file?`, base_case_set=${a.saved_case_set_file}`:"")+(P?`, analysis_date=${P}`:", analysis_date=current_state")),_n(Ze.job_id)}catch(a){const c=a instanceof Error?a.message:String(a);Ue(`Запуск прогонов: ${c}`),oe(`Autogen run error: ${c}`),Kt(!1)}},[O,m,i,ye,D.useMock,oe,_n,h,xt,St]),M=x.useCallback(a=>{if(a.role!=="assistant")return;const c=a.case_id??pe,y=a.case_message_index??a.message_index;Ge({open:!0,caseId:c,caseMessageIndex:y,messageIndex:a.message_index,rating:a.annotation?.rating??3,comment:a.annotation?.comment??"",manualCaseDecision:a.annotation?.manual_case_decision??rl,annotationAuthor:a.annotation?.annotation_author??p.generatedBy,saving:!1,error:""})},[p.generatedBy,pe]),j=x.useCallback(a=>{Ge(c=>c.saving&&!a?.force?c:{open:!1,caseId:"",caseMessageIndex:-1,messageIndex:-1,rating:3,comment:"",manualCaseDecision:rl,annotationAuthor:p.generatedBy,saving:!1,error:""})},[p.generatedBy]),xe=x.useCallback(async()=>{const a=ve,c=ae.caseId,y=ae.caseMessageIndex;if(!(!a||!c||y<0)){if(xs(a)){Ge(P=>({...P,error:"Комментарий можно сохранить после завершения прогона."}));return}if(!ae.comment.trim()){Ge(P=>({...P,error:"Добавьте комментарий."}));return}Ge(P=>({...P,saving:!0,error:""}));try{await Ne.saveAutoRunAnnotation({run_id:a,case_id:c,message_index:y,rating:ae.rating,comment:ae.comment.trim(),manual_case_decision:ae.manualCaseDecision,annotation_author:ae.annotationAuthor.trim()||void 0}),j({force:!0}),Promise.all([Et(a,pe),Ut(),Xe()]).catch(P=>{const le=P instanceof Error?P.message:String(P);Ue(`Обновление после комментария: ${le}`),oe(`Comment refresh error: ${le}`)})}catch(P){Ge(le=>({...le,saving:!1,error:P instanceof Error?P.message:String(P)}))}}},[j,ae.annotationAuthor,ae.caseId,ae.caseMessageIndex,ae.comment,ae.manualCaseDecision,ae.rating,Ut,Xe,Et,oe,pe,ve]),Wn=x.useCallback(a=>a.role==="assistant",[]),Sn=x.useCallback(a=>a.role==="assistant"&&nn.has(a.message_id),[nn]),eo=x.useCallback((a,c)=>{if(a.role!=="assistant")return;const y=it.trim(),P=String(a.session_id??"").trim();if(!(y||P)){tn("Сначала получите ответ ассистента в активной сессии.");return}!y&&P&&hn(P);const Ze=nn.get(a.message_id)??null;tn(""),yt({open:!0,messageIndex:c,rating:Ze?.rating??3,comment:Ze?.comment??"",annotationAuthor:Ze?.annotation_author??"manual_reviewer",saving:!1,error:""})},[nn,it]),to=x.useCallback(async()=>{if(me.messageIndex<0)return;if(!me.comment.trim()){yt(y=>({...y,error:"Добавьте комментарий."}));return}const a=gn[me.messageIndex]??null,c=it.trim()||(a?.role==="assistant"?String(a.session_id??"").trim():"");if(!c){yt(y=>({...y,error:"Сессия ассистента не найдена."}));return}yt(y=>({...y,saving:!0,error:""}));try{const y=await Ne.saveAssistantAnnotation({session_id:c,message_index:me.messageIndex,rating:me.rating,comment:me.comment.trim(),annotation_author:me.annotationAuthor.trim()||void 0});kt(P=>{const le=[...P],Ze=le.findIndex(Bt=>Bt.annotation_id===y.annotation.annotation_id);return Ze>=0?le[Ze]=y.annotation:le.unshift(y.annotation),le.sort((Bt,Pt)=>Date.parse(Pt.updated_at)-Date.parse(Bt.updated_at))}),xn({force:!0})}catch(y){const P=y instanceof Error?y.message:String(y);yt(le=>({...le,saving:!1,error:P}))}},[me.annotationAuthor,me.comment,me.messageIndex,me.rating,gn,it,xn]),ws=x.useCallback(a=>{ze(c=>c.map(y=>y.annotation_id===a.annotation_id?{...y,...a}:y)),ie(c=>c&&{...c,annotations:c.annotations.map(y=>y.annotation_id===a.annotation_id?a:y),messages:c.messages.map(y=>!y.annotation||y.annotation.annotation_id!==a.annotation_id?y:{...y,commented:!0,annotation:a})})},[]),Jr=x.useCallback(async(a,c)=>{if(a.annotation_id){if(xs(a.run_id)){Ue("Статус выполнения можно менять только для завершённых прогонов.");return}zt(a.annotation_id);try{const y=await Ne.updateAutoRunAnnotation({annotation_id:a.annotation_id,resolved:c,resolved_by:p.generatedBy||void 0});ws(y.annotation),Xe()}catch(y){const P=y instanceof Error?y.message:String(y);Ue(`Смена статуса кейса: ${P}`),oe(`Annotation resolve toggle error: ${P}`)}finally{zt("")}}},[ws,p.generatedBy,Xe,oe]),Lr=x.useCallback(async a=>{nt(a.annotation_id),await Et(a.run_id,a.case_id),ue?.items.some(c=>c.run_id===a.run_id)||Ue("Комментарий относится к прогону вне текущего фильтра. Детали загружены напрямую.")},[ue?.items,Et]);x.useEffect(()=>{dr.current||(dr.current=!0,zn({keepSelection:!1}),_t(),sn(),Xe())},[_t,sn,zn,Xe]),x.useEffect(()=>{dr.current&&Ut()},[Te,Ut]),x.useEffect(()=>{nt(a=>J.length===0?"":J.some(c=>c.annotation_id===a)?a:J[0].annotation_id)},[J]),x.useEffect(()=>{fe(a=>G.length===0?"":a&&G.some(c=>c.generation_id===a)?a:G[0].generation_id)},[G]),x.useEffect(()=>{if(!xt){ge([]);return}ge([...xt.questions])},[xt?.generation_id]),x.useEffect(()=>{gt(String(D.limit))},[D.limit]),x.useEffect(()=>{vt(String(p.count))},[p.count]),x.useEffect(()=>{if(!it.trim()){kt([]);return}rn(it)},[it,rn]),x.useEffect(()=>{if(!te)return;const a=ll(te.job_id);if(ve!==a)return;const c=Zs(te,pe||ht);re(c.detail),ie(c.dialog),A(c.caseId)},[te,pe,ve]),x.useEffect(()=>()=>{St()},[St]),x.useEffect(()=>{Q.length!==0&&k(a=>{let c=!1;const y={...a.personalityPrompts};for(const le of Q)(typeof y[le.id]!="string"||y[le.id].trim().length===0)&&(y[le.id]=le.defaultPrompt,c=!0);let P=a.personalityId;return Q.some(le=>le.id===a.personalityId)||(P=Q[0].id,c=!0),c?{...a,personalityId:P,personalityPrompts:y}:a})},[Q]),x.useEffect(()=>{const a=localStorage.getItem(wc);if(a)try{const c=JSON.parse(a);if(c.filters){const y=c.filters;q(P=>({...P,...y,limit:typeof y.limit=="number"?Math.max(1,Math.min(500,y.limit)):P.limit}))}typeof c.analysisDate=="string"&&H(Hi(c.analysisDate)),typeof c.autogenPersonalityPromptHeight=="number"&&yn(Cc(c.autogenPersonalityPromptHeight)),c.autoGenSettings&&k(y=>{const P={...y.personalityPrompts},le=c.autoGenSettings?.personalityPrompts??{};for(const[Bt,Pt]of Object.entries(le))typeof Pt=="string"&&Bt.trim().length>0&&(P[Bt.trim()]=Pt);const Ze=typeof c.autoGenSettings?.personalityId=="string"&&c.autoGenSettings.personalityId.trim().length>0?c.autoGenSettings.personalityId.trim():y.personalityId;return{...y,mode:c.autoGenSettings?.mode==="codex_creative"||c.autoGenSettings?.mode==="qwen_seed"?c.autoGenSettings.mode:y.mode,count:typeof c.autoGenSettings?.count=="number"?Math.max(1,Math.min(200,c.autoGenSettings.count)):y.count,personalityId:Ze,personalityPrompts:P,persistToEvalCases:typeof c.autoGenSettings?.persistToEvalCases=="boolean"?c.autoGenSettings.persistToEvalCases:y.persistToEvalCases,generatedBy:typeof c.autoGenSettings?.generatedBy=="string"?c.autoGenSettings.generatedBy:y.generatedBy}}),(c.annotationDecisionFilter==="all"||typeof c.annotationDecisionFilter=="string"&&c.annotationDecisionFilter.length>0)&&Ie(c.annotationDecisionFilter),typeof c.hideResolvedAnnotations=="boolean"&&We(c.hideResolvedAnnotations)}catch{}},[]);const wn=x.useCallback(()=>{const a={filters:D,analysisDate:O,autogenPersonalityPromptHeight:vn,autoGenSettings:{mode:p.mode,count:p.count,personalityId:p.personalityId,personalityPrompts:p.personalityPrompts,persistToEvalCases:p.persistToEvalCases,generatedBy:p.generatedBy},annotationDecisionFilter:Te,hideResolvedAnnotations:Le};localStorage.setItem(wc,JSON.stringify(a))},[O,Te,p,vn,D,Le]);return x.useEffect(()=>{const a=()=>{wn(),oe("Сохранены настройки панели автопрогонов.")};return window.addEventListener(jc,a),()=>{window.removeEventListener(jc,a)}},[oe,wn]),o.jsxs(Mn,{className:"autoruns-frame",title:"",hideHeader:!0,children:[o.jsxs("div",{className:"autoruns-columns",children:[o.jsxs("section",{className:"autoruns-col",children:[o.jsx("div",{className:"autoruns-col-header",children:o.jsx("h3",{children:"Настройки"})}),o.jsx("h4",{children:"Настройки выборки"}),o.jsxs("div",{className:"autoruns-form-grid",children:[o.jsxs("label",{children:["Дата с",o.jsx("input",{type:"datetime-local",value:D.fromLocal,onChange:a=>q(c=>({...c,fromLocal:a.target.value}))})]}),o.jsxs("label",{children:["Дата по",o.jsx("input",{type:"datetime-local",value:D.toLocal,onChange:a=>q(c=>({...c,toLocal:a.target.value}))})]}),o.jsxs("label",{children:["Целевой контур",o.jsxs("select",{value:D.target,onChange:a=>q(c=>({...c,target:a.target.value})),children:[o.jsx("option",{value:"all",children:"все"}),(ue?.available.targets??[]).map(a=>o.jsx("option",{value:a,children:a},a))]})]}),o.jsxs("label",{children:["Режим",o.jsxs("select",{value:D.mode,onChange:a=>q(c=>({...c,mode:a.target.value})),children:[o.jsx("option",{value:"all",children:"все"}),(ue?.available.modes??[]).map(a=>o.jsx("option",{value:a,children:a},a))]})]}),o.jsxs("label",{children:["Использовать mock",o.jsxs("select",{value:D.useMock,onChange:a=>q(c=>({...c,useMock:a.target.value})),children:[o.jsx("option",{value:"any",children:"любой"}),o.jsx("option",{value:"true",children:"да"}),o.jsx("option",{value:"false",children:"нет"})]})]}),o.jsxs("label",{children:["Лимит",o.jsx("input",{type:"number",min:1,max:500,value:ur,onChange:a=>{const c=a.target.value;(c===""||/^\d+$/.test(c))&>(c)},onBlur:a=>ct(a.target.value),onKeyDown:a=>{a.key==="Enter"&&ct(a.target.value)}})]}),o.jsxs("label",{className:"full-width",children:["Версия промпта содержит",o.jsx("input",{value:D.promptContains,onChange:a=>q(c=>({...c,promptContains:a.target.value})),placeholder:"normalizer_v2_0_2 / address_query_runtime_v1",list:"autoruns-prompt-versions"})]})]}),o.jsx("datalist",{id:"autoruns-prompt-versions",children:(ue?.available.prompt_versions??[]).map(a=>o.jsx("option",{value:a},a))}),o.jsxs("div",{className:"button-row",children:[o.jsx("button",{type:"button",disabled:Gt,onClick:()=>{zn({keepSelection:!1})},children:Gt?"Обновляю...":"Применить"}),o.jsx("button",{type:"button",className:"tab",onClick:()=>{q({...Bi,fromLocal:Nc()}),Ue("")},children:"Сбросить фильтры"})]}),o.jsx("h4",{children:"Контур генерации"}),o.jsxs("div",{className:"autoruns-meta-list",children:[o.jsxs("div",{children:[o.jsx("span",{children:"Провайдер:"}),o.jsx("strong",{children:i.llmProvider})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Модель:"}),o.jsx("strong",{children:i.model||"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Промпт ассистента:"}),o.jsx("strong",{children:m})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Промпт декомпозиции:"}),o.jsx("strong",{children:I})]})]}),o.jsx("h4",{children:"Автогенерация вопросов"}),o.jsxs("div",{className:"autoruns-form-grid",children:[o.jsxs("label",{children:["Режим генерации",o.jsxs("select",{value:p.mode,onChange:a=>k(c=>({...c,mode:a.target.value})),children:[o.jsx("option",{value:"codex_creative",children:"codex_creative"}),o.jsx("option",{value:"qwen_seed",children:"qwen_seed"})]})]}),o.jsxs("label",{children:["Кол-во",o.jsx("input",{type:"number",min:1,max:200,value:cr,onChange:a=>{const c=a.target.value;(c===""||/^\d+$/.test(c))&&vt(c)},onBlur:a=>qr(a.target.value),onKeyDown:a=>{a.key==="Enter"&&qr(a.target.value)}})]}),o.jsxs("label",{children:["Личность автогенерации",o.jsx("select",{value:p.personalityId,onChange:a=>k(c=>({...c,personalityId:a.target.value})),children:Q.map(a=>o.jsx("option",{value:a.id,children:a.label},a.id))})]}),o.jsxs("label",{children:["Кто генерирует",o.jsx("input",{value:p.generatedBy,onChange:a=>k(c=>({...c,generatedBy:a.target.value})),placeholder:"manual_reviewer"})]}),o.jsxs("label",{className:"full-width",children:["Промпт личности",o.jsx("textarea",{className:"autoruns-personality-prompt",value:p.personalityPrompts[p.personalityId]??"",onChange:a=>k(c=>({...c,personalityPrompts:{...c.personalityPrompts,[c.personalityId]:a.target.value}})),placeholder:"Текст промпта для выбранной личности автогенерации",style:{height:`${vn}px`},onMouseUp:Ir,onTouchEnd:Ir})]}),o.jsxs("label",{className:"checkbox-row",children:[o.jsx("input",{type:"checkbox",checked:p.persistToEvalCases,onChange:a=>k(c=>({...c,persistToEvalCases:a.target.checked}))}),"Сохранять кейс-сет в `eval_cases`"]})]}),o.jsxs("div",{className:"autoruns-form-grid",children:[o.jsxs("label",{children:["Дата анализа (срез)",o.jsx("input",{type:"date",value:O,onChange:a=>H(Hi(a.target.value))})]}),o.jsx("div",{className:"button-row",children:o.jsx("button",{type:"button",className:"tab",disabled:!O,onClick:()=>H(""),children:"Сбросить дату среза"})})]}),o.jsxs("div",{className:"button-row",children:[o.jsx("button",{type:"button",disabled:Rn,onClick:()=>{Ss()},children:Rn?"Генерирую...":"Сгенерировать пачку"}),o.jsx("button",{type:"button",className:"tab",disabled:fn,onClick:()=>{_t()},children:fn?"Обновляю...":"Обновить историю"}),o.jsx("button",{type:"button",className:"autoruns-run-launch-btn",disabled:rr||ye.length===0,onClick:()=>{f()},children:rr?"Запускаю...":"Запустить прогоны"})]}),o.jsx("div",{className:"autoruns-form-grid",children:o.jsxs("label",{className:"full-width",children:["Кейс-сет для запуска",o.jsxs("select",{value:de,onChange:a=>fe(a.target.value),disabled:G.length===0,children:[G.length===0?o.jsx("option",{value:"",children:"нет генераций"}):null,G.map(a=>o.jsxs("option",{value:a.generation_id,children:[tr(a.created_at)," | ",a.mode," | ",a.count," | ",a.saved_case_set_file??"без файла"]},a.generation_id))]})]})}),o.jsxs("div",{className:"autoruns-generated-questions",children:[o.jsxs("div",{className:"autoruns-generated-questions-head",children:[o.jsxs("strong",{children:["Вопросы к запуску: ",ye.length]}),o.jsx("button",{type:"button",className:"tab",onClick:()=>ge([...xt?.questions??[]]),disabled:!xt,children:"Восстановить"})]}),ye.length===0?o.jsx("p",{className:"muted",children:"Список вопросов пуст. Сгенерируйте пачку или восстановите из выбранной генерации."}):o.jsx("div",{className:"autoruns-generated-questions-list",children:ye.map((a,c)=>o.jsxs("div",{className:"autoruns-generated-question-item",children:[o.jsxs("span",{children:[c+1,". ",a]}),o.jsx("button",{type:"button",className:"autoruns-remove-question-btn",onClick:()=>ge(y=>y.filter((P,le)=>le!==c)),title:"Удалить вопрос из запуска","aria-label":"Удалить вопрос из запуска",children:"+"})]},`${c}-${a.slice(0,24)}`))})]}),o.jsx("p",{className:"muted",children:"Запуск выполняет `assistant_stage1` eval по выбранному кейс-сету."}),o.jsxs("div",{className:"autoruns-autogen-list",children:[fn?o.jsx("p",{className:"muted",children:"Загружаю историю автогенераций..."}):null,!fn&&G.length===0?o.jsx("p",{className:"muted",children:"История автогенераций пока пустая."}):null,G.slice(0,30).map(a=>o.jsxs("article",{className:de===a.generation_id?"autoruns-autogen-item selected":"autoruns-autogen-item",onClick:()=>fe(a.generation_id),children:[o.jsxs("header",{children:[o.jsx("strong",{children:tr(a.created_at)}),o.jsx("span",{children:a.mode})]}),o.jsxs("div",{className:"autoruns-run-meta",children:["id=",a.generation_id," | count=",a.count]}),o.jsxs("div",{className:"autoruns-run-meta",children:["домен=",a.domain??"общий",a.generated_by?` | автор=${a.generated_by}`:""]}),a.saved_case_set_file?o.jsxs("div",{className:"autoruns-run-meta",children:["кейс-сет=",a.saved_case_set_file]}):null,(a.questions??[]).length>0?o.jsx("p",{children:a.questions[0]}):null]},a.generation_id))]}),o.jsxs("details",{className:"autoruns-prompt-details",children:[o.jsx("summary",{children:"Копия активного промпта (только чтение)"}),o.jsxs("label",{children:["Системный",o.jsx("textarea",{readOnly:!0,value:h.systemPrompt})]}),o.jsxs("label",{children:["Разработчика",o.jsx("textarea",{readOnly:!0,value:h.developerPrompt})]}),o.jsxs("label",{children:["Доменный",o.jsx("textarea",{readOnly:!0,value:h.domainPrompt})]}),o.jsxs("label",{children:["Заметки по схеме",o.jsx("textarea",{readOnly:!0,value:h.schemaNotes})]}),o.jsxs("label",{children:["Примеры few-shot",o.jsx("textarea",{readOnly:!0,value:h.fewShotExamples})]})]}),pn?o.jsx("p",{className:"error-text",children:pn}):null]}),o.jsxs("section",{className:"autoruns-col",children:[o.jsx("div",{className:"autoruns-col-header",children:o.jsx("h3",{children:"Выдача прогонов"})}),o.jsxs("div",{className:"autoruns-stats-grid",children:[o.jsxs("div",{children:[o.jsx("span",{children:"Всего"}),o.jsx("strong",{children:(ue?.stats.runs_total??0)+(te?1:0)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Средний score"}),o.jsx("strong",{children:ol(ue?.stats.avg_score_index??null)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Тренд"}),o.jsx("strong",{children:ue?Ec(ue.stats.trend):"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Блокеры"}),o.jsx("strong",{children:ue?.stats.blocking_runs??0})]})]}),o.jsxs("div",{className:"autoruns-run-list",children:[Vn.map(a=>o.jsxs("button",{type:"button",className:ve===a.run_id?"autoruns-run-item selected":"autoruns-run-item",onClick:()=>{Et(a.run_id)},children:[o.jsxs("div",{className:"autoruns-run-head",children:[o.jsx("strong",{children:tr(a.run_timestamp)}),o.jsx("span",{children:qf(a.eval_target)})]}),o.jsxs("div",{className:"autoruns-run-meta autoruns-run-id-row",children:[o.jsx("span",{children:a.run_id}),o.jsx("span",{role:"button",tabIndex:0,className:"autoruns-copy-run-id-btn",onClick:c=>{fr(c,a.run_id)},onKeyDown:c=>{(c.key==="Enter"||c.key===" ")&&(c.preventDefault(),fr(c,a.run_id))},title:"Скопировать run id","aria-label":`Скопировать run id ${a.run_id}`,children:o.jsx(Yf,{})})]}),o.jsxs("div",{className:"autoruns-run-meta",children:["режим=",a.mode??"нет данных"," | mock=",String(a.use_mock)]}),o.jsxs("div",{className:"autoruns-run-meta",children:["analysis_date=",a.analysis_date??"current_state"]}),a.llm_provider||a.model?o.jsxs("div",{className:"autoruns-run-meta",children:["llm=",a.llm_provider??"нет данных"," | модель=",a.model??"нет данных"]}):null,o.jsxs("div",{className:"autoruns-run-meta",children:["промпт=",a.prompt_version??"нет данных"]}),o.jsxs("div",{className:"autoruns-run-foot",children:[o.jsxs("span",{children:["оценка: ",ol(a.score_index)]}),o.jsxs("span",{children:["закрыто/открыто: ",a.closed_cases,"/",a.open_cases]})]}),o.jsxs("div",{className:"autoruns-run-foot",children:[o.jsxs("span",{children:["блокеры: ",a.blocking_failures]}),o.jsxs("span",{children:["качество: ",a.quality_failures]})]})]},a.run_id)),Vn.length===0?o.jsx("p",{className:"muted",children:"За выбранный диапазон прогонов нет."}):null]})]}),o.jsxs("section",{className:"autoruns-col",children:[o.jsxs("div",{className:"autoruns-col-header",children:[o.jsx("h3",{children:"Диалог прогона"}),o.jsxs("div",{className:"autoruns-dialog-toolbar",children:[o.jsxs("label",{children:["Прогон",o.jsx("select",{value:ve,onChange:a=>{const c=a.target.value;Et(c)},children:Vn.map(a=>o.jsxs("option",{value:a.run_id,children:[tr(a.run_timestamp)," | ",a.run_id]},a.run_id))})]}),o.jsxs("label",{children:["Кейс",o.jsxs("select",{value:pe,onChange:a=>{const c=a.target.value;A(c),ve&&c&&Qn(ve,c)},children:[(ee?.cases.length??0)>0?o.jsx("option",{value:ht,children:"ВСЕ кейсы подряд"}):null,(ee?.cases??[]).map(a=>o.jsxs("option",{value:a.case_id,children:[a.case_id," | ",a.status]},a.case_id))]})]})]})]}),o.jsxs("div",{className:"autoruns-case-list",children:[(ee?.cases.length??0)>0?o.jsxs("button",{type:"button",className:pe===ht?"autoruns-case-item selected":"autoruns-case-item",onClick:()=>{A(ht),ve&&Qn(ve,ht)},children:[o.jsx("span",{children:"ВСЕ кейсы подряд"}),o.jsx("span",{children:ee?.cases.length})]},ht):null,(ee?.cases??[]).map(a=>o.jsxs("button",{type:"button",className:pe===a.case_id?"autoruns-case-item selected":"autoruns-case-item",onClick:()=>{A(a.case_id),ve&&Qn(ve,a.case_id)},children:[o.jsx("span",{children:a.case_id}),o.jsxs("span",{children:[a.status,a.commented_count>0?` | комм=${a.commented_count}`:""]})]},a.case_id))]}),o.jsxs("div",{className:"autoruns-dialog-view",children:[or||sr?o.jsx("p",{className:"muted",children:"Загружаю диалог..."}):null,!or&&!sr&&(K?.messages.length??0)===0?o.jsx("p",{className:"muted",children:"Диалог для этого прогона не найден."}):null,(K?.messages??[]).map((a,c)=>{const y=a.role==="assistant"?"assistant":"user";return o.jsxs("article",{className:`autoruns-msg ${y}`,children:[o.jsxs("header",{children:[o.jsx("strong",{children:y==="assistant"?"Система":"Модель/вопрос"}),o.jsxs("div",{className:"autoruns-msg-head-actions",children:[a.case_id?o.jsx("span",{className:"autoruns-msg-case-tag",children:a.case_id}):null,o.jsx("span",{children:a.created_at?tr(a.created_at):"нет данных"}),y==="assistant"&&!xs(ve)?o.jsxs(o.Fragment,{children:[o.jsx("button",{type:"button",className:a.commented?"autoruns-comment-icon commented":"autoruns-comment-icon",onClick:()=>M(a),title:"\\u041a\\u043e\\u043c\\u043c\\u0435\\u043d\\u0442\\u0438\\u0440\\u043e\\u0432\\u0430\\u0442\\u044c \\u043e\\u0442\\u0432\\u0435\\u0442 \\u0441\\u0438\\u0441\\u0442\\u0435\\u043c\\u044b","aria-label":"\\u041a\\u043e\\u043c\\u043c\\u0435\\u043d\\u0442\\u0438\\u0440\\u043e\\u0432\\u0430\\u0442\\u044c \\u043e\\u0442\\u0432\\u0435\\u0442 \\u0441\\u0438\\u0441\\u0442\\u0435\\u043c\\u044b",children:o.jsx(Jf,{commented:a.commented})}),a.annotation?o.jsx("button",{type:"button",className:a.annotation.resolved?"autoruns-resolve-toggle resolved":"autoruns-resolve-toggle",onClick:()=>{Jr(a.annotation,!a.annotation.resolved)},disabled:lr===a.annotation.annotation_id,title:a.annotation.resolved?"Отметить кейс как невыполненный":"Отметить кейс как выполненный","aria-label":a.annotation.resolved?"Отметить кейс как невыполненный":"Отметить кейс как выполненный",children:o.jsx(Rc,{resolved:a.annotation.resolved})}):null]}):null]})]}),o.jsx("p",{children:a.text}),y==="assistant"&&a.annotation?o.jsxs("div",{className:"autoruns-msg-annotation",children:[o.jsx("strong",{children:Vi(a.annotation.rating)}),o.jsx("span",{children:a.annotation.comment}),o.jsxs("span",{className:"muted",children:[a.annotation.manual_case_decision,a.annotation.annotation_author?` | ${a.annotation.annotation_author}`:""]})]}):null,(a.trace_id||a.reply_type)&&o.jsxs("footer",{children:[a.trace_id?o.jsxs("span",{children:["trace=",a.trace_id]}):null,a.reply_type?o.jsxs("span",{children:["reply_type=",a.reply_type]}):null]})]},a.message_id??`${y}-${c}`)})]})]}),C?o.jsx("div",{className:"autoruns-col autoruns-assistant-live-col",children:o.jsx($c,{sessionId:it,conversation:gn,inputValue:Ln,onInputChange:en,useMock:$t,onUseMockChange:Ft,onSend:_s,onClear:Nt,busy:Mr,statusText:ir,errorMessage:ar,showCommentAction:!0,onCommentAssistantMessage:eo,isAssistantMessageCommented:Sn,canCommentAssistantMessage:Wn})}):null,L?o.jsxs("section",{className:"autoruns-col",children:[o.jsx("div",{className:"autoruns-col-header",children:o.jsx("h3",{children:"Режим декомпозиции"})}),o.jsxs("div",{className:"autoruns-meta-list",children:[o.jsxs("div",{children:[o.jsx("span",{children:"кейс:"}),o.jsx("strong",{children:Dn?.case_id??"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"домен:"}),o.jsx("strong",{children:Dn?.domain??"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"класс запроса:"}),o.jsx("strong",{children:Dn?.query_class??"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"trace:"}),o.jsx("strong",{children:Dn?.trace_id??"нет данных"})]})]}),o.jsx("h4",{children:"Шаги декомпозиции"}),(K?.decomposition.length??0)>0?o.jsx("ol",{className:"autoruns-decomposition-list",children:(K?.decomposition??[]).map((a,c)=>o.jsx("li",{children:a},`${c}-${a.slice(0,24)}`))}):o.jsx("p",{className:"muted",children:"В логах кейса нет явной декомпозиции."})]}):null,U?o.jsxs("section",{className:"autoruns-col",children:[o.jsx("div",{className:"autoruns-col-header",children:o.jsx("h3",{children:"Прогресс / регресс"})}),o.jsxs("div",{className:"autoruns-stats-grid",children:[o.jsxs("div",{children:[o.jsx("span",{children:"Последний score"}),o.jsx("strong",{children:ol(ue?.stats.latest_score_index??null)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Предыдущий"}),o.jsx("strong",{children:ol(ue?.stats.previous_score_index??null)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Тренд"}),o.jsx("strong",{children:ue?Ec(ue.stats.trend):"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Пробелы качества"}),o.jsx("strong",{children:ue?.stats.quality_gap_runs??0})]})]}),o.jsx("h4",{children:"Покрытие доменов (история)"}),Pc(ue?.stats.domain_coverage??[]),o.jsx("h4",{style:{marginTop:14},children:"Покрытие доменов (выбранный прогон)"}),Pc(ee?.coverage.domain_coverage??[]),o.jsx("h4",{style:{marginTop:14},children:"Очереди фиксов пост-анализа"}),qt?o.jsx("p",{className:"muted",children:"Собираю пост-анализ..."}):null,qt?null:o.jsx("div",{className:"autoruns-stats-grid",children:Object.entries(Dt?.post_analysis.stats.by_queue??{}).map(([a,c])=>o.jsxs("div",{children:[o.jsx("span",{children:a}),o.jsx("strong",{children:c})]},a))}),o.jsxs("div",{className:"autoruns-autogen-list",children:[(Dt?.post_analysis.recommended_regression_candidates??[]).slice(0,12).map(a=>o.jsxs("article",{className:"autoruns-autogen-item",children:[o.jsxs("header",{children:[o.jsx("strong",{children:a.manual_case_decision}),o.jsxs("span",{children:[a.rating,"/5"]})]}),o.jsxs("div",{className:"autoruns-run-meta",children:[a.domain??"неизвестно"," / ",a.query_class??"неизвестно"]}),o.jsx("p",{children:a.comment})]},a.annotation_id)),!qt&&(Dt?.post_analysis.recommended_regression_candidates.length??0)===0?o.jsx("p",{className:"muted",children:"Рекомендованных кандидатов пока нет."}):null]})]}):null,Z?o.jsxs("section",{className:"autoruns-col",children:[o.jsx("div",{className:"autoruns-col-header",children:o.jsx("h3",{children:"Комментарии"})}),o.jsx("h4",{children:"Размеченные ответы"}),o.jsxs("div",{className:"autoruns-comment-filter-row",children:[o.jsxs("label",{children:["Фильтр решений",o.jsxs("select",{value:Te,onChange:a=>Ie(a.target.value),children:[o.jsx("option",{value:"all",children:"все"}),(Ke.length>0?Ke:se?.enum??[]).map(a=>o.jsx("option",{value:a,children:String(se?.labels?.[a]??a)},a))]})]}),o.jsx("button",{type:"button",className:"tab autoruns-resolved-filter-toggle",onClick:()=>We(a=>!a),children:Le?"Показать выполненные":"Скрыть выполненные"})]}),o.jsxs("div",{className:"autoruns-stats-grid",children:[o.jsxs("div",{children:[o.jsx("span",{children:"Комментариев"}),o.jsx("strong",{children:_e.length})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Средний рейтинг"}),o.jsx("strong",{children:Ar===null?"нет данных":`${Ar.toFixed(2)} / 5`})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Последний"}),o.jsx("strong",{children:_e.length>0?tr(_e[0].updated_at):"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"Статус"}),o.jsx("strong",{children:Jt?"обновляю":"готово"})]})]}),o.jsxs("div",{className:"button-row",children:[o.jsx("button",{type:"button",disabled:Jt,onClick:()=>{Ut()},children:Jt?"Обновляю...":"Обновить список"}),o.jsx("button",{type:"button",className:"tab",disabled:qt,onClick:()=>{Xe()},children:qt?"Идет пост-анализ...":"Обновить пост-анализ"})]}),o.jsxs("div",{className:"autoruns-comments-list",children:[Jt?o.jsx("p",{className:"muted",children:"Загружаю комментарии..."}):null,!Jt&&_e.length===0?o.jsx("p",{className:"muted",children:je.length===0&&Zt.length===0?"Пока нет откомментированных ответов.":"Нет открытых кейсов по текущему фильтру."}):null,_e.map(a=>{if(a.source==="assistant_live"){const y=a.assistant;return o.jsxs("article",{className:"autoruns-comment-item",children:[o.jsxs("div",{className:"autoruns-comment-head",children:[o.jsx("strong",{children:Vi(y.rating)}),o.jsx("div",{className:"autoruns-comment-head-actions",children:o.jsx("span",{children:tr(y.updated_at)})})]}),o.jsxs("div",{className:"autoruns-run-meta",children:["live-session: ",y.session_id]}),o.jsxs("div",{className:"autoruns-run-meta",children:["msg=",y.message_index]}),o.jsxs("div",{className:"autoruns-run-meta",children:["source=assistant_live",y.annotation_author?` | author=${y.annotation_author}`:""]}),y.context.question_text?o.jsxs("p",{children:["Q: ",y.context.question_text]}):null,y.context.answer_text?o.jsxs("p",{children:["A: ",y.context.answer_text]}):null,o.jsx("p",{children:y.comment})]},a.key)}const c=a.autorun;return o.jsxs("article",{className:Ye===c.annotation_id?"autoruns-comment-item selected":"autoruns-comment-item",onClick:()=>{Lr(c)},role:"button",tabIndex:0,onKeyDown:y=>{(y.key==="Enter"||y.key===" ")&&(y.preventDefault(),Lr(c))},children:[o.jsxs("div",{className:"autoruns-comment-head",children:[o.jsx("strong",{children:Vi(c.rating)}),o.jsxs("div",{className:"autoruns-comment-head-actions",children:[o.jsx("span",{children:tr(c.updated_at)}),o.jsx("button",{type:"button",className:c.resolved?"autoruns-resolve-toggle resolved":"autoruns-resolve-toggle",onClick:y=>{y.preventDefault(),y.stopPropagation(),Jr(c,!c.resolved)},disabled:lr===c.annotation_id,title:c.resolved?"Отметить кейс как невыполненный":"Отметить кейс как выполненный","aria-label":c.resolved?"Отметить кейс как невыполненный":"Отметить кейс как выполненный",children:o.jsx(Rc,{resolved:c.resolved})})]})]}),o.jsx("div",{className:"autoruns-run-meta",children:c.run_id}),o.jsxs("div",{className:"autoruns-run-meta",children:["case=",c.case_id," | msg=",c.message_index]}),o.jsxs("div",{className:"autoruns-run-meta",children:["decision=",c.manual_case_decision,c.annotation_author?` | author=${c.annotation_author}`:""]}),c.resolved_at?o.jsxs("div",{className:"autoruns-run-meta",children:["выполнено",": ",tr(c.resolved_at),c.resolved_by?` | by=${c.resolved_by}`:""]}):null,c.context.question_text?o.jsxs("p",{children:["Q: ",c.context.question_text]}):null,c.context.answer_text?o.jsxs("p",{children:["A: ",c.context.answer_text]}):null,o.jsx("p",{children:c.comment})]},a.key)})]}),Ee?o.jsxs(o.Fragment,{children:[o.jsx("h4",{children:"Тех-контекст брака"}),o.jsxs("div",{className:"autoruns-meta-list",children:[o.jsxs("div",{children:[o.jsx("span",{children:"trace:"}),o.jsx("strong",{children:Ee.technical_context.trace_id??"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"reply_type:"}),o.jsx("strong",{children:Ee.technical_context.reply_type??"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"domain:"}),o.jsx("strong",{children:Ee.technical_context.domain??"нет данных"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"query_class:"}),o.jsx("strong",{children:Ee.technical_context.query_class??"нет данных"})]})]}),o.jsx("h4",{children:"JSON разбор"}),o.jsx(Wt,{value:{annotation_id:Ee.annotation_id,run_id:Ee.run_id,case_id:Ee.case_id,message_index:Ee.message_index,rating:Ee.rating,comment:Ee.comment,manual_case_decision:Ee.manual_case_decision,annotation_author:Ee.annotation_author,resolved:Ee.resolved,resolved_at:Ee.resolved_at,resolved_by:Ee.resolved_by,context:Ee.context,technical_context:Ee.technical_context,case_summary:Ee.case_summary?{case_id:Ee.case_summary.case_id,domain:Ee.case_summary.domain,query_class:Ee.case_summary.query_class,checks:Ee.case_summary.checks,metric_subscores:Ee.case_summary.metric_subscores}:null}})]}):null]}):null]}),me.open?o.jsx("div",{className:"autoruns-comment-modal-backdrop",onClick:a=>{a.target===a.currentTarget&&xn()},children:o.jsxs("div",{className:"autoruns-comment-modal",children:[o.jsx("h3",{children:"Комментарий к ответу ассистента"}),o.jsx("p",{className:"muted",children:"Комментарий будет добавлен в общий список комментариев справа с меткой `assistant_live`."}),Kr?o.jsxs("details",{className:"autoruns-prompt-details",open:!0,children:[o.jsx("summary",{children:"Вопрос пользователя"}),o.jsx("p",{className:"autoruns-comment-quote",children:Kr.text})]}):null,Tr?o.jsxs("details",{className:"autoruns-prompt-details",open:!0,children:[o.jsx("summary",{children:"Ответ ассистента"}),o.jsx("p",{className:"autoruns-comment-quote",children:Tr.text})]}):null,o.jsx("div",{className:"autoruns-rating-row",role:"group","aria-label":"Рейтинг ответа ассистента",children:[1,2,3,4,5].map(a=>o.jsx("button",{type:"button",className:me.rating>=a?"autoruns-rating-dot active":"autoruns-rating-dot",onClick:()=>yt(c=>({...c,rating:a})),disabled:me.saving,"aria-label":`Оценка ${a}`,children:me.rating>=a?"●":"○"},a))}),o.jsx("div",{className:"autoruns-form-grid",children:o.jsxs("label",{children:["Автор комментария",o.jsx("input",{value:me.annotationAuthor,onChange:a=>yt(c=>({...c,annotationAuthor:a.target.value})),placeholder:"manual_reviewer",disabled:me.saving})]})}),o.jsxs("label",{children:["Комментарий",o.jsx("textarea",{value:me.comment,onChange:a=>yt(c=>({...c,comment:a.target.value})),placeholder:"Что именно не так в ответе и что нужно исправить.",rows:4,disabled:me.saving})]}),me.error?o.jsx("p",{className:"error-text",children:me.error}):null,o.jsxs("div",{className:"button-row",children:[o.jsx("button",{type:"button",onClick:()=>{to()},disabled:me.saving,children:me.saving?"Сохраняю...":"Готово"}),o.jsx("button",{type:"button",className:"tab",onClick:()=>xn(),disabled:me.saving,children:"Отмена"})]})]})}):null,ae.open?o.jsx("div",{className:"autoruns-comment-modal-backdrop",onClick:a=>{a.target===a.currentTarget&&j()},children:o.jsxs("div",{className:"autoruns-comment-modal",children:[o.jsx("h3",{children:"Комментарий к ответу системы"}),o.jsx("p",{className:"muted",children:"Оцените ответ по 5-балльной шкале и добавьте комментарий по браку."}),On?o.jsxs(o.Fragment,{children:[o.jsxs("details",{className:"autoruns-prompt-details",open:!0,children:[o.jsx("summary",{children:"Вопрос пользователя"}),o.jsx("p",{className:"autoruns-comment-quote",children:Rr?.text??"Вопрос в диалоге не найден."})]}),o.jsxs("details",{className:"autoruns-prompt-details",open:!0,children:[o.jsx("summary",{children:"Ответ системы"}),o.jsx("p",{className:"autoruns-comment-quote",children:On.text})]})]}):null,o.jsx("div",{className:"autoruns-rating-row",role:"group","aria-label":"Рейтинг ответа",children:[1,2,3,4,5].map(a=>o.jsx("button",{type:"button",className:ae.rating>=a?"autoruns-rating-dot active":"autoruns-rating-dot",onClick:()=>Ge(c=>({...c,rating:a})),disabled:ae.saving,"aria-label":`Оценка ${a}`,children:ae.rating>=a?"●":"○"},a))}),o.jsxs("div",{className:"autoruns-form-grid",children:[o.jsxs("label",{children:["Решение по кейсу",o.jsx("select",{value:ae.manualCaseDecision,onChange:a=>Ge(c=>({...c,manualCaseDecision:a.target.value})),disabled:ae.saving,children:(Ke.length>0?Ke:se?.enum??[rl]).map(a=>o.jsx("option",{value:a,children:String(se?.labels?.[a]??a)},a))})]}),o.jsxs("label",{children:["Автор комментария",o.jsx("input",{value:ae.annotationAuthor,onChange:a=>Ge(c=>({...c,annotationAuthor:a.target.value})),placeholder:"manual_reviewer",disabled:ae.saving})]})]}),o.jsxs("label",{children:["Комментарий",o.jsx("textarea",{value:ae.comment,onChange:a=>Ge(c=>({...c,comment:a.target.value})),placeholder:"Почему ответ бракованный, что именно пошло не так, какие технические детали проверить.",rows:4,disabled:ae.saving})]}),ae.error?o.jsx("p",{className:"error-text",children:ae.error}):null,o.jsxs("div",{className:"button-row",children:[o.jsx("button",{type:"button",onClick:()=>{xe()},disabled:ae.saving,children:ae.saving?"Сохраняю...":"Готово"}),o.jsx("button",{type:"button",className:"tab",onClick:()=>j(),disabled:ae.saving,children:"Отмена"})]})]})}):null]})}function Tc({value:i,modelOptions:h,modelsBusy:m,onChange:I,onReloadModels:C,onTestConnection:L,onSaveLocalConfig:U,lastStatus:Z,busy:F}){const D=i.llmProvider==="local",q=h.includes(i.model),[O,H]=x.useState(String(i.temperature)),[ue,Re]=x.useState(String(i.maxOutputTokens));x.useEffect(()=>{H(String(i.temperature))},[i.temperature]),x.useEffect(()=>{Re(String(i.maxOutputTokens))},[i.maxOutputTokens]);const ee=K=>{const ie=K.replace(",",".").trim();if(!ie){H(String(i.temperature));return}const je=Number(ie);if(!Number.isFinite(je)){H(String(i.temperature));return}I({...i,temperature:je}),H(String(je))},re=K=>{const ie=K.trim();if(!ie){Re(String(i.maxOutputTokens));return}const je=Number.parseInt(ie,10);if(!Number.isFinite(je)||je<=0){Re(String(i.maxOutputTokens));return}I({...i,maxOutputTokens:je}),Re(String(je))};return o.jsxs(Mn,{title:"LLM Connection",subtitle:"Switch between OpenAI cloud and local OpenAI-compatible server.",actions:o.jsx("span",{className:"status-chip",children:Z||"Status: not checked"}),children:[o.jsxs("div",{className:"grid-two",children:[o.jsxs("label",{children:["Provider",o.jsxs("select",{value:i.llmProvider,onChange:K=>{const ie=K.target.value==="local"?"local":"openai";I({...i,llmProvider:ie,baseUrl:ie==="local"?"http://127.0.0.1:1234/v1":"https://api.openai.com/v1"})},children:[o.jsx("option",{value:"openai",children:"OpenAI (token)"}),o.jsx("option",{value:"local",children:"Local (LM Studio / OpenAI-compatible)"})]})]}),o.jsxs("label",{children:["Model",o.jsxs("select",{value:q?i.model:"__manual__",onChange:K=>{const ie=K.target.value;ie!=="__manual__"&&I({...i,model:ie})},children:[o.jsx("option",{value:"__manual__",children:"Manual input"}),h.map(K=>o.jsx("option",{value:K,children:K},K))]})]}),o.jsxs("label",{children:["Model ID (manual)",o.jsx("input",{value:i.model,onChange:K=>I({...i,model:K.target.value}),placeholder:"qwen2.5-14b-instruct or lmstudio loaded model id"})]}),D?null:o.jsxs("label",{className:"full-width",children:["OpenAI API Key",o.jsx("input",{type:"password",value:i.apiKey,onChange:K=>I({...i,apiKey:K.target.value}),placeholder:"sk-..."})]}),o.jsxs("label",{className:D?"full-width":void 0,children:[D?"Local server base URL":"Base URL",o.jsx("input",{value:i.baseUrl,onChange:K=>I({...i,baseUrl:K.target.value}),placeholder:D?"http://127.0.0.1:1234/v1":"https://api.openai.com/v1"})]}),o.jsxs("label",{children:["Temperature",o.jsx("input",{type:"number",step:"0.1",value:O,onChange:K=>H(K.target.value),onBlur:K=>ee(K.target.value),onKeyDown:K=>{K.key==="Enter"&&ee(K.target.value)}})]}),o.jsxs("label",{children:["Max output tokens",o.jsx("input",{type:"number",value:ue,onChange:K=>Re(K.target.value),onBlur:K=>re(K.target.value),onKeyDown:K=>{K.key==="Enter"&&re(K.target.value)}})]})]}),o.jsxs("div",{className:"button-row",children:[o.jsx("button",{type:"button",onClick:()=>U(),children:"Save local config"}),o.jsx("button",{type:"button",onClick:()=>C(),disabled:F||m,children:m?"Loading models...":"Load model list"}),o.jsx("button",{type:"button",onClick:()=>L(),disabled:F,children:F?"Checking...":"Test connection"})]})]})}function Zf({items:i,onRefresh:h,onOpenTrace:m}){return o.jsx(Mn,{title:"История нормализаций",subtitle:"Короткий вопрос, confidence, route hint и статус валидации.",actions:o.jsx("button",{type:"button",onClick:()=>h(),children:"Обновить"}),children:o.jsxs("div",{className:"history-list",children:[i.length===0?o.jsx("p",{className:"muted",children:"История пока пустая."}):null,i.map(I=>o.jsxs("button",{type:"button",className:"history-item",onClick:()=>m(I.trace_id),children:[o.jsxs("div",{className:"history-row",children:[o.jsx("strong",{children:I.route_hint??"route: n/a"}),o.jsx("span",{children:I.validation_passed?"schema: ok":"schema: fail"})]}),o.jsx("p",{children:I.question_short}),o.jsxs("div",{className:"history-row",children:[o.jsx("span",{children:I.model}),o.jsx("span",{children:new Date(I.timestamp).toLocaleString("ru-RU")})]})]},I.trace_id))]})})}function nr(i){return i==null||i===""?"—":String(i)}function em({result:i}){return o.jsx(Mn,{title:"Runtime метрики",subtitle:"trace_id, токены, latency и статус валидации.",children:o.jsxs("div",{className:"metrics-grid",children:[o.jsxs("div",{children:[o.jsx("span",{children:"trace_id"}),o.jsx("strong",{children:nr(i?.trace_id)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"request_started_at"}),o.jsx("strong",{children:nr(i?new Date(Date.now()-i.latency_ms).toISOString():null)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"request_finished_at"}),o.jsx("strong",{children:nr(i?new Date().toISOString():null)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"latency_ms"}),o.jsx("strong",{children:nr(i?.latency_ms)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"input_tokens"}),o.jsx("strong",{children:nr(i?.usage?.input_tokens)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"output_tokens"}),o.jsx("strong",{children:nr(i?.usage?.output_tokens)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"total_tokens"}),o.jsx("strong",{children:nr(i?.usage?.total_tokens)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"validation_status"}),o.jsx("strong",{children:i?.validation?.passed?"passed":"failed"})]}),o.jsxs("div",{children:[o.jsx("span",{children:"prompt_version"}),o.jsx("strong",{children:nr(i?.prompt_version)})]}),o.jsxs("div",{children:[o.jsx("span",{children:"schema_version"}),o.jsx("strong",{children:nr(i?.schema_version)})]})]})})}const tm={normalized:"Normalized JSON",fragments:"Fragment View",scope:"Scope View",flags:"Flags View",route:"Route Simulation",raw:"Raw model output",validation:"Validation",logs:"Logs"};function nm(i){return i&&typeof i=="object"?i:null}function rm({tab:i,onTabChange:h,result:m,appLogs:I}){const C=["normalized","fragments","scope","flags","route","raw","validation","logs"],L=nm(m?.normalized),U=String(L?.schema_version??""),Z=U==="normalized_query_v2"||U==="normalized_query_v2_0_1"||U==="normalized_query_v2_0_2",F=Z?{fragments:L?.fragments??[],discarded_fragments:L?.discarded_fragments??[]}:{note:"Fragment View доступен для normalized_query_v2."},D=Z?{message_in_scope:L?.message_in_scope??null,scope_confidence:L?.scope_confidence??null,contains_multiple_tasks:L?.contains_multiple_tasks??null,global_notes:L?.global_notes??null}:{note:"Scope View доступен для normalized_query_v2."},q=Z?Array.isArray(L?.fragments)?(L?.fragments).map(O=>({fragment_id:O.fragment_id??null,domain_relevance:O.domain_relevance??null,candidate_labels:O.candidate_labels??[],execution_readiness:O.execution_readiness??null,clarification_reason:O.clarification_reason??null,soft_assumption_used:O.soft_assumption_used??[],route_status:O.route_status??null,no_route_reason:O.no_route_reason??null,flags:O.flags??{}})):[]:{note:"Flags View доступен для normalized_query_v2."};return o.jsxs(Mn,{title:"Выходные данные",subtitle:"Structured output и диагностические вкладки.",children:[o.jsx("div",{className:"tab-row",children:C.map(O=>o.jsx("button",{type:"button",className:i===O?"tab active":"tab",onClick:()=>h(O),children:tm[O]},O))}),i==="normalized"?o.jsx(Wt,{value:m?.normalized??{note:"Нет данных."}}):null,i==="fragments"?o.jsx(Wt,{value:F}):null,i==="scope"?o.jsx(Wt,{value:D}):null,i==="flags"?o.jsx(Wt,{value:q}):null,i==="route"?o.jsx(Wt,{value:m?.route_hint_summary??{note:"Нет данных."}}):null,i==="raw"?o.jsx(Wt,{value:m?.raw_model_output??{note:"Нет данных."}}):null,i==="validation"?o.jsx(Wt,{value:m?.validation??{note:"Нет данных."}}):null,i==="logs"?o.jsx(Wt,{value:I}):null]})}function Ac({value:i,onChange:h,presets:m,selectedPresetId:I,onSelectPreset:C,onLoadPreset:L,onSavePreset:U,onResetDefaults:Z,onDiffPrevious:F,presetName:D,onPresetNameChange:q,diffSummary:O}){return o.jsxs(Mn,{title:"Prompt Manager",subtitle:"Системный, developer и domain уровни управляются отдельно.",children:[o.jsxs("div",{className:"prompt-manager-grid",children:[o.jsxs("label",{children:["Системный prompt",o.jsx("textarea",{value:i.systemPrompt,onChange:H=>h({...i,systemPrompt:H.target.value}),rows:6})]}),o.jsxs("label",{children:["Developer / Instruction prompt",o.jsx("textarea",{value:i.developerPrompt,onChange:H=>h({...i,developerPrompt:H.target.value}),rows:6})]}),o.jsxs("label",{children:["Domain prompt",o.jsx("textarea",{value:i.domainPrompt,onChange:H=>h({...i,domainPrompt:H.target.value}),rows:6})]}),o.jsxs("label",{children:["Schema notes",o.jsx("textarea",{value:i.schemaNotes,onChange:H=>h({...i,schemaNotes:H.target.value}),rows:6})]}),o.jsxs("label",{className:"full-width",children:["Few-shot examples",o.jsx("textarea",{value:i.fewShotExamples,onChange:H=>h({...i,fewShotExamples:H.target.value}),rows:8})]})]}),o.jsxs("div",{className:"button-row",children:[o.jsxs("select",{value:I,onChange:H=>C(H.target.value),children:[o.jsx("option",{value:"",children:"Выберите preset..."}),m.map(H=>o.jsx("option",{value:H.id,children:H.name},H.id))]}),o.jsx("button",{type:"button",onClick:()=>L(),children:"Загрузить preset"}),o.jsx("input",{value:D,onChange:H=>q(H.target.value),placeholder:"Имя для сохранения"}),o.jsx("button",{type:"button",onClick:()=>U(),children:"Сохранить preset"}),o.jsx("button",{type:"button",onClick:()=>F(),children:"Diff с предыдущим"}),o.jsx("button",{type:"button",onClick:()=>Z(),children:"Сбросить к default"})]}),O?o.jsx("p",{className:"diff-summary",children:O}):null]})}function sm({value:i,onChange:h,onApplyBatchFormat:m,onNormalize:I,busy:C,useMock:L,onUseMockChange:U,errorMessage:Z}){return o.jsxs(Mn,{title:"Запрос пользователя",subtitle:"NDC semantic front-end: нормализуем, но не отвечаем за бухгалтерскую суть.",children:[o.jsxs("div",{className:"grid-two",children:[o.jsxs("label",{className:"full-width",children:["Raw user question",o.jsx("textarea",{value:i.userQuestion,onChange:F=>h({...i,userQuestion:F.target.value}),rows:6,placeholder:"Например: По каким покупателям у нас на конец июня висят отгрузки без оплаты..."})]}),o.jsxs("label",{className:"full-width",children:["Batch queries (`;` separator)",o.jsx("textarea",{value:i.batchQuestionsRaw,onChange:F=>h({...i,batchQuestionsRaw:F.target.value}),onBlur:()=>m(),rows:8,placeholder:"Вопрос 1; Вопрос 2; Вопрос 3"})]}),o.jsxs("label",{children:["Optional period context",o.jsx("input",{value:i.periodHint,onChange:F=>h({...i,periodHint:F.target.value})})]}),o.jsxs("label",{children:["Optional business context",o.jsx("input",{value:i.businessContext,onChange:F=>h({...i,businessContext:F.target.value})})]}),o.jsxs("label",{children:["Optional expected route (eval)",o.jsx("input",{value:i.expectedRoute,onChange:F=>h({...i,expectedRoute:F.target.value})})]})]}),o.jsxs("div",{className:"button-row",children:[o.jsxs("label",{className:"checkbox-row",children:[o.jsx("input",{type:"checkbox",checked:L,onChange:F=>U(F.target.checked)}),"Mock-режим (без вызова OpenAI)"]}),o.jsx("button",{type:"button",onClick:()=>m(),disabled:C||!i.batchQuestionsRaw.trim(),children:"Применить `;` в переносы"}),o.jsx("button",{type:"button",onClick:()=>I(!1),disabled:C||!i.userQuestion.trim(),children:C?"Нормализуем...":"Normalize"}),o.jsx("button",{type:"button",onClick:()=>I(!0),disabled:C||!i.userQuestion.trim(),children:C?"Сохраняем...":"Normalize + Save as test case"})]}),Z?o.jsx("p",{className:"error-text",children:Z}):null]})}function om({runs:i,selectedRunId:h,onSelectRun:m,onStartRun:I,onFinishRun:C,onRefreshRuns:L,onRunEval:U,onCopyEvalReport:Z,evalBusy:F,traceItems:D,evalReport:q}){return o.jsxs(Mn,{title:"NDC Run Monitor",subtitle:"Важно: кнопка Запустить run создает только run-сущность. Кнопка eval запускает batch-проверку normalizer v2.0.2.",children:[o.jsxs("div",{className:"button-row",children:[o.jsx("button",{type:"button",onClick:()=>I(),children:"Запустить run"}),o.jsx("button",{type:"button",onClick:()=>C(),disabled:!h,children:"Завершить выбранный run"}),o.jsx("button",{type:"button",onClick:()=>L(),children:"Обновить runs"}),o.jsx("button",{type:"button",onClick:()=>U(),disabled:F,children:F?"Идет eval v2.0.2...":"Запустить eval v2.0.2"})]}),o.jsxs("div",{className:"runtime-stack",children:[o.jsxs("div",{className:"runtime-runs",children:[i.map(O=>o.jsxs("button",{type:"button",className:h===O.runId?"history-item selected":"history-item",onClick:()=>m(O.runId),children:[o.jsxs("div",{className:"history-row",children:[o.jsx("strong",{children:O.status}),o.jsx("span",{children:O.runId})]}),o.jsxs("div",{className:"history-row",children:[o.jsx("span",{children:O.sessionId}),o.jsx("span",{children:new Date(O.updatedAt).toLocaleString("ru-RU")})]})]},O.runId)),i.length===0?o.jsx("p",{className:"muted",children:"Нет активных запусков."}):null]}),o.jsxs("div",{className:"runtime-details",children:[o.jsx("h3",{children:"Trace выбранного run"}),o.jsx(Wt,{value:D}),o.jsxs("div",{className:"eval-report-wrap",children:[o.jsx("h3",{style:{marginTop:12},children:"Отчет eval"}),o.jsx(Wt,{value:q??{note:"Eval пока не запускался"}}),o.jsx("button",{type:"button",className:"copy-cube-button",title:"Скопировать отчет eval",onClick:()=>Z(),children:"⧉"})]})]})]})]})}const lm={llmProvider:"openai",apiKey:"",model:"gpt-4o-mini",baseUrl:"https://api.openai.com/v1",temperature:0,maxOutputTokens:700},Ic={systemPrompt:"Ты semantic-normalizer для бухгалтерского ассистента NDC. Возвращай только JSON по схеме normalized_query_v2_0_2.",developerPrompt:"Сначала делай decomposition сообщения на task fragments, затем определяй domain scope и route-critical flags. Для каждого fragment заполняй execution_readiness + route_status + no_route_reason. Если fragment routable, не оставляй его в no_route.",domainPrompt:"Контур: данные текущего предприятия в 1С/NDC. In-scope: документы, проводки, взаиморасчеты, остатки, периодное закрытие, аномалии и контрольные проверки. Out-of-scope: общая теория, законы и оффтоп.",schemaNotes:"schema_version: normalized_query_v2_0_2. Строгий JSON без дополнительных полей.",fewShotExamples:"Q: Проверь по поставщикам хвосты и разложи цепочку документов/оплат. => fragment in_scope, flags: multi_entity + chain_explanation. Q: Как вообще по ФСБУ? => out_of_scope/generic_accounting."},im={userQuestion:"",batchQuestionsRaw:"",periodHint:"",businessContext:"",expectedRoute:""},Qi={colors:{backgroundRgb:"18, 18, 18",mainSurfaceRgb:"25, 25, 25",horizontalSurfaceRgb:"30, 30, 30",focusSurfaceRgb:"35, 35, 35",activeRgb:"167, 59, 255",activeTextRgb:"240, 240, 240",textMainRgb:"240, 240, 240",textMutedRgb:"166, 166, 166",dangerRgb:"126, 126, 126",scrollbarTrackRgb:"20, 20, 20",scrollbarThumbRgb:"30, 30, 30",scrollbarThumbHoverRgb:"30, 50, 30"},layout:{modeColumnWidthPx:406,modeToggleWidthPx:188}},Lc="ndc_normalizer_session_config_v1",Dc="ndc_autoruns_layout_config_v1",am="ndc-autoruns-save",Wi=["Анализ запроса","Получение данных","Подготовка ответа"],um="assistant",Ki="normalizer_v2_0_2",Oc="address_query_runtime_v1",cm=["normalized","fragments","scope","flags","route","raw","validation","logs"],qi="manual_reviewer";function dm(i){return`[${new Date().toLocaleTimeString("ru-RU")}] ${i}`}function fm(i,h){if(!h)return"Previous preset is not selected.";const I=["systemPrompt","developerPrompt","domainPrompt","schemaNotes","fewShotExamples"].filter(C=>i[C]!==h[C]).map(C=>`${C}: ${Math.abs(i[C].length-h[C].length)} chars delta`);return I.length===0?"No changes against previous preset.":`Changed fields: ${I.length}. ${I.join(" | ")}`}function mm(){const[i,h]=x.useState(lm),[m,I]=x.useState(Ic),[C,L]=x.useState(im),[U,Z]=x.useState(null),[F,D]=x.useState([]),[q,O]=x.useState([]),[H,ue]=x.useState("normalized"),[Re,ee]=x.useState(!1),[re,K]=x.useState(!1),[ie,je]=x.useState([]),[ze,Te]=x.useState(""),[Ie,Le]=x.useState([]),[We,se]=x.useState(""),[Fe,Ke]=x.useState("NDC custom preset"),[lt,Ye]=x.useState(null),[nt,ve]=x.useState(""),[Me,pe]=x.useState(!1),[A,Q]=x.useState([]),[z,p]=x.useState(""),[k,G]=x.useState([]),[ce,de]=x.useState(!1),[fe,ye]=x.useState(null),[ge,te]=x.useState(""),[Ce,Dt]=x.useState(um),[bn,Rn]=x.useState(!0),[Tn,rr]=x.useState(!0),[Kt,qt]=x.useState(!0),[Hn,fn]=x.useState(!0),[Ot,Gt]=x.useState(!0),[mn,sr]=x.useState(!0),[An,or]=x.useState(!0),[In,Jt]=x.useState(!0),[Yt,lr]=x.useState(!0),[zt,pn]=x.useState(!0),[Ue,it]=x.useState(!0),[hn,gn]=x.useState(!0),[Xt,Zt]=x.useState(!0),[kt,Ln]=x.useState(!0),[en,$t]=x.useState(!0),[Ft,Mr]=x.useState(!0),[He,ir]=x.useState(""),[Ct,ar]=x.useState([]),[tn,ur]=x.useState(""),[gt,cr]=x.useState(!1),[vt,vn]=x.useState(""),[yn,ae]=x.useState(""),[Ge,me]=x.useState([]),[yt,dr]=x.useState(!1),[ke,Ve]=x.useState({open:!1,messageIndex:-1,rating:3,comment:"",annotationAuthor:qi,saving:!1,error:""}),xt=x.useRef(!1),Dn=x.useRef(!1);x.useEffect(()=>{const f=document.documentElement,{colors:M}=Qi;f.style.setProperty("--rgb-background",M.backgroundRgb),f.style.setProperty("--rgb-surface-main",M.mainSurfaceRgb),f.style.setProperty("--rgb-surface-horizontal",M.horizontalSurfaceRgb),f.style.setProperty("--rgb-surface-focus",M.focusSurfaceRgb),f.style.setProperty("--rgb-active",M.activeRgb),f.style.setProperty("--rgb-active-text",M.activeTextRgb),f.style.setProperty("--rgb-text-main",M.textMainRgb),f.style.setProperty("--rgb-text-muted",M.textMutedRgb),f.style.setProperty("--rgb-danger",M.dangerRgb),f.style.setProperty("--rgb-scrollbar-track",M.scrollbarTrackRgb),f.style.setProperty("--rgb-scrollbar-thumb",M.scrollbarThumbRgb),f.style.setProperty("--rgb-scrollbar-thumb-hover",M.scrollbarThumbHoverRgb),f.style.setProperty("--mode-column-width",`${Qi.layout.modeColumnWidthPx}px`),f.style.setProperty("--mode-toggle-width",`${Qi.layout.modeToggleWidthPx}px`)},[]);const J=f=>{O(M=>[dm(f),...M].slice(0,300))};function Ee(){let f=0;vn(Wi[0]);const M=window.setInterval(()=>{f=Math.min(f+1,Wi.length-1),vn(Wi[f])},650);return()=>window.clearInterval(M)}x.useEffect(()=>{const f=localStorage.getItem(Lc);if(f)try{const j=JSON.parse(f);h(xe=>({...xe,llmProvider:j.llmProvider==="local"?"local":"openai",model:j.model??xe.model,baseUrl:j.baseUrl??xe.baseUrl,temperature:j.temperature??xe.temperature,maxOutputTokens:j.maxOutputTokens??xe.maxOutputTokens}))}catch{}const M=localStorage.getItem(Dc);if(M)try{const j=JSON.parse(M);(j.uiMode==="assistant"||j.uiMode==="decomposition"||j.uiMode==="autoruns")&&Dt(j.uiMode),j.activeTab&&cm.includes(j.activeTab)&&ue(j.activeTab),typeof j.showAutorunsAssistantMode=="boolean"&&Rn(j.showAutorunsAssistantMode),typeof j.showAutorunsDecompositionMode=="boolean"&&rr(j.showAutorunsDecompositionMode),typeof j.showAutorunsProgressMode=="boolean"&&qt(j.showAutorunsProgressMode),typeof j.showAutorunsCommentsMode=="boolean"&&fn(j.showAutorunsCommentsMode),typeof j.showAssistantConnectionMode=="boolean"&&Gt(j.showAssistantConnectionMode),typeof j.showAssistantPromptMode=="boolean"&&sr(j.showAssistantPromptMode),typeof j.showAssistantChatMode=="boolean"&&or(j.showAssistantChatMode),typeof j.showAssistantCommentsMode=="boolean"&&Jt(j.showAssistantCommentsMode),typeof j.showAssistantSamMode=="boolean"&&lr(j.showAssistantSamMode),typeof j.showDecompositionConnectionMode=="boolean"&&pn(j.showDecompositionConnectionMode),typeof j.showDecompositionPromptMode=="boolean"&&it(j.showDecompositionPromptMode),typeof j.showDecompositionQueryMode=="boolean"&&gn(j.showDecompositionQueryMode),typeof j.showDecompositionOutputMode=="boolean"&&Zt(j.showDecompositionOutputMode),typeof j.showDecompositionMetricsMode=="boolean"&&Ln(j.showDecompositionMetricsMode),typeof j.showDecompositionHistoryMode=="boolean"&&$t(j.showDecompositionHistoryMode),typeof j.showDecompositionRuntimeMode=="boolean"&&Mr(j.showDecompositionRuntimeMode),j.prompts&&(I(xe=>({...xe,...j.prompts})),Dn.current=!0)}catch{}On(),Rr(),nn()},[]);async function On(){try{const f=await Ne.loadHistory();D(f.items??[])}catch(f){J(`History load error: ${f instanceof Error?f.message:String(f)}`)}}async function Rr(){try{const M=(await Ne.loadPresets()).presets??[];if(Le(M),Dn.current){xt.current=!0;return}if(xt.current)return;const j=M.find(xe=>xe.prompt_version===Ki)??M.find(xe=>xe.id==="default-normalizer-v2_0_2");if(!j){xt.current=!0,J(`Preset autoload skipped: ${Ki} not found.`);return}se(j.id),Ye(m),I({systemPrompt:j.systemPrompt,developerPrompt:j.developerPrompt,domainPrompt:j.domainPrompt,schemaNotes:j.schemaNotes??"",fewShotExamples:j.fewShotExamples??""}),xt.current=!0,J(`Preset autoloaded: ${j.name} (${j.prompt_version}).`)}catch(f){J(`Presets load error: ${f instanceof Error?f.message:String(f)}`)}}async function nn(){try{const f=await Ne.listRuns();Q(f.items??[])}catch(f){J(`Runs load error: ${f instanceof Error?f.message:String(f)}`)}}function Tr(){localStorage.setItem(Lc,JSON.stringify({model:i.model,llmProvider:i.llmProvider,baseUrl:i.baseUrl,temperature:i.temperature,maxOutputTokens:i.maxOutputTokens})),J("Local config saved (without API key).")}function Kr(){localStorage.setItem(Dc,JSON.stringify({uiMode:Ce,activeTab:H,showAutorunsAssistantMode:bn,showAutorunsDecompositionMode:Tn,showAutorunsProgressMode:Kt,showAutorunsCommentsMode:Hn,showAssistantConnectionMode:Ot,showAssistantPromptMode:mn,showAssistantChatMode:An,showAssistantCommentsMode:In,showAssistantSamMode:Yt,showDecompositionConnectionMode:zt,showDecompositionPromptMode:Ue,showDecompositionQueryMode:hn,showDecompositionOutputMode:Xt,showDecompositionMetricsMode:kt,showDecompositionHistoryMode:en,showDecompositionRuntimeMode:Ft,prompts:m})),window.dispatchEvent(new CustomEvent(am)),J("UI layout and prompts saved.")}async function _e(){ee(!0),te("");try{const f=await Ne.testConnection(i);f.provider==="local"?f.model_found===!0?(Te(`LOCAL OK - ${f.model}`),J(`Local model is available: ${f.model} (catalog size=${f.models_count??"n/a"}).`)):f.model_found===!1?(Te(`LOCAL OK, model not loaded - ${f.model}`),J(`Local server is reachable, but model '${f.model}' is not in loaded catalog. Use 'Load model list' and select one of loaded models.`)):(Te(`LOCAL OK (model list unavailable) - ${f.model}`),J("Local server is reachable, but model catalog could not be verified.")):(Te(`OPENAI OK - ${f.model}`),J(`OpenAI connection ok: ${f.model}`))}catch(f){const M=f instanceof Error?f.message:String(f);Te("Connection error"),te(`Test connection: ${M}`),J(`Test connection error: ${M}`)}finally{ee(!1)}}async function Ar(){K(!0);try{const M=(await Ne.listModels(i)).models??[];je(M),M.length>0&&h(j=>j.model&&M.includes(j.model)?j:{...j,model:M[0]}),J(`Model catalog loaded (${i.llmProvider}): ${M.length} items.`)}catch(f){const M=f instanceof Error?f.message:String(f);J(`Load model list error: ${M}`)}finally{K(!1)}}x.useEffect(()=>{je([])},[i.llmProvider,i.baseUrl]);async function Vn(f){ee(!0),te("");try{const M=await Ne.normalize({connection:i,prompts:m,promptVersion:"normalizer_v2_0_2",query:{userQuestion:C.userQuestion,periodHint:C.periodHint,businessContext:C.businessContext,expectedRoute:C.expectedRoute},saveAsTestCase:f,useMock:Me});Z(M),ue("normalized"),J(`Normalize done: trace=${M.trace_id}, validation=${M.validation.passed?"passed":"failed"}`),On()}catch(M){const j=M instanceof Error?M.message:String(M);te(`Normalize: ${j}`),J(`Normalize error: ${j}`)}finally{ee(!1)}}function oe(){const f=Ie.find(M=>M.id===We);if(!f){J("Preset is not selected.");return}Ye(m),I({systemPrompt:f.systemPrompt,developerPrompt:f.developerPrompt,domainPrompt:f.domainPrompt,schemaNotes:f.schemaNotes??"",fewShotExamples:f.fewShotExamples??""}),J(`Preset loaded: ${f.name}`)}async function rn(){try{await Ne.savePreset({name:Fe||"NDC preset",prompt_version:"normalizer_v2_0_2",systemPrompt:m.systemPrompt,developerPrompt:m.developerPrompt,domainPrompt:m.domainPrompt,schemaNotes:m.schemaNotes,fewShotExamples:m.fewShotExamples}),J("Preset saved."),await Rr()}catch(f){J(`Preset save error: ${f instanceof Error?f.message:String(f)}`)}}function xn(){I(Ic),J("Prompt panel reset to defaults.")}function fr(){const f=fm(m,lt);ve(f),J(f)}function mr(){const f=C.batchQuestionsRaw.split(";").map(M=>M.trim()).filter(Boolean).join(` - -`);f&&(L(M=>({...M,batchQuestionsRaw:f})),J("Batch field formatted: `;` converted to blank-line separators."))}async function Nt(f){try{const j=(await Ne.loadTrace(f)).trace,xe=j.parsed_normalized_json??null;Z({trace_id:String(j.trace_id??f),ok:!!j.validation_result?.passed,normalized:xe,route_hint_summary:j.route_hint_summary??(xe?{route_hint:xe.route_hint??null,confidence:xe.confidence?.route_hint??null}:null),raw_model_output:j.raw_model_response??{},validation:j.validation_result??{passed:!1,errors:["validation not found"]},usage:j.usage??{input_tokens:0,output_tokens:0,total_tokens:0},latency_ms:Number(j.latency_ms??0),prompt_version:String(j.prompt_version??"unknown"),schema_version:String(j.schema_version??"unknown")}),ue("raw"),te(""),J(`Trace opened: ${f}`)}catch(M){const j=M instanceof Error?M.message:String(M);te(`Trace: ${j}`),J(`Trace open error ${f}: ${j}`)}}async function _s(){try{const f=await Ne.startRun();p(f.run.runId),J(`Run started: ${f.run.runId}`),J("Tip: start run does not execute normalize by itself. Use 'Run eval v2.0.2' button."),await nn()}catch(f){J(`Run start error: ${f instanceof Error?f.message:String(f)}`)}}async function ct(){if(z)try{await Ne.finishRun(z),J(`Run finished: ${z}`),await nn()}catch(f){J(`Run finish error: ${f instanceof Error?f.message:String(f)}`)}}async function qr(){de(!0),te("");try{J("Starting eval in v2 contour.");const f=C.batchQuestionsRaw.trim()||C.userQuestion.trim();if(!f)throw new Error("Fill batch field or Raw user question first.");const M=await Ne.runEval({connection:i,prompts:m,promptVersion:"normalizer_v2_0_2",mode:"single-pass-strict",rawQuestions:f,useMock:Me});ye(M.report),J("Eval v2.0.2 run finished.");const j=M.report;if(j.run_id&&J(`Eval run id: ${j.run_id}`),j.metrics){const xe=j.metrics;J(`Eval metrics v2.0.2: schema=${xe.schema_validation_pass_rate??"n/a"}%, route_accuracy=${xe.route_resolution_accuracy??"n/a"}%, no_route_precision=${xe.no_route_precision??"n/a"}%, state_consistency=${xe.execution_state_consistency_rate??"n/a"}%`)}await On()}catch(f){const M=f instanceof Error?f.message:String(f);M.includes("Legacy eval runner supports normalized_query_v1 only")?(ye({status:"plan_only",prompt_version:"normalizer_v2",reason:"backend eval runner is still legacy-v1 only",plan_file:"reports/v2_pilot_eval_plan.md",next_steps:["run cheap mock sanity for schema/fragment/scope","run small real batch (10-15 messages, temperature=0)","run challenge-30 replay with v2 metrics"]}),J("Backend is legacy-only for eval right now. Showing v2 pilot plan.")):(te(`Eval: ${M}`),J(`Eval run error: ${M}`))}finally{de(!1)}}async function Gr(){try{const f=JSON.stringify(fe??{},null,2);await navigator.clipboard.writeText(f),J("Eval report copied to clipboard.")}catch(f){J(`Eval report copy error: ${f instanceof Error?f.message:String(f)}`)}}const Ir=x.useMemo(()=>{const f=new Map;for(const M of Ge)M.message_id&&f.set(M.message_id,M);return f},[Ge]),Ut=ke.messageIndex>=0?Ct[ke.messageIndex]??null:null,_t=x.useMemo(()=>{if(ke.messageIndex<0)return null;for(let f=ke.messageIndex-1;f>=0;f-=1){const M=Ct[f];if(M?.role==="user")return M}return null},[ke.messageIndex,Ct]);async function sn(f){if(!f.trim()){me([]);return}dr(!0);try{const M=await Ne.loadAssistantAnnotations({session_id:f,limit:400});me(M.items??[])}catch(M){const j=M instanceof Error?M.message:String(M);J(`Assistant annotations load error: ${j}`)}finally{dr(!1)}}function Xe(f){Ve(M=>M.saving&&!f?.force?M:{open:!1,messageIndex:-1,rating:3,comment:"",annotationAuthor:qi,saving:!1,error:""})}function Ss(f,M){if(f.role!=="assistant")return;const j=He.trim(),xe=String(f.session_id??"").trim();if(!(j||xe)){ae("Сначала получите ответ ассистента в активной сессии.");return}!j&&xe&&ir(xe);const Sn=Ir.get(f.message_id)??null;Ve({open:!0,messageIndex:M,rating:Sn?.rating??3,comment:Sn?.comment??"",annotationAuthor:Sn?.annotation_author??qi,saving:!1,error:""})}function Qn(f){return f.role==="assistant"}function Et(f){return f.role==="assistant"&&Ir.has(f.message_id)}async function zn(){if(!He.trim()){Ve(f=>({...f,error:"Сессия ассистента не найдена."}));return}if(!(ke.messageIndex<0)){if(!ke.comment.trim()){Ve(f=>({...f,error:"Добавьте комментарий."}));return}Ve(f=>({...f,saving:!0,error:""}));try{const f=await Ne.saveAssistantAnnotation({session_id:He,message_index:ke.messageIndex,rating:ke.rating,comment:ke.comment.trim(),annotation_author:ke.annotationAuthor.trim()||void 0});me(M=>{const j=[...M],xe=j.findIndex(Wn=>Wn.annotation_id===f.annotation.annotation_id);return xe>=0?j[xe]=f.annotation:j.unshift(f.annotation),j.sort((Wn,Sn)=>Date.parse(Sn.updated_at)-Date.parse(Wn.updated_at))}),Xe({force:!0})}catch(f){const M=f instanceof Error?f.message:String(f);Ve(j=>({...j,saving:!1,error:M}))}}}function St(){ir(""),ar([]),ur(""),vn(""),ae(""),me([]),Xe({force:!0}),J("Assistant session reset.")}async function _n(){const f=tn.trim();if(!f)return;cr(!0),ae(""),ur(""),ar(j=>[...j,{message_id:`local-${Date.now()}`,session_id:He||"pending",role:"user",text:f,reply_type:null,created_at:new Date().toISOString(),trace_id:null,debug:null}]);const M=Ee();try{const j=await Ne.sendAssistantMessage({connection:i,prompts:m,userMessage:f,sessionId:He||void 0,promptVersion:Oc,useMock:Me});ir(j.session_id),ar(j.conversation),vn("Ответ готов"),await sn(j.session_id),J(`Assistant reply received: trace=${j.debug.trace_id}`)}catch(j){const xe=j instanceof Error?j.message:String(j);ae(xe),vn("Ошибка ассистента"),J(`Assistant error: ${xe}`)}finally{M(),cr(!1)}}return x.useEffect(()=>{if(!He.trim()){me([]);return}sn(He)},[He]),x.useEffect(()=>{if(!z){G([]);return}Ne.runTrace(z).then(f=>G(f.items)).catch(f=>J(`Run trace error: ${f instanceof Error?f.message:String(f)}`))},[z]),o.jsxs("main",{className:`app-root ${Ce==="assistant"||Ce==="decomposition"||Ce==="autoruns"?"app-root-autoruns":""}`,children:[o.jsxs("header",{className:"app-topbar",children:[o.jsxs("div",{className:"mode-switch-row",children:[o.jsx("button",{type:"button",className:Ce==="assistant"?"tab active":"tab",onClick:()=>Dt("assistant"),children:"Ассистент"}),o.jsx("button",{type:"button",className:Ce==="decomposition"?"tab active":"tab",onClick:()=>Dt("decomposition"),children:"Декомпозиция"}),o.jsx("button",{type:"button",className:Ce==="autoruns"?"tab active":"tab",onClick:()=>Dt("autoruns"),children:"История автопрогонов"}),o.jsx("button",{type:"button",className:"tab",onClick:Kr,children:"Сохранить"})]}),Ce==="assistant"?o.jsxs("div",{className:"mode-switch-row mode-switch-row-right",children:[o.jsx("button",{type:"button",className:Ot?"tab active":"tab",onClick:()=>Gt(f=>!f),children:"LLM Connector"}),o.jsx("button",{type:"button",className:mn?"tab active":"tab",onClick:()=>sr(f=>!f),children:"Prompt Manager"}),o.jsx("button",{type:"button",className:An?"tab active":"tab",onClick:()=>or(f=>!f),children:"Режим ассистента"}),o.jsx("button",{type:"button",className:In?"tab active":"tab",onClick:()=>Jt(f=>!f),children:"Комментарии ассистента"}),o.jsx("button",{type:"button",className:Yt?"tab active":"tab",onClick:()=>lr(f=>!f),children:"SAM"})]}):Ce==="decomposition"?o.jsxs("div",{className:"mode-switch-row mode-switch-row-right",children:[o.jsx("button",{type:"button",className:zt?"tab active":"tab",onClick:()=>pn(f=>!f),children:"LLM"}),o.jsx("button",{type:"button",className:Ue?"tab active":"tab",onClick:()=>it(f=>!f),children:"Prompt"}),o.jsx("button",{type:"button",className:hn?"tab active":"tab",onClick:()=>gn(f=>!f),children:"Запрос"}),o.jsx("button",{type:"button",className:Xt?"tab active":"tab",onClick:()=>Zt(f=>!f),children:"Выход"}),o.jsx("button",{type:"button",className:kt?"tab active":"tab",onClick:()=>Ln(f=>!f),children:"Метрики"}),o.jsx("button",{type:"button",className:en?"tab active":"tab",onClick:()=>$t(f=>!f),children:"История"}),o.jsx("button",{type:"button",className:Ft?"tab active":"tab",onClick:()=>Mr(f=>!f),children:"NDC Run Monitor"})]}):Ce==="autoruns"?o.jsxs("div",{className:"mode-switch-row mode-switch-row-right",children:[o.jsx("button",{type:"button",className:bn?"tab active":"tab",onClick:()=>Rn(f=>!f),children:"Режим ассистента"}),o.jsx("button",{type:"button",className:Tn?"tab active":"tab",onClick:()=>rr(f=>!f),children:"Режим декомпозиции"}),o.jsx("button",{type:"button",className:Kt?"tab active":"tab",onClick:()=>qt(f=>!f),children:"Прогресс/регресс"}),o.jsx("button",{type:"button",className:Hn?"tab active":"tab",onClick:()=>fn(f=>!f),children:"Комментарии"})]}):null]}),Ce==="assistant"?o.jsx("div",{className:"layout-grid layout-grid-mode-columns",children:o.jsxs("div",{className:"mode-columns",children:[Ot?o.jsx("div",{className:"mode-col",children:o.jsx(Tc,{value:i,modelOptions:ie,modelsBusy:re,onChange:h,onReloadModels:Ar,onSaveLocalConfig:Tr,onTestConnection:_e,lastStatus:ze,busy:Re||gt})}):null,mn?o.jsx("div",{className:"mode-col mode-col-wide",children:o.jsx(Ac,{value:m,onChange:I,presets:Ie,selectedPresetId:We,onSelectPreset:se,onLoadPreset:oe,onSavePreset:rn,onResetDefaults:xn,onDiffPrevious:fr,presetName:Fe,onPresetNameChange:Ke,diffSummary:nt})}):null,An?o.jsx("div",{className:"mode-col mode-col-xwide",children:o.jsx($c,{sessionId:He,conversation:Ct,inputValue:tn,onInputChange:ur,useMock:Me,onUseMockChange:pe,onSend:_n,onClear:St,busy:gt,statusText:vt,errorMessage:yn,showCommentAction:!0,onCommentAssistantMessage:Ss,isAssistantMessageCommented:Et,canCommentAssistantMessage:Qn})}):null,In?o.jsx("div",{className:"mode-col",children:o.jsx(Mn,{className:"assistant-comments-frame",title:"Комментарии ассистента",children:o.jsxs("div",{className:"assistant-comments-shell",children:[o.jsxs("div",{className:"assistant-comments-toolbar",children:[o.jsx("span",{className:"muted",children:He?`session: ${He}`:"Сессия не запущена"}),o.jsx("button",{type:"button",className:"tab",onClick:()=>{sn(He)},disabled:!He||yt,children:yt?"Обновляю...":"Обновить"})]}),o.jsxs("div",{className:"assistant-comments-list",children:[He?null:o.jsx("p",{className:"muted",children:"Появится после первого ответа ассистента."}),He&&Ge.length===0&&!yt?o.jsx("p",{className:"muted",children:"Комментариев по этой сессии пока нет."}):null,Ge.map(f=>o.jsxs("article",{className:"assistant-comment-item",children:[o.jsxs("div",{className:"assistant-comment-head",children:[o.jsx("strong",{children:`${"●".repeat(Math.max(1,Math.min(5,Math.round(f.rating))))}${"○".repeat(Math.max(0,5-Math.round(f.rating)))}`}),o.jsx("span",{children:new Date(f.updated_at).toLocaleString("ru-RU")})]}),f.context.question_text?o.jsxs("p",{children:["Q: ",f.context.question_text]}):null,f.context.answer_text?o.jsxs("p",{children:["A: ",f.context.answer_text]}):null,o.jsx("p",{children:f.comment}),o.jsxs("div",{className:"assistant-comment-meta",children:[f.context.trace_id?o.jsx("span",{children:`trace=${f.context.trace_id}`}):null,f.context.reply_type?o.jsx("span",{children:`reply_type=${f.context.reply_type}`}):null]})]},f.annotation_id))]})]})})}):null,Yt?o.jsx("div",{className:"mode-col",children:o.jsx(Rf,{sessionId:He,conversation:Ct,statusText:vt,errorMessage:yn,useMock:Me,appLogs:q})}):null,!Ot&&!mn&&!An&&!In&&!Yt?o.jsx("div",{className:"mode-columns-empty",children:"Все панели режима ассистента скрыты. Включите нужные блоки справа в шапке."}):null]})}):Ce==="decomposition"?o.jsx("div",{className:"layout-grid layout-grid-mode-columns",children:o.jsxs("div",{className:"mode-columns",children:[zt?o.jsx("div",{className:"mode-col",children:o.jsx(Tc,{value:i,modelOptions:ie,modelsBusy:re,onChange:h,onReloadModels:Ar,onSaveLocalConfig:Tr,onTestConnection:_e,lastStatus:ze,busy:Re})}):null,Ue?o.jsx("div",{className:"mode-col mode-col-wide",children:o.jsx(Ac,{value:m,onChange:I,presets:Ie,selectedPresetId:We,onSelectPreset:se,onLoadPreset:oe,onSavePreset:rn,onResetDefaults:xn,onDiffPrevious:fr,presetName:Fe,onPresetNameChange:Ke,diffSummary:nt})}):null,hn?o.jsx("div",{className:"mode-col",children:o.jsx(sm,{value:C,onChange:L,onApplyBatchFormat:mr,onNormalize:Vn,busy:Re,useMock:Me,onUseMockChange:pe,errorMessage:ge})}):null,Xt?o.jsx("div",{className:"mode-col mode-col-xwide",children:o.jsx(rm,{tab:H,onTabChange:ue,result:U,appLogs:q})}):null,kt?o.jsx("div",{className:"mode-col",children:o.jsx(em,{result:U})}):null,en?o.jsx("div",{className:"mode-col",children:o.jsx(Zf,{items:F,onRefresh:On,onOpenTrace:Nt})}):null,Ft?o.jsx("div",{className:"mode-col mode-col-xwide",children:o.jsx(om,{runs:A,selectedRunId:z,onSelectRun:p,onStartRun:_s,onFinishRun:ct,onRefreshRuns:nn,onRunEval:qr,onCopyEvalReport:Gr,evalBusy:ce,traceItems:k,evalReport:fe})}):null,!zt&&!Ue&&!hn&&!Xt&&!kt&&!en&&!Ft?o.jsx("div",{className:"mode-columns-empty",children:"Все панели режима декомпозиции скрыты. Включите нужные блоки справа в шапке."}):null]})}):o.jsx("div",{className:"layout-grid layout-grid-autoruns",children:o.jsx(Xf,{connection:i,prompts:m,assistantPromptVersion:Oc,decompositionPromptVersion:Ki,showAssistantMode:bn,showDecompositionMode:Tn,showProgressMode:Kt,showCommentsMode:Hn,onLog:J})}),ke.open?o.jsx("div",{className:"autoruns-comment-modal-backdrop",onClick:f=>{f.target===f.currentTarget&&Xe()},children:o.jsxs("div",{className:"autoruns-comment-modal",children:[o.jsx("h3",{children:"Комментарий к ответу ассистента"}),o.jsx("p",{className:"muted",children:"Эта разметка хранится отдельно от комментариев автопрогонов."}),_t?o.jsxs("details",{className:"autoruns-prompt-details",open:!0,children:[o.jsx("summary",{children:"Вопрос пользователя"}),o.jsx("p",{className:"autoruns-comment-quote",children:_t.text})]}):null,Ut?o.jsxs("details",{className:"autoruns-prompt-details",open:!0,children:[o.jsx("summary",{children:"Ответ ассистента"}),o.jsx("p",{className:"autoruns-comment-quote",children:Ut.text})]}):null,o.jsx("div",{className:"autoruns-rating-row",role:"group","aria-label":"Рейтинг ответа",children:[1,2,3,4,5].map(f=>o.jsx("button",{type:"button",className:ke.rating>=f?"autoruns-rating-dot active":"autoruns-rating-dot",onClick:()=>Ve(M=>({...M,rating:f})),disabled:ke.saving,"aria-label":`Оценка ${f}`,children:ke.rating>=f?"●":"○"},f))}),o.jsx("div",{className:"autoruns-form-grid",children:o.jsxs("label",{children:["Автор комментария",o.jsx("input",{value:ke.annotationAuthor,onChange:f=>Ve(M=>({...M,annotationAuthor:f.target.value})),placeholder:"manual_reviewer",disabled:ke.saving})]})}),o.jsxs("label",{children:["Комментарий",o.jsx("textarea",{value:ke.comment,onChange:f=>Ve(M=>({...M,comment:f.target.value})),placeholder:"Что именно не так в ответе и что проверить.",rows:4,disabled:ke.saving})]}),ke.error?o.jsx("p",{className:"error-text",children:ke.error}):null,o.jsxs("div",{className:"button-row",children:[o.jsx("button",{type:"button",onClick:()=>{zn()},disabled:ke.saving,children:ke.saving?"Сохраняю...":"Готово"}),o.jsx("button",{type:"button",className:"tab",onClick:()=>Xe(),disabled:ke.saving,children:"Отмена"})]})]})}):null]})}Ef.createRoot(document.getElementById("root")).render(o.jsx(_f.StrictMode,{children:o.jsx(mm,{})})); diff --git a/llm_normalizer/frontend/dist/assets/index-Cx2J_KsF.css b/llm_normalizer/frontend/dist/assets/index-Cx2J_KsF.css deleted file mode 100644 index da3eb2b..0000000 --- a/llm_normalizer/frontend/dist/assets/index-Cx2J_KsF.css +++ /dev/null @@ -1 +0,0 @@ -@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;600;700;800&family=Space+Grotesk:wght@500;700&display=swap";:root{--rgb-background: 16, 16, 19;--rgb-surface-main: 26, 26, 31;--rgb-surface-horizontal: 32, 32, 38;--rgb-surface-focus: 40, 40, 47;--rgb-active: 228, 142, 92;--rgb-active-text: 18, 18, 18;--rgb-text-main: 240, 240, 240;--rgb-text-muted: 166, 166, 170;--rgb-danger: 255, 126, 126;--rgb-scrollbar-track: 31, 31, 36;--rgb-scrollbar-thumb: 74, 74, 82;--rgb-scrollbar-thumb-hover: 90, 90, 100;--mode-column-width: 440px;--mode-toggle-width: 188px;--bg-main: rgb(var(--rgb-background));--bg-soft: rgb(var(--rgb-surface-main));--bg-panel: rgb(var(--rgb-surface-main));--bg-panel-accent: rgb(var(--rgb-surface-horizontal));--surface-horizontal: rgb(var(--rgb-surface-horizontal));--surface-focus: rgb(var(--rgb-surface-focus));--line: transparent;--line-strong: rgba(var(--rgb-active), .48);--text-main: rgb(var(--rgb-text-main));--text-muted: rgb(var(--rgb-text-muted));--lime-main: rgb(var(--rgb-text-main));--lime-press: rgb(var(--rgb-text-main));--danger: rgb(var(--rgb-danger));--radius-lg: 20px;--radius-md: 14px;--shadow: none;--autoruns-col-width: var(--mode-column-width)}*{box-sizing:border-box;scrollbar-width:thin;scrollbar-color:rgb(var(--rgb-scrollbar-thumb)) rgb(var(--rgb-scrollbar-track))}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-track{background:rgb(var(--rgb-scrollbar-track))}*::-webkit-scrollbar-thumb{background:rgb(var(--rgb-scrollbar-thumb));border-radius:999px;border:2px solid rgb(var(--rgb-scrollbar-track))}*::-webkit-scrollbar-thumb:hover{background:rgb(var(--rgb-scrollbar-thumb-hover))}html,body,#root{margin:0;min-height:100dvh;font-family:Manrope,Segoe UI,sans-serif;background:var(--bg-main);color:var(--text-main)}.app-root{max-width:1720px;margin:0 auto;padding:12px 16px 16px}.app-root.app-root-autoruns{max-width:none;width:100%;min-height:100dvh;max-height:100dvh;display:flex;flex-direction:column;overflow:hidden}.app-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 0 12px;padding:0;min-height:38px}.layout-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}.layout-grid.layout-grid-autoruns,.layout-grid.layout-grid-mode-columns{min-height:0;flex:1 1 auto;grid-template-columns:minmax(0,1fr)}.mode-switch-row{display:flex;gap:8px;margin:0;padding:0}.mode-switch-row.mode-switch-row-right{margin-left:auto;justify-content:flex-end;max-width:72%;overflow-x:auto;overflow-y:hidden;padding-bottom:2px}.mode-switch-row .tab{white-space:nowrap}.mode-switch-row.mode-switch-row-right .tab{width:var(--mode-toggle-width);min-width:var(--mode-toggle-width);text-align:center}.mode-columns{display:flex;gap:12px;width:100%;min-height:0;flex:1 1 auto;overflow-x:auto;overflow-y:hidden;padding-bottom:4px}.mode-col{flex:0 0 var(--mode-column-width);width:var(--mode-column-width);min-height:0;height:100%;display:flex}.mode-col.mode-col-wide,.mode-col.mode-col-xwide{flex-basis:var(--mode-column-width);width:var(--mode-column-width)}.mode-col .panel-frame{width:100%;height:100%}.mode-col .panel-body{min-height:0;overflow:auto}.mode-columns-empty{min-width:360px;border-radius:14px;background:rgb(var(--rgb-surface-main));color:var(--text-muted);padding:14px}.panel-frame{grid-column:span 12;border:none;border-radius:var(--radius-lg);background:var(--bg-panel);overflow:hidden;box-shadow:none;animation:rise .4s ease-out;display:flex;flex-direction:column;min-height:0}.panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:14px 18px 10px;border-bottom:none;background:var(--bg-panel-accent)}.panel-header h2{margin:0;font-size:1.02rem;letter-spacing:.02em}.panel-header p{margin:6px 0 0;font-size:.85rem;color:var(--text-muted)}.panel-body{padding:10px 12px 12px;min-height:0}.app-root-autoruns .autoruns-frame{height:100%}.app-root-autoruns .autoruns-frame .panel-body{flex:1 1 auto;overflow:hidden;display:flex;flex-direction:column;gap:10px;padding:10px 12px 12px;background:rgb(var(--rgb-background))}.status-chip{border:none;border-radius:999px;padding:4px 10px;color:var(--lime-main);font-size:.78rem;background:rgb(var(--rgb-surface-focus))}.assistant-toolbar{display:grid;gap:8px}.assistant-toolbar-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));align-items:center;gap:8px}.assistant-toolbar-meta{display:flex;align-items:center;justify-content:space-between;gap:8px}.assistant-toolbar-meta-right{margin-left:auto;display:flex;align-items:center;justify-content:flex-end;gap:8px;min-width:0;flex-wrap:wrap}.assistant-live-status{color:var(--text-muted);font-size:.8rem;white-space:nowrap}.assistant-toolbar-error{margin:0}.assistant-copy-btn{width:100%;justify-self:stretch;background:transparent;border-color:transparent;color:var(--text-main);font-size:.6rem;line-height:1.1;white-space:nowrap;text-align:center;letter-spacing:0;padding:6px 8px;box-shadow:none;transform:none}.assistant-copy-btn:hover{background:rgb(var(--rgb-surface-focus));filter:none;box-shadow:none;transform:none}.assistant-copy-feedback{font-size:.76rem;color:var(--text-muted)}.assistant-copy-feedback.success{color:var(--lime-main)}.assistant-copy-feedback.error{color:var(--danger)}input,select,textarea,button{font-family:Manrope,sans-serif}label{display:flex;flex-direction:column;gap:6px;color:var(--text-muted);font-size:.84rem}input,select,textarea{border:none;border-radius:var(--radius-md);background:rgb(var(--rgb-surface-horizontal));color:var(--text-main);padding:10px 12px;outline:none;transition:background-color .18s ease}input:focus,select:focus,textarea:focus{border-color:transparent;box-shadow:none;outline:none;background:rgb(var(--rgb-surface-focus))}textarea{resize:vertical;min-height:86px;overflow-y:auto;overflow-x:hidden;scrollbar-gutter:stable}.assistant-input-textarea,.autoruns-personality-prompt{overflow-y:auto;overflow-x:hidden;scrollbar-gutter:stable both-edges;border-bottom-right-radius:6px}.assistant-input-textarea::-webkit-scrollbar-corner,.autoruns-personality-prompt::-webkit-scrollbar-corner{background:rgb(var(--rgb-surface-horizontal))}button{border:none;border-radius:999px;background:rgb(var(--rgb-surface-horizontal));color:rgb(var(--rgb-text-main));font-weight:700;font-size:.83rem;letter-spacing:.02em;cursor:pointer;padding:9px 14px;transition:background .2s ease,color .2s ease;outline:none;box-shadow:none}button:hover{border-color:transparent;background:rgb(var(--rgb-surface-focus))}button:disabled{opacity:.52;cursor:not-allowed}.button-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-top:12px}.checkbox-row{flex-direction:row;align-items:center;gap:8px;color:var(--text-main)}.grid-two{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.prompt-manager-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:12px}.full-width{grid-column:1 / -1}.tab-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.tab{background:rgb(var(--rgb-surface-main));color:var(--text-main);border:none}.tab.active{border-color:transparent;background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.assistant-chat-list{flex:1 1 auto;min-height:0;overflow:auto;overscroll-behavior:contain;display:flex;flex-direction:column;gap:8px;padding:10px;border:none;border-radius:12px;background:rgb(var(--rgb-surface-horizontal))}.assistant-chat-list .assistant-msg:first-child{margin-top:auto}.assistant-empty{padding:18px;text-align:center}.assistant-msg{border:none;border-radius:12px;background:rgb(var(--rgb-surface-focus));padding:8px 10px;display:grid;gap:6px}.assistant-msg.user{margin-left:12%;border-color:transparent;background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.assistant-msg.assistant{margin-right:12%;border-color:transparent}.assistant-msg.user .assistant-msg-head{color:rgba(var(--rgb-active-text),.9)}.assistant-msg.user .assistant-msg-body{color:rgb(var(--rgb-active-text))}.assistant-msg-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:0;font-size:.74rem;color:var(--text-muted)}.assistant-msg-head-main{flex:1 1 auto;min-width:0;display:flex;align-items:center;justify-content:space-between;gap:8px}.assistant-msg-head-actions{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}.assistant-comment-btn{cursor:pointer}.assistant-comment-btn:disabled{opacity:.42;cursor:not-allowed}.assistant-msg.user .assistant-comment-btn{color:rgba(var(--rgb-active-text),.92)}.assistant-msg-body{display:grid;gap:10px;line-height:1.35;font-size:.84rem}.assistant-msg-block{display:grid;gap:4px}.assistant-msg-line{margin:0;white-space:pre-wrap;word-break:break-word}.assistant-msg-line.heading{font-weight:700;letter-spacing:.01em}.assistant-msg-line.numbered{margin-top:2px}.assistant-msg-line strong{font-weight:800}.assistant-trace{margin-top:6px;color:var(--text-muted);font-size:.75rem}.assistant-debug{margin-top:8px}.assistant-debug summary{cursor:pointer;color:var(--lime-main);font-size:.8rem}.assistant-compose{margin-top:0;display:grid;gap:8px;flex:0 0 auto}.assistant-send-row{align-items:center;margin-top:2px}.assistant-send-btn{margin-left:auto}.assistant-comments-frame .panel-body{display:flex;flex-direction:column;min-height:0;overflow:hidden}.assistant-comments-shell{display:grid;gap:8px;min-height:0;height:100%}.assistant-comments-toolbar{display:flex;align-items:center;justify-content:space-between;gap:8px}.assistant-comments-list{display:grid;gap:8px;overflow:auto;min-height:0;padding-right:2px}.assistant-comment-item{border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:8px;display:grid;gap:6px}.assistant-comment-head{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:.75rem}.assistant-comment-item p{margin:0;white-space:pre-wrap;font-size:.8rem}.assistant-comment-meta{display:flex;flex-wrap:wrap;gap:8px;color:var(--text-muted);font-size:.74rem}.app-root-autoruns .assistant-panel-frame .panel-header{position:sticky;top:-12px;z-index:8;margin:-12px -12px 0;padding:12px 12px 10px;background:rgb(var(--rgb-surface-main))}.app-root-autoruns .assistant-panel-frame{overflow:visible}.app-root-autoruns .assistant-panel-frame .panel-body{flex:1 1 auto;padding:0 12px 12px;display:flex;flex-direction:column;min-height:0;overflow:hidden}.app-root-autoruns .assistant-panel-frame .assistant-live-shell{flex:1 1 auto;min-height:0;padding:12px;border-radius:14px;background:rgb(var(--rgb-background));display:flex;flex-direction:column;gap:10px}.app-root-autoruns .assistant-panel-frame .assistant-chat-list{overflow-y:auto}.app-root-autoruns .assistant-panel-frame .panel-header h2{margin:0;font-size:.95rem}.json-view{margin:0;width:100%;min-height:180px;max-height:420px;overflow:auto;background:rgb(var(--rgb-surface-horizontal));border:none;border-radius:var(--radius-md);padding:12px;color:rgb(var(--rgb-text-main));font-family:JetBrains Mono,Consolas,monospace;font-size:.78rem;line-height:1.45}.metrics-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.metrics-grid div{background:rgba(var(--rgb-surface-main),.8);border:none;border-radius:12px;padding:10px;display:flex;flex-direction:column;gap:4px}.metrics-grid span{color:var(--text-muted);font-size:.75rem}.metrics-grid strong{font-size:.84rem;color:var(--lime-main)}.history-list{display:grid;gap:8px;max-height:340px;overflow:auto}.history-item{width:100%;text-align:left;border-radius:12px;border:none;background:rgb(var(--rgb-surface-main));color:var(--text-main);padding:10px}.history-item p{margin:8px 0;color:var(--text-muted);font-size:.82rem}.history-item.selected{border-color:var(--line-strong)}.history-row{display:flex;justify-content:space-between;gap:8px;font-size:.76rem;color:var(--text-muted)}.runtime-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:12px}.runtime-stack{display:grid;grid-template-columns:minmax(0,1fr);gap:12px}.runtime-details{display:grid;gap:12px}.runtime-runs{max-height:360px;overflow:auto;display:grid;gap:8px}.eval-report-wrap{position:relative}.copy-cube-button{position:absolute;right:10px;bottom:10px;width:34px;height:34px;border-radius:10px;padding:0;min-width:34px;display:grid;place-items:center;font-size:.92rem;line-height:1}.muted{color:var(--text-muted)}.diff-summary{margin-top:10px;font-size:.82rem;color:var(--lime-main)}.error-text{margin-top:10px;color:var(--danger);font-size:.84rem}.autoruns-columns{display:flex;gap:12px;width:100%;min-height:0;flex:1 1 auto;overflow-x:auto;overflow-y:hidden;padding-bottom:4px}.autoruns-col{flex:0 0 var(--mode-column-width);width:var(--mode-column-width);height:100%;min-height:0;overflow-y:auto;overflow-x:hidden;border:none;border-radius:14px;background:rgb(var(--rgb-surface-main));padding:12px;scrollbar-gutter:stable}.autoruns-assistant-live-col{background:rgb(var(--rgb-surface-main));padding:12px;overflow:hidden;scrollbar-gutter:auto}.autoruns-assistant-live-col .panel-frame{height:100%;background:rgb(var(--rgb-surface-main))}.autoruns-col h3{margin:0;font-size:.95rem}.autoruns-col h4{margin:12px 0 8px;font-size:.82rem;color:var(--text-muted)}.autoruns-col-header{position:sticky;top:-12px;z-index:8;margin:-12px -12px 10px;padding:12px 12px 10px;background:rgb(var(--rgb-surface-main))}.autoruns-col-header .tab-row{margin:8px 0 0}.autoruns-col-header .autoruns-dialog-toolbar{margin-top:8px}.autoruns-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.autoruns-meta-list{display:grid;gap:8px}.autoruns-meta-list>div{display:flex;justify-content:space-between;gap:8px;border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:8px 9px;font-size:.79rem}.autoruns-meta-list span{color:var(--text-muted)}.autoruns-prompt-details summary{cursor:pointer;color:var(--text-main);font-size:.8rem;margin-bottom:8px}.autoruns-prompt-details textarea{min-height:68px}.autoruns-stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:10px}.autoruns-stats-grid>div{border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:8px;display:grid;gap:3px}.autoruns-stats-grid span{color:var(--text-muted);font-size:.74rem}.autoruns-stats-grid strong{color:var(--lime-main);font-size:.84rem}.autoruns-run-list{display:grid;gap:8px;max-height:none;min-height:0;flex:1 1 auto;overflow:auto;padding-right:2px}.autoruns-run-item{width:100%;text-align:left;border-radius:12px;border:none;background:rgb(var(--rgb-surface-horizontal));color:var(--text-main);padding:10px;display:grid;gap:5px;transition:background-color .2s ease,box-shadow .2s ease}.autoruns-run-item.selected{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text));box-shadow:none}.autoruns-run-item.selected .autoruns-run-meta{color:rgba(var(--rgb-active-text),.95)}.autoruns-run-head,.autoruns-run-foot{display:flex;justify-content:space-between;gap:8px;font-size:.76rem}.autoruns-run-meta{color:var(--text-muted);font-size:.75rem;word-break:break-word}.autoruns-run-id-row{display:flex;align-items:center;justify-content:space-between;gap:8px;min-width:0}.autoruns-run-id-row>span{min-width:0;overflow-wrap:anywhere;word-break:break-word}.autoruns-copy-run-id-btn{border:none;background:transparent;color:rgb(var(--rgb-text-main));width:16px;height:16px;min-width:16px;min-height:16px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:4px;opacity:.92;cursor:pointer}.autoruns-copy-run-id-btn:hover{color:rgb(var(--rgb-text-main));opacity:1;background:transparent;box-shadow:none;transform:none}.autoruns-copy-run-id-btn:focus-visible{outline:1px solid rgba(var(--rgb-text-main),.7);outline-offset:1px}.autoruns-copy-icon-svg{width:.82rem;height:.82rem;fill:none;stroke:currentColor;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}.autoruns-dialog-toolbar{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.autoruns-case-list{margin-top:8px;display:grid;gap:6px;max-height:180px;overflow:auto}.autoruns-case-item{width:100%;text-align:left;border-radius:10px;border:none;background:rgb(var(--rgb-surface-horizontal));color:var(--text-main);padding:7px 8px;display:flex;justify-content:space-between;gap:6px;font-size:.76rem}.autoruns-case-item.selected{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text));box-shadow:none}.autoruns-dialog-view{margin-top:10px;border:none;border-radius:12px;background:rgb(var(--rgb-surface-horizontal));padding:10px;max-height:none;min-height:0;flex:1 1 auto;overflow:auto;display:grid;gap:8px}.autoruns-msg{border:none;border-radius:12px;background:rgb(var(--rgb-surface-focus));padding:8px 10px;display:grid;gap:6px;min-width:0;overflow:hidden}.autoruns-msg header,.autoruns-msg footer{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;min-width:0;gap:8px;font-size:.74rem;color:var(--text-muted)}.autoruns-msg-head-actions{display:flex;align-items:center;justify-content:flex-end;flex:1 1 auto;min-width:0;flex-wrap:wrap;gap:8px}.autoruns-msg-head-actions>span{min-width:0;overflow-wrap:anywhere;word-break:break-word}.autoruns-msg-case-tag{display:inline-flex;align-items:center;border-radius:999px;padding:2px 8px;font-size:.7rem;line-height:1;color:rgb(var(--rgb-active-text));background:rgba(var(--rgb-active),.24)}.autoruns-msg p{margin:0;white-space:pre-wrap;line-height:1.35;font-size:.84rem;overflow-wrap:anywhere;word-break:break-word}.autoruns-msg footer span{min-width:0;overflow-wrap:anywhere;word-break:break-word}.autoruns-comment-icon{border:none;background:transparent;color:rgb(var(--rgb-text-main));border-radius:0;min-width:16px;min-height:16px;width:16px;height:16px;padding:0;line-height:1;box-shadow:none;transform:none;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;opacity:.92}.autoruns-comment-icon:hover{background:transparent;color:rgb(var(--rgb-text-main));opacity:1;box-shadow:none;transform:none}.autoruns-comment-icon.commented{color:rgb(var(--rgb-active));background:transparent;box-shadow:none}.autoruns-comment-icon:focus-visible{outline:1px solid rgba(var(--rgb-text-main),.7);outline-offset:1px}.autoruns-comment-icon:disabled{opacity:.42;cursor:not-allowed}.comment-icon-svg{width:.82rem;height:.82rem;stroke:currentColor;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round;fill:none}.comment-icon-svg.commented{stroke:rgb(var(--rgb-active));fill:none}.autoruns-resolve-toggle{border:none;background:rgb(var(--rgb-surface-focus));color:rgb(var(--rgb-text-main));border-radius:999px;width:22px;height:22px;min-width:22px;min-height:22px;padding:0;display:inline-flex;align-items:center;justify-content:center;box-shadow:none;transform:none}.autoruns-resolve-toggle:hover{background:rgb(var(--rgb-surface-focus));color:rgb(var(--rgb-active));box-shadow:none;transform:none}.autoruns-resolve-toggle:disabled{opacity:.55;cursor:wait}.autoruns-resolve-toggle.resolved{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.resolve-icon-svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.resolve-icon-svg.resolved{fill:currentColor}.autoruns-msg-annotation{display:grid;gap:4px;border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:7px 8px;font-size:.78rem}.autoruns-comments-list{display:grid;gap:8px;max-height:none;min-height:0;flex:1 1 auto;overflow:auto;padding-right:2px;margin-top:6px}.autoruns-autogen-list{display:grid;gap:8px;max-height:none;min-height:0;overflow:auto;padding-right:2px}.autoruns-autogen-item{border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:8px;display:grid;gap:5px;cursor:pointer}.autoruns-autogen-item.selected{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.autoruns-autogen-item.selected .autoruns-run-meta,.autoruns-autogen-item.selected p{color:rgba(var(--rgb-active-text),.95)}.autoruns-autogen-item header{display:flex;justify-content:space-between;gap:8px;font-size:.76rem}.autoruns-autogen-item p{margin:0;color:var(--text-muted);white-space:pre-wrap;font-size:.8rem}.autoruns-run-launch-btn{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.autoruns-run-launch-btn:hover{background:rgb(var(--rgb-surface-focus));color:rgb(var(--rgb-text-main))}.autoruns-run-launch-btn:disabled{background:rgba(var(--rgb-active),.38);color:rgba(var(--rgb-active-text),.88)}.autoruns-generated-questions{border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:8px;display:grid;gap:8px}.autoruns-generated-questions-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.autoruns-generated-questions-list{display:grid;gap:6px;max-height:220px;overflow:auto;padding-right:2px}.autoruns-generated-question-item{position:relative;display:block;gap:8px;border:none;border-radius:9px;background:rgb(var(--rgb-surface-focus));padding:7px 30px 7px 8px;font-size:.78rem}.autoruns-generated-question-item span{display:block;white-space:pre-wrap}.autoruns-remove-question-btn{position:absolute;top:6px;right:6px;flex:0 0 auto;border:none;border-radius:0;background:transparent;color:rgb(var(--rgb-text-main));min-width:16px;width:16px;height:16px;padding:0;font-size:1rem;font-weight:700;line-height:1;display:inline-flex;align-items:center;justify-content:center;transform:rotate(45deg);box-shadow:none;transition:color .15s ease}.autoruns-remove-question-btn:hover{background:transparent;color:rgb(var(--rgb-active-text));box-shadow:none}.autoruns-remove-question-btn:focus-visible{outline:none}.autoruns-personality-prompt{resize:vertical;min-height:110px}.autoruns-comment-item{width:100%;text-align:left;border-radius:12px;border:none;background:rgb(var(--rgb-surface-horizontal));color:var(--text-main);padding:9px;display:grid;gap:6px;cursor:pointer}.autoruns-comment-item p{margin:0;white-space:pre-wrap;color:var(--text-muted);font-size:.79rem}.autoruns-comment-item.selected{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.autoruns-comment-item.selected p,.autoruns-comment-item.selected .autoruns-run-meta,.autoruns-comment-item.selected .muted{color:rgba(var(--rgb-active-text),.94)}.autoruns-comment-item.selected .autoruns-resolve-toggle{background:rgba(var(--rgb-active-text),.18);color:rgb(var(--rgb-active-text))}.autoruns-comment-head{display:flex;justify-content:space-between;align-items:center;gap:8px;font-size:.75rem}.autoruns-comment-head-actions{display:inline-flex;align-items:center;gap:8px}.autoruns-comment-filter-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:10px;margin-bottom:8px}.autoruns-resolved-filter-toggle{min-height:38px;white-space:nowrap}.autoruns-msg.assistant{margin-right:12%}.autoruns-msg.user{margin-left:12%;border-color:transparent;background:rgb(var(--rgb-surface-focus))}.autoruns-decomposition-list{margin:0;padding-left:18px;display:grid;gap:7px;font-size:.8rem}.autoruns-comment-modal-backdrop{position:fixed;inset:0;background:rgba(var(--rgb-background),.74);display:grid;place-items:center;z-index:1800;padding:12px}.autoruns-comment-modal{width:min(660px,100%);border:none;border-radius:16px;background:rgb(var(--rgb-surface-horizontal));box-shadow:var(--shadow);padding:14px;display:grid;gap:10px}.autoruns-comment-modal h3{margin:0;font-size:.95rem}.autoruns-comment-quote{margin:0;border:none;border-radius:10px;background:rgb(var(--rgb-surface-focus));padding:8px;white-space:pre-wrap;max-height:150px;overflow:auto;font-size:.82rem}.autoruns-rating-row{display:flex;gap:8px}.autoruns-rating-dot{width:34px;height:34px;border-radius:999px;padding:0;border:none;background:rgb(var(--rgb-surface-focus));color:var(--text-muted);font-size:.95rem;box-shadow:none;transform:none}.autoruns-rating-dot:hover{border-color:var(--line-strong);box-shadow:none;transform:none}.autoruns-rating-dot.active{border-color:var(--line-strong);color:rgb(var(--rgb-active-text));background:rgb(var(--rgb-active))}.autoruns-coverage-list{display:grid;gap:8px}.autoruns-coverage-item{border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:8px}.autoruns-coverage-head{display:flex;justify-content:space-between;gap:8px;font-size:.76rem;margin-bottom:5px}.autoruns-coverage-head span{color:var(--text-muted)}.autoruns-coverage-bar{height:7px;border-radius:999px;background:rgb(var(--rgb-surface-focus));overflow:hidden}.autoruns-coverage-bar>div{height:100%;border-radius:999px;background:rgb(var(--rgb-active))}@media(max-width:1200px){:root{--mode-column-width: 400px}.metrics-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:920px){:root{--mode-column-width: 360px}.grid-two,.runtime-grid,.runtime-stack{grid-template-columns:1fr}.metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.autoruns-form-grid,.autoruns-dialog-toolbar,.autoruns-stats-grid,.autoruns-comment-filter-row{grid-template-columns:1fr}}@media(max-width:640px){:root{--mode-column-width: 320px}.app-root{padding:18px 12px 24px}.metrics-grid{grid-template-columns:1fr}}@keyframes rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}} diff --git a/llm_normalizer/frontend/dist/assets/index-Dcuz1nX5.css b/llm_normalizer/frontend/dist/assets/index-Dcuz1nX5.css new file mode 100644 index 0000000..01e4d50 --- /dev/null +++ b/llm_normalizer/frontend/dist/assets/index-Dcuz1nX5.css @@ -0,0 +1 @@ +@import"https://fonts.googleapis.com/css2?family=Manrope:wght@400;600;700;800&family=Space+Grotesk:wght@500;700&display=swap";:root{--rgb-background: 16, 16, 19;--rgb-surface-main: 26, 26, 31;--rgb-surface-horizontal: 32, 32, 38;--rgb-surface-focus: 40, 40, 47;--rgb-assistant-chip: 18, 18, 18;--rgb-assistant-chip-hover: 44, 44, 44;--rgb-assistant-chip-selected: 228, 142, 92;--rgb-assistant-chip-selected-text: 18, 18, 18;--rgb-active: 228, 142, 92;--rgb-active-text: 18, 18, 18;--rgb-text-main: 240, 240, 240;--rgb-text-muted: 166, 166, 170;--rgb-danger: 255, 126, 126;--rgb-scrollbar-track: 31, 31, 36;--rgb-scrollbar-thumb: 74, 74, 82;--rgb-scrollbar-thumb-hover: 90, 90, 100;--mode-column-width: 440px;--mode-toggle-width: 188px;--bg-main: rgb(var(--rgb-background));--bg-soft: rgb(var(--rgb-surface-main));--bg-panel: rgb(var(--rgb-surface-main));--bg-panel-accent: rgb(var(--rgb-surface-horizontal));--surface-horizontal: rgb(var(--rgb-surface-horizontal));--surface-focus: rgb(var(--rgb-surface-focus));--line: transparent;--line-strong: rgba(var(--rgb-active), .48);--text-main: rgb(var(--rgb-text-main));--text-muted: rgb(var(--rgb-text-muted));--lime-main: rgb(var(--rgb-text-main));--lime-press: rgb(var(--rgb-text-main));--danger: rgb(var(--rgb-danger));--radius-lg: 20px;--radius-md: 14px;--shadow: none;--autoruns-col-width: var(--mode-column-width)}*{box-sizing:border-box;scrollbar-width:thin;scrollbar-color:rgb(var(--rgb-scrollbar-thumb)) rgb(var(--rgb-scrollbar-track))}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-track{background:rgb(var(--rgb-scrollbar-track))}*::-webkit-scrollbar-thumb{background:rgb(var(--rgb-scrollbar-thumb));border-radius:999px;border:2px solid rgb(var(--rgb-scrollbar-track))}*::-webkit-scrollbar-thumb:hover{background:rgb(var(--rgb-scrollbar-thumb-hover))}html,body,#root{margin:0;min-height:100dvh;font-family:Manrope,Segoe UI,sans-serif;background:var(--bg-main);color:var(--text-main)}.app-root{max-width:1720px;margin:0 auto;padding:12px 16px 16px}.app-root.app-root-autoruns{max-width:none;width:100%;min-height:100dvh;max-height:100dvh;display:flex;flex-direction:column;overflow:hidden}.app-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 0 12px;padding:0;min-height:38px}.layout-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:16px}.layout-grid.layout-grid-autoruns,.layout-grid.layout-grid-mode-columns{min-height:0;flex:1 1 auto;grid-template-columns:minmax(0,1fr)}.mode-switch-row{display:flex;gap:8px;margin:0;padding:0}.mode-switch-row.mode-switch-row-right{margin-left:auto;justify-content:flex-end;max-width:72%;overflow-x:auto;overflow-y:hidden;padding-bottom:2px}.mode-switch-row .tab{white-space:nowrap}.mode-switch-row.mode-switch-row-right .tab{width:var(--mode-toggle-width);min-width:var(--mode-toggle-width);text-align:center}.mode-columns{display:flex;gap:12px;width:100%;min-height:0;flex:1 1 auto;overflow-x:auto;overflow-y:hidden;padding-bottom:4px}.mode-col{flex:0 0 var(--mode-column-width);width:var(--mode-column-width);min-height:0;height:100%;display:flex}.mode-col.mode-col-wide,.mode-col.mode-col-xwide{flex-basis:var(--mode-column-width);width:var(--mode-column-width)}.mode-col .panel-frame{width:100%;height:100%}.mode-col .panel-body{min-height:0;overflow:auto}.mode-columns-empty{min-width:360px;border-radius:14px;background:rgb(var(--rgb-surface-main));color:var(--text-muted);padding:14px}.panel-frame{grid-column:span 12;border:none;border-radius:var(--radius-lg);background:var(--bg-panel);overflow:hidden;box-shadow:none;animation:rise .4s ease-out;display:flex;flex-direction:column;min-height:0}.panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:14px 18px 10px;border-bottom:none;background:var(--bg-panel-accent)}.panel-header h2{margin:0;font-size:1.02rem;letter-spacing:.02em}.panel-header p{margin:6px 0 0;font-size:.85rem;color:var(--text-muted)}.panel-body{padding:10px 12px 12px;min-height:0}.app-root-autoruns .autoruns-frame{height:100%}.app-root-autoruns .autoruns-frame .panel-body{flex:1 1 auto;overflow:hidden;display:flex;flex-direction:column;gap:10px;padding:10px 12px 12px;background:rgb(var(--rgb-background))}.status-chip{border:none;border-radius:999px;padding:4px 10px;color:var(--lime-main);font-size:.78rem;background:rgb(var(--rgb-surface-focus))}.assistant-toolbar{display:grid;gap:8px}.assistant-toolbar-actions{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));align-items:center;gap:8px}.assistant-toolbar-meta{display:flex;align-items:center;justify-content:space-between;gap:8px}.assistant-toolbar-meta-right{margin-left:auto;display:flex;align-items:center;justify-content:flex-end;gap:8px;min-width:0;flex-wrap:wrap}.assistant-live-status{color:var(--text-muted);font-size:.8rem;white-space:nowrap}.assistant-toolbar-error{margin:0}.assistant-copy-btn{width:100%;justify-self:stretch;background:transparent;border-color:transparent;color:var(--text-main);font-size:.6rem;line-height:1.1;white-space:nowrap;text-align:center;letter-spacing:0;padding:6px 8px;box-shadow:none;transform:none}.assistant-copy-btn:hover{background:rgb(var(--rgb-surface-focus));filter:none;box-shadow:none;transform:none}.assistant-copy-feedback{font-size:.76rem;color:var(--text-muted)}.assistant-copy-feedback.success{color:var(--lime-main)}.assistant-copy-feedback.error{color:var(--danger)}input,select,textarea,button{font-family:Manrope,sans-serif}label{display:flex;flex-direction:column;gap:6px;color:var(--text-muted);font-size:.84rem}input,select,textarea{border:none;border-radius:var(--radius-md);background:rgb(var(--rgb-surface-horizontal));color:var(--text-main);padding:10px 12px;outline:none;transition:background-color .18s ease}input:focus,select:focus,textarea:focus{border-color:transparent;box-shadow:none;outline:none;background:rgb(var(--rgb-surface-focus))}textarea{resize:vertical;min-height:86px;overflow-y:auto;overflow-x:hidden;scrollbar-gutter:stable}.assistant-input-textarea,.autoruns-personality-prompt{overflow-y:auto;overflow-x:hidden;scrollbar-gutter:stable both-edges;border-bottom-right-radius:6px}.assistant-input-textarea::-webkit-scrollbar-corner,.autoruns-personality-prompt::-webkit-scrollbar-corner{background:rgb(var(--rgb-surface-horizontal))}button{border:none;border-radius:999px;background:rgb(var(--rgb-surface-horizontal));color:rgb(var(--rgb-text-main));font-weight:700;font-size:.83rem;letter-spacing:.02em;cursor:pointer;padding:9px 14px;transition:background .2s ease,color .2s ease;outline:none;box-shadow:none}button:hover{border-color:transparent;background:rgb(var(--rgb-surface-focus))}button:disabled{opacity:.52;cursor:not-allowed}.button-row{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-top:12px}.checkbox-row{flex-direction:row;align-items:center;gap:8px;color:var(--text-main)}.grid-two{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.prompt-manager-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:12px}.full-width{grid-column:1 / -1}.tab-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.tab{background:rgb(var(--rgb-surface-main));color:var(--text-main);border:none}.tab.active{border-color:transparent;background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.assistant-chat-list{flex:1 1 auto;min-height:0;overflow:auto;overscroll-behavior:contain;display:flex;flex-direction:column;gap:8px;padding:10px;border:none;border-radius:12px;background:rgb(var(--rgb-surface-horizontal))}.assistant-chat-list .assistant-msg:first-child{margin-top:auto}.assistant-empty{padding:18px;text-align:center}.assistant-msg{border:none;border-radius:12px;background:rgb(var(--rgb-surface-focus));padding:8px 10px;display:grid;gap:6px;min-width:0}.assistant-msg.user{margin-left:12%;border-color:transparent;background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.assistant-msg.assistant{margin-right:12%;border-color:transparent}.assistant-msg.user .assistant-msg-head{color:rgba(var(--rgb-active-text),.9)}.assistant-msg.user .assistant-msg-body{color:rgb(var(--rgb-active-text))}.assistant-msg-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:0;font-size:.74rem;color:var(--text-muted)}.assistant-msg-head-main{flex:1 1 auto;min-width:0;display:flex;align-items:center;justify-content:space-between;gap:8px}.assistant-msg-head-actions{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}.assistant-comment-btn{cursor:pointer}.assistant-comment-btn:disabled{opacity:.42;cursor:not-allowed}.assistant-msg.user .assistant-comment-btn{color:rgba(var(--rgb-active-text),.92)}.assistant-msg-body{display:grid;gap:10px;line-height:1.35;font-size:.84rem;min-width:0}.assistant-msg-block{display:grid;gap:4px;min-width:0}.assistant-msg-block.selectable{cursor:pointer;padding:8px 10px;border-radius:12px;transition:background .18s ease,color .18s ease}.assistant-msg-block.selectable:hover,.assistant-msg-block.selectable:focus-visible{background:rgba(var(--rgb-active),.18);outline:none}.assistant-msg-block.selectable.active{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.assistant-msg-block.selectable.active:hover,.assistant-msg-block.selectable.active:focus-visible{background:rgb(var(--rgb-active))}.assistant-msg-block.selectable.active .assistant-msg-line,.assistant-msg-block.selectable.active .assistant-msg-line strong{color:rgb(var(--rgb-active-text))}.assistant-msg-line{margin:0;white-space:pre-wrap;word-break:break-word;overflow-wrap:anywhere}.assistant-msg-line.heading{font-weight:700;letter-spacing:.01em}.assistant-msg-line.numbered{margin-top:2px}.assistant-msg-line strong{font-weight:800}.assistant-trace{margin-top:6px;color:var(--text-muted);font-size:.75rem}.assistant-debug{margin-top:8px}.assistant-debug summary{cursor:pointer;color:var(--lime-main);font-size:.8rem}.assistant-compose{margin-top:0;display:grid;gap:8px;flex:0 0 auto}.assistant-compose-context{display:grid;gap:6px;padding:10px 12px;border-radius:var(--radius-md);background:rgb(var(--rgb-surface-horizontal))}.assistant-compose-context-label{color:var(--text-muted);font-size:.74rem;font-weight:700;letter-spacing:.01em}.assistant-compose-context-pill{display:inline-flex;align-items:center;gap:8px;max-width:100%;width:fit-content;min-height:38px;padding:0 10px 0 12px;border-radius:999px;background:rgb(var(--rgb-assistant-chip-selected));color:rgb(var(--rgb-assistant-chip-selected-text))}.assistant-compose-context-pill-text{min-width:0;max-width:min(100%,460px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.82rem;font-weight:700}.assistant-compose-context-clear{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;min-width:24px;padding:0;border-radius:999px;background:#0000002e;color:inherit;font-size:.96rem;line-height:1}.assistant-compose-context-clear:hover{background:#00000047}.assistant-send-row{align-items:center;margin-top:2px}.assistant-send-btn{margin-left:auto}.assistant-comments-frame .panel-body{display:flex;flex-direction:column;min-height:0;overflow:hidden}.assistant-comments-shell{display:grid;gap:8px;min-height:0;height:100%}.assistant-comments-toolbar{display:flex;align-items:center;justify-content:space-between;gap:8px}.assistant-comments-list{display:grid;gap:8px;overflow:auto;min-height:0;padding-right:2px}.assistant-comment-item{border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:8px;display:grid;gap:6px}.assistant-comment-head{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:.75rem}.assistant-comment-item p{margin:0;white-space:pre-wrap;font-size:.8rem}.assistant-comment-meta{display:flex;flex-wrap:wrap;gap:8px;color:var(--text-muted);font-size:.74rem}.app-root-autoruns .assistant-panel-frame .panel-header{position:sticky;top:-12px;z-index:8;margin:-12px -12px 0;padding:12px 12px 10px;background:rgb(var(--rgb-surface-main))}.app-root-autoruns .assistant-panel-frame{overflow:visible}.app-root-autoruns .assistant-panel-frame .panel-body{flex:1 1 auto;padding:0 12px 12px;display:flex;flex-direction:column;min-height:0;overflow:hidden}.app-root-autoruns .assistant-panel-frame .assistant-live-shell{flex:1 1 auto;min-height:0;padding:12px;border-radius:14px;background:rgb(var(--rgb-background));display:flex;flex-direction:column;gap:10px}.app-root-autoruns .assistant-panel-frame .assistant-chat-list{overflow-y:auto}.app-root-autoruns .assistant-panel-frame .panel-header h2{margin:0;font-size:.95rem}.json-view{margin:0;width:100%;min-height:180px;max-height:420px;overflow:auto;background:rgb(var(--rgb-surface-horizontal));border:none;border-radius:var(--radius-md);padding:12px;color:rgb(var(--rgb-text-main));font-family:JetBrains Mono,Consolas,monospace;font-size:.78rem;line-height:1.45}.metrics-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.metrics-grid div{background:rgba(var(--rgb-surface-main),.8);border:none;border-radius:12px;padding:10px;display:flex;flex-direction:column;gap:4px}.metrics-grid span{color:var(--text-muted);font-size:.75rem}.metrics-grid strong{font-size:.84rem;color:var(--lime-main)}.history-list{display:grid;gap:8px;max-height:340px;overflow:auto}.history-item{width:100%;text-align:left;border-radius:12px;border:none;background:rgb(var(--rgb-surface-main));color:var(--text-main);padding:10px}.history-item p{margin:8px 0;color:var(--text-muted);font-size:.82rem}.history-item.selected{border-color:var(--line-strong)}.history-row{display:flex;justify-content:space-between;gap:8px;font-size:.76rem;color:var(--text-muted)}.runtime-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:12px}.runtime-stack{display:grid;grid-template-columns:minmax(0,1fr);gap:12px}.runtime-details{display:grid;gap:12px}.runtime-runs{max-height:360px;overflow:auto;display:grid;gap:8px}.eval-report-wrap{position:relative}.copy-cube-button{position:absolute;right:10px;bottom:10px;width:34px;height:34px;border-radius:10px;padding:0;min-width:34px;display:grid;place-items:center;font-size:.92rem;line-height:1}.muted{color:var(--text-muted)}.diff-summary{margin-top:10px;font-size:.82rem;color:var(--lime-main)}.error-text{margin-top:10px;color:var(--danger);font-size:.84rem}.autoruns-columns{display:flex;gap:12px;width:100%;min-height:0;flex:1 1 auto;overflow-x:auto;overflow-y:hidden;padding-bottom:4px}.autoruns-col{flex:0 0 var(--mode-column-width);width:var(--mode-column-width);height:100%;min-height:0;overflow-y:auto;overflow-x:hidden;border:none;border-radius:14px;background:rgb(var(--rgb-surface-main));padding:12px;scrollbar-gutter:stable}.autoruns-assistant-live-col{background:rgb(var(--rgb-surface-main));padding:12px;overflow:hidden;scrollbar-gutter:auto}.autoruns-assistant-live-col .panel-frame{height:100%;background:rgb(var(--rgb-surface-main))}.autoruns-col h3{margin:0;font-size:.95rem}.autoruns-col h4{margin:12px 0 8px;font-size:.82rem;color:var(--text-muted)}.autoruns-col-header{position:sticky;top:-12px;z-index:8;margin:-12px -12px 10px;padding:12px 12px 10px;background:rgb(var(--rgb-surface-main))}.autoruns-col-header .tab-row{margin:8px 0 0}.autoruns-col-header .autoruns-dialog-toolbar{margin-top:8px}.autoruns-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.autoruns-meta-list{display:grid;gap:8px}.autoruns-meta-list>div{display:flex;justify-content:space-between;gap:8px;border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:8px 9px;font-size:.79rem}.autoruns-meta-list span{color:var(--text-muted)}.autoruns-prompt-details summary{cursor:pointer;color:var(--text-main);font-size:.8rem;margin-bottom:8px}.autoruns-prompt-details textarea{min-height:68px}.autoruns-stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-bottom:10px}.autoruns-stats-grid>div{border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:8px;display:grid;gap:3px}.autoruns-stats-grid span{color:var(--text-muted);font-size:.74rem}.autoruns-stats-grid strong{color:var(--lime-main);font-size:.84rem}.autoruns-run-list{display:grid;gap:8px;max-height:none;min-height:0;flex:1 1 auto;overflow:auto;padding-right:2px}.autoruns-run-item{width:100%;text-align:left;border-radius:12px;border:none;background:rgb(var(--rgb-surface-horizontal));color:var(--text-main);padding:10px;display:grid;gap:5px;transition:background-color .2s ease,box-shadow .2s ease}.autoruns-run-item.selected{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text));box-shadow:none}.autoruns-run-item.selected .autoruns-run-meta{color:rgba(var(--rgb-active-text),.95)}.autoruns-run-head,.autoruns-run-foot{display:flex;justify-content:space-between;gap:8px;font-size:.76rem}.autoruns-run-meta{color:var(--text-muted);font-size:.75rem;word-break:break-word}.autoruns-run-id-row{display:flex;align-items:center;justify-content:space-between;gap:8px;min-width:0}.autoruns-run-id-row>span{min-width:0;overflow-wrap:anywhere;word-break:break-word}.autoruns-copy-run-id-btn{border:none;background:transparent;color:rgb(var(--rgb-text-main));width:16px;height:16px;min-width:16px;min-height:16px;padding:0;display:inline-flex;align-items:center;justify-content:center;border-radius:4px;opacity:.92;cursor:pointer}.autoruns-copy-run-id-btn:hover{color:rgb(var(--rgb-text-main));opacity:1;background:transparent;box-shadow:none;transform:none}.autoruns-copy-run-id-btn:focus-visible{outline:1px solid rgba(var(--rgb-text-main),.7);outline-offset:1px}.autoruns-copy-icon-svg{width:.82rem;height:.82rem;fill:none;stroke:currentColor;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round}.autoruns-dialog-toolbar{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.autoruns-case-list{margin-top:8px;display:grid;gap:6px;max-height:180px;overflow:auto}.autoruns-case-item{width:100%;text-align:left;border-radius:10px;border:none;background:rgb(var(--rgb-surface-horizontal));color:var(--text-main);padding:7px 8px;display:flex;justify-content:space-between;gap:6px;font-size:.76rem}.autoruns-case-item.selected{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text));box-shadow:none}.autoruns-dialog-view{margin-top:10px;border:none;border-radius:12px;background:rgb(var(--rgb-surface-horizontal));padding:10px;max-height:none;min-height:0;flex:1 1 auto;overflow:auto;display:grid;gap:8px}.autoruns-msg{border:none;border-radius:12px;background:rgb(var(--rgb-surface-focus));padding:8px 10px;display:grid;gap:6px;min-width:0;overflow:hidden}.autoruns-msg header,.autoruns-msg footer{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;min-width:0;gap:8px;font-size:.74rem;color:var(--text-muted)}.autoruns-msg-head-actions{display:flex;align-items:center;justify-content:flex-end;flex:1 1 auto;min-width:0;flex-wrap:wrap;gap:8px}.autoruns-msg-head-actions>span{min-width:0;overflow-wrap:anywhere;word-break:break-word}.autoruns-msg-case-tag{display:inline-flex;align-items:center;border-radius:999px;padding:2px 8px;font-size:.7rem;line-height:1;color:rgb(var(--rgb-active-text));background:rgba(var(--rgb-active),.24)}.autoruns-msg p{margin:0;white-space:pre-wrap;line-height:1.35;font-size:.84rem;overflow-wrap:anywhere;word-break:break-word}.autoruns-msg footer span{min-width:0;overflow-wrap:anywhere;word-break:break-word}.autoruns-comment-icon{border:none;background:transparent;color:rgb(var(--rgb-text-main));border-radius:0;min-width:16px;min-height:16px;width:16px;height:16px;padding:0;line-height:1;box-shadow:none;transform:none;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;opacity:.92}.autoruns-comment-icon:hover{background:transparent;color:rgb(var(--rgb-text-main));opacity:1;box-shadow:none;transform:none}.autoruns-comment-icon.commented{color:rgb(var(--rgb-active));background:transparent;box-shadow:none}.autoruns-comment-icon:focus-visible{outline:1px solid rgba(var(--rgb-text-main),.7);outline-offset:1px}.autoruns-comment-icon:disabled{opacity:.42;cursor:not-allowed}.comment-icon-svg{width:.82rem;height:.82rem;stroke:currentColor;stroke-width:1.75;stroke-linecap:round;stroke-linejoin:round;fill:none}.comment-icon-svg.commented{stroke:rgb(var(--rgb-active));fill:none}.autoruns-resolve-toggle{border:none;background:rgb(var(--rgb-surface-focus));color:rgb(var(--rgb-text-main));border-radius:999px;width:22px;height:22px;min-width:22px;min-height:22px;padding:0;display:inline-flex;align-items:center;justify-content:center;box-shadow:none;transform:none}.autoruns-resolve-toggle:hover{background:rgb(var(--rgb-surface-focus));color:rgb(var(--rgb-active));box-shadow:none;transform:none}.autoruns-resolve-toggle:disabled{opacity:.55;cursor:wait}.autoruns-resolve-toggle.resolved{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.resolve-icon-svg{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}.resolve-icon-svg.resolved{fill:currentColor}.autoruns-msg-annotation{display:grid;gap:4px;border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:7px 8px;font-size:.78rem}.autoruns-comments-list{display:grid;gap:8px;max-height:none;min-height:0;flex:1 1 auto;overflow:auto;padding-right:2px;margin-top:6px}.autoruns-autogen-list{display:grid;gap:8px;max-height:none;min-height:0;overflow:auto;padding-right:2px}.autoruns-autogen-item{border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:8px;display:grid;gap:5px;cursor:pointer}.autoruns-autogen-item.selected{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.autoruns-autogen-item.selected .autoruns-run-meta,.autoruns-autogen-item.selected p{color:rgba(var(--rgb-active-text),.95)}.autoruns-autogen-item header{display:flex;justify-content:space-between;gap:8px;font-size:.76rem}.autoruns-autogen-item p{margin:0;color:var(--text-muted);white-space:pre-wrap;font-size:.8rem}.autoruns-run-launch-btn{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.autoruns-run-launch-btn:hover{background:rgb(var(--rgb-surface-focus));color:rgb(var(--rgb-text-main))}.autoruns-run-launch-btn:disabled{background:rgba(var(--rgb-active),.38);color:rgba(var(--rgb-active-text),.88)}.autoruns-generated-questions{border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:8px;display:grid;gap:8px}.autoruns-generated-questions-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.autoruns-generated-questions-list{display:grid;gap:6px;max-height:220px;overflow:auto;padding-right:2px}.autoruns-generated-question-item{position:relative;display:block;gap:8px;border:none;border-radius:9px;background:rgb(var(--rgb-surface-focus));padding:7px 30px 7px 8px;font-size:.78rem}.autoruns-generated-question-item span{display:block;white-space:pre-wrap}.autoruns-remove-question-btn{position:absolute;top:6px;right:6px;flex:0 0 auto;border:none;border-radius:0;background:transparent;color:rgb(var(--rgb-text-main));min-width:16px;width:16px;height:16px;padding:0;font-size:1rem;font-weight:700;line-height:1;display:inline-flex;align-items:center;justify-content:center;transform:rotate(45deg);box-shadow:none;transition:color .15s ease}.autoruns-remove-question-btn:hover{background:transparent;color:rgb(var(--rgb-active-text));box-shadow:none}.autoruns-remove-question-btn:focus-visible{outline:none}.autoruns-personality-prompt{resize:vertical;min-height:110px}.autoruns-comment-item{width:100%;text-align:left;border-radius:12px;border:none;background:rgb(var(--rgb-surface-horizontal));color:var(--text-main);padding:9px;display:grid;gap:6px;cursor:pointer}.autoruns-comment-item p{margin:0;white-space:pre-wrap;color:var(--text-muted);font-size:.79rem}.autoruns-comment-item.selected{background:rgb(var(--rgb-active));color:rgb(var(--rgb-active-text))}.autoruns-comment-item.selected p,.autoruns-comment-item.selected .autoruns-run-meta,.autoruns-comment-item.selected .muted{color:rgba(var(--rgb-active-text),.94)}.autoruns-comment-item.selected .autoruns-resolve-toggle{background:rgba(var(--rgb-active-text),.18);color:rgb(var(--rgb-active-text))}.autoruns-comment-head{display:flex;justify-content:space-between;align-items:center;gap:8px;font-size:.75rem}.autoruns-comment-head-actions{display:inline-flex;align-items:center;gap:8px}.autoruns-comment-filter-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:10px;margin-bottom:8px}.autoruns-resolved-filter-toggle{min-height:38px;white-space:nowrap}.autoruns-msg.assistant{margin-right:12%}.autoruns-msg.user{margin-left:12%;border-color:transparent;background:rgb(var(--rgb-surface-focus))}.autoruns-decomposition-list{margin:0;padding-left:18px;display:grid;gap:7px;font-size:.8rem}.autoruns-comment-modal-backdrop{position:fixed;inset:0;background:rgba(var(--rgb-background),.74);display:grid;place-items:center;z-index:1800;padding:12px}.autoruns-comment-modal{width:min(660px,100%);border:none;border-radius:16px;background:rgb(var(--rgb-surface-horizontal));box-shadow:var(--shadow);padding:14px;display:grid;gap:10px}.autoruns-comment-modal h3{margin:0;font-size:.95rem}.autoruns-comment-quote{margin:0;border:none;border-radius:10px;background:rgb(var(--rgb-surface-focus));padding:8px;white-space:pre-wrap;max-height:150px;overflow:auto;font-size:.82rem}.autoruns-rating-row{display:flex;gap:8px}.autoruns-rating-dot{width:34px;height:34px;border-radius:999px;padding:0;border:none;background:rgb(var(--rgb-surface-focus));color:var(--text-muted);font-size:.95rem;box-shadow:none;transform:none}.autoruns-rating-dot:hover{border-color:var(--line-strong);box-shadow:none;transform:none}.autoruns-rating-dot.active{border-color:var(--line-strong);color:rgb(var(--rgb-active-text));background:rgb(var(--rgb-active))}.autoruns-coverage-list{display:grid;gap:8px}.autoruns-coverage-item{border:none;border-radius:10px;background:rgb(var(--rgb-surface-horizontal));padding:8px}.autoruns-coverage-head{display:flex;justify-content:space-between;gap:8px;font-size:.76rem;margin-bottom:5px}.autoruns-coverage-head span{color:var(--text-muted)}.autoruns-coverage-bar{height:7px;border-radius:999px;background:rgb(var(--rgb-surface-focus));overflow:hidden}.autoruns-coverage-bar>div{height:100%;border-radius:999px;background:rgb(var(--rgb-active))}@media(max-width:1200px){:root{--mode-column-width: 400px}.metrics-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:920px){:root{--mode-column-width: 360px}.grid-two,.runtime-grid,.runtime-stack{grid-template-columns:1fr}.metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.autoruns-form-grid,.autoruns-dialog-toolbar,.autoruns-stats-grid,.autoruns-comment-filter-row{grid-template-columns:1fr}}@media(max-width:640px){:root{--mode-column-width: 320px}.app-root{padding:18px 12px 24px}.metrics-grid{grid-template-columns:1fr}}@keyframes rise{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}} diff --git a/llm_normalizer/frontend/dist/index.html b/llm_normalizer/frontend/dist/index.html index 509d45a..ebd74c8 100644 --- a/llm_normalizer/frontend/dist/index.html +++ b/llm_normalizer/frontend/dist/index.html @@ -4,8 +4,8 @@ NDC AI Normalizer Playground - - + +
diff --git a/llm_normalizer/frontend/src/App.tsx b/llm_normalizer/frontend/src/App.tsx index e3b53ce..50bd6f4 100644 --- a/llm_normalizer/frontend/src/App.tsx +++ b/llm_normalizer/frontend/src/App.tsx @@ -16,6 +16,7 @@ import { designConfig } from "../../../designconfig"; import type { AssistantConversationItem, AssistantAnnotationRecord, + AssistantSelectionChip, ConnectionState, HistoryItem, NormalizeResultState, @@ -60,6 +61,25 @@ function diffPrompts(current: PromptState, previous: PromptState | null): string return `Changed fields: ${changed.length}. ${changed.join(" | ")}`; } +function buildAssistantFollowupMessage(inputValue: string, selectedChip: AssistantSelectionChip | null): string { + const trimmedInput = inputValue.trim(); + if (!trimmedInput) { + return ""; + } + if (!selectedChip) { + return trimmedInput; + } + + const normalizedInput = trimmedInput.toLowerCase(); + const selectionAnchor = selectedChip.anchor_text.trim(); + const normalizedSelection = selectionAnchor.toLowerCase(); + if (normalizedSelection && normalizedInput.includes(normalizedSelection)) { + return trimmedInput; + } + + return `По выбранному объекту "${selectionAnchor}": ${trimmedInput}`; +} + export default function App() { const [connection, setConnection] = useState(DEFAULT_CONNECTION); const [prompts, setPrompts] = useState(DEFAULT_PROMPTS); @@ -116,6 +136,7 @@ export default function App() { const [assistantSessionId, setAssistantSessionId] = useState(""); const [assistantConversation, setAssistantConversation] = useState([]); const [assistantInput, setAssistantInput] = useState(""); + const [assistantSelectedChip, setAssistantSelectedChip] = useState(null); const [assistantBusy, setAssistantBusy] = useState(false); const [assistantStatus, setAssistantStatus] = useState(""); const [assistantError, setAssistantError] = useState(""); @@ -140,6 +161,10 @@ export default function App() { root.style.setProperty("--rgb-surface-main", colors.mainSurfaceRgb); root.style.setProperty("--rgb-surface-horizontal", colors.horizontalSurfaceRgb); root.style.setProperty("--rgb-surface-focus", colors.focusSurfaceRgb); + root.style.setProperty("--rgb-assistant-chip", colors.assistantChipRgb); + root.style.setProperty("--rgb-assistant-chip-hover", colors.assistantChipHoverRgb); + root.style.setProperty("--rgb-assistant-chip-selected", colors.assistantChipSelectedRgb); + root.style.setProperty("--rgb-assistant-chip-selected-text", colors.assistantChipSelectedTextRgb); root.style.setProperty("--rgb-active", colors.activeRgb); root.style.setProperty("--rgb-active-text", colors.activeTextRgb); root.style.setProperty("--rgb-text-main", colors.textMainRgb); @@ -785,6 +810,7 @@ export default function App() { setAssistantSessionId(""); setAssistantConversation([]); setAssistantInput(""); + setAssistantSelectedChip(null); setAssistantStatus(""); setAssistantError(""); setAssistantAnnotations([]); @@ -793,7 +819,7 @@ export default function App() { } async function sendAssistantMessage() { - const userMessage = assistantInput.trim(); + const userMessage = buildAssistantFollowupMessage(assistantInput, assistantSelectedChip); if (!userMessage) { return; } @@ -1035,6 +1061,9 @@ export default function App() { conversation={assistantConversation} inputValue={assistantInput} onInputChange={setAssistantInput} + selectedContextChip={assistantSelectedChip} + onSelectContextChip={setAssistantSelectedChip} + onClearContextChip={() => setAssistantSelectedChip(null)} useMock={useMock} onUseMockChange={setUseMock} onSend={sendAssistantMessage} diff --git a/llm_normalizer/frontend/src/components/AssistantPanel.tsx b/llm_normalizer/frontend/src/components/AssistantPanel.tsx index 9757747..871054f 100644 --- a/llm_normalizer/frontend/src/components/AssistantPanel.tsx +++ b/llm_normalizer/frontend/src/components/AssistantPanel.tsx @@ -1,5 +1,5 @@ import { useEffect, useRef, useState } from "react"; -import type { AssistantConversationItem } from "../state/types"; +import type { AssistantConversationItem, AssistantSelectionChip } from "../state/types"; import { buildConversationExportForCopy } from "../utils/conversationExport"; import { JsonView } from "./JsonView"; import { PanelFrame } from "./PanelFrame"; @@ -9,6 +9,9 @@ interface AssistantPanelProps { conversation: AssistantConversationItem[]; inputValue: string; onInputChange: (value: string) => void; + selectedContextChip: AssistantSelectionChip | null; + onSelectContextChip: (value: AssistantSelectionChip) => void; + onClearContextChip: () => void; useMock: boolean; onUseMockChange: (value: boolean) => void; onSend: () => Promise | void; @@ -147,17 +150,134 @@ function lineClassName(line: string): string { return "assistant-msg-line"; } -function renderAssistantMessageBody(text: string): JSX.Element[] { - const blocks = splitAssistantMessageBlocks(text); +function buildSelectionPreview(label: string, maxChars = 40): string { + const normalized = label.replace(/\s+/g, " ").trim(); + if (normalized.length <= maxChars) { + return normalized; + } + + const firstWords = normalized.split(" ").slice(0, 3).join(" ").trim(); + if (firstWords.length >= 10 && firstWords.length <= maxChars) { + return `${firstWords}…`; + } + + return `${normalized.slice(0, maxChars - 1).trimEnd()}…`; +} + +function stripBlockSelectionPrefix(line: string): string { + return line.replace(/\*\*(.+?)\*\*/g, "$1").replace(/^\d+\.\s*/, "").trim(); +} + +function extractSelectionAnchorText(block: string): string { + const firstLine = block + .replace(/\r\n?/g, "\n") + .split("\n") + .map((line) => line.trim()) + .find(Boolean); + const normalizedFirstLine = stripBlockSelectionPrefix(firstLine ?? ""); + const primarySegment = normalizedFirstLine.split("|")[0]?.trim() ?? normalizedFirstLine; + return primarySegment.replace(/\s+/g, " ").trim(); +} + +function isSelectableEntityBlock(block: string): boolean { + const firstLine = block + .replace(/\r\n?/g, "\n") + .split("\n") + .map((line) => line.trim()) + .find(Boolean); + if (!firstLine || !/^\d+\.\s/.test(firstLine)) { + return false; + } + const normalizedFirstLine = stripBlockSelectionPrefix(firstLine); + return normalizedFirstLine.includes("|"); +} + +function buildSelectionChipForBlock(item: AssistantConversationItem, block: string): AssistantSelectionChip | null { + const normalizedBlock = block + .replace(/\r\n?/g, "\n") + .replace(/\*\*(.+?)\*\*/g, "$1") + .split("\n") + .map((line, index) => { + const trimmed = line.trim(); + if (index === 0) { + return trimmed.replace(/^\d+\.\s*/, ""); + } + return trimmed; + }) + .filter(Boolean) + .join(" ") + .replace(/\s+/g, " ") + .trim(); + + if (!normalizedBlock) { + return null; + } + + const anchorText = extractSelectionAnchorText(block) || normalizedBlock; + return { + message_id: item.message_id, + source_text: normalizedBlock, + anchor_text: anchorText, + preview_text: buildSelectionPreview(anchorText) + }; +} + +function renderAssistantMessageBody( + item: AssistantConversationItem, + selectedContextChip: AssistantSelectionChip | null, + onSelectContextChip: (value: AssistantSelectionChip) => void, + onClearContextChip: () => void +): JSX.Element[] { + const blocks = splitAssistantMessageBlocks(item.text); return blocks.map((block, blockIndex) => { const lines = block.split("\n"); + const isSelectable = item.role === "assistant" && isSelectableEntityBlock(block); + const selectionChip = isSelectable ? buildSelectionChipForBlock(item, block) : null; + const selected = + Boolean(selectionChip) && + selectedContextChip?.message_id === selectionChip?.message_id && + selectedContextChip?.source_text === selectionChip?.source_text; + + const body = lines.map((line, lineIndex) => ( +

+ {renderInlineBold(line, `line-${blockIndex}-${lineIndex}`)} +

+ )); + + if (!isSelectable || !selectionChip) { + return ( +
+ {body} +
+ ); + } + return ( -
- {lines.map((line, lineIndex) => ( -

- {renderInlineBold(line, `line-${blockIndex}-${lineIndex}`)} -

- ))} +
{ + if (selected) { + onClearContextChip(); + return; + } + onSelectContextChip(selectionChip); + }} + onKeyDown={(event) => { + if (event.key !== "Enter" && event.key !== " ") { + return; + } + event.preventDefault(); + if (selected) { + onClearContextChip(); + return; + } + onSelectContextChip(selectionChip); + }} + > + {body}
); }); @@ -168,6 +288,9 @@ export function AssistantPanel({ conversation, inputValue, onInputChange, + selectedContextChip, + onSelectContextChip, + onClearContextChip, useMock, onUseMockChange, onSend, @@ -316,7 +439,9 @@ export function AssistantPanel({
) : null} -
{renderAssistantMessageBody(item.text)}
+
+ {renderAssistantMessageBody(item, selectedContextChip, onSelectContextChip, onClearContextChip)} +
{item.role === "assistant" && item.debug ? (
Показать технический разбор @@ -329,6 +454,23 @@ export function AssistantPanel({
+ {selectedContextChip ? ( +
+ Выбранный объект +
+ {selectedContextChip.preview_text} + +
+
+ ) : null}