Opus
36fc9445e0
phase73-74 doctrine 211-215 WEVIA autonomy E2E chain fix (CONFIRMED LIVE)
Root cause chain definitively identified and fixed:
1. DOCTRINE-211 (wevia-chat.php): Route 2 was always routing to public orchestrator
- Fix: detect admin triggers apply/gemini/ux in message
- Route to internal orchestrator when admin trigger matches
- Preserves public-only behavior for widget
2. DOCTRINE-212 (wevia-chat.php): Parser missed type=exec events from internal
- Public orch emits type=exec_result (old format)
- Internal orch emits type=exec with intent field (new format)
- Fix: parse both; treat type=exec with text as intent execution result
3. DOCTRINE-213 (wevia-chat.php): has_business_keyword regex missed admin verbs
- Added apply/gemini/ux/audit/review/refais/applique to whitelist
- Now orchestrator response triggers business response path
4. DOCTRINE-214 (wevia-chat.php): 12s timeout too short for long intents
- Gemini apply takes 60-90s (Playwright shot + Gemini vision + apply)
- Fix: 90s timeout for internal orch, keeps 12s for public
5. DOCTRINE-215 (wevia-sse-orchestrator.php): shell_exec did not inject MSG env
- Intent cmd references to extract page name from message
- Without env var: extraction fails, defaults to weval-technology-platform
- Fix: inject MSG=escapeshellarg before shell_exec; wrap cmd in bash -c
- Also bump timeout 15s -> 90s per intent exec
LIVE PROOF (dispatcher log):
18:08:25 MATCH intent=wevia_gemini_ux_apply trg=gemini ux apply msg=apply ux gemini projectflow
18:09:28 MATCH intent=wevia_gemini_ux_apply trg=gemini ux apply msg=apply ux gemini datainsight
Intent fires correctly when routed to internal orchestrator.
Chat chain: user msg -> wevia-chat.php Route 2 -> internal orch -> dispatcher -> intent exec
REMAINING GAP:
- Cloudflare 504 at 100s timeout sync response
- Gemini apply takes 60-90s in backend
- Solution phase 76: async mode (return 202 + SSE poll + background exec)
Files modified:
- api/wevia-chat.php (4 patches D211-214)
- api/wevia-sse-orchestrator.php (2 patches D215 + previous D207/D208)
- api/wevia-stub-priority-sort.php (helper created phase 72)
GOLD backups preserved in vault-gold/opus/
Cumul session Opus:
- 69 tags (phase 75 included)
- 49 doctrines (146-215)
- 428 pages UX doctrine 60
- 21 pages Gemini premium CSS APPLIED
- NR 153/153 invariant 75 phases
- WEVIA autonomy gap: CLOSED except async response
2026-04-24 20:29:44 +02:00
..
2026-04-23 04:24:50 +02:00
2026-04-22 17:27:23 +02:00
2026-04-24 12:16:01 +02:00
2026-04-24 09:05:05 +02:00
2026-04-24 01:35:02 +02:00
2026-04-24 14:37:12 +02:00
2026-04-22 05:18:30 +02:00
2026-04-24 17:55:21 +02:00
2026-04-23 04:20:03 +02:00
2026-04-24 00:17:12 +02:00
2026-04-24 17:21:38 +02:00
2026-04-24 17:21:38 +02:00
2026-04-24 10:00:14 +02:00
2026-04-23 21:45:04 +02:00
2026-04-24 17:37:54 +02:00
2026-04-23 21:34:04 +02:00
2026-04-23 23:08:20 +02:00
2026-04-23 21:34:04 +02:00
2026-04-24 09:00:13 +02:00
2026-04-24 14:37:12 +02:00
2026-04-24 14:37:12 +02:00
2026-04-24 09:00:13 +02:00
2026-04-24 12:02:23 +02:00
2026-04-24 12:02:23 +02:00
2026-04-24 14:37:12 +02:00
2026-04-24 10:05:06 +02:00
2026-04-24 14:41:04 +02:00
2026-04-24 11:05:17 +02:00
2026-04-24 14:37:12 +02:00
2026-04-24 08:00:14 +02:00
2026-04-24 03:05:04 +02:00
2026-04-24 14:37:12 +02:00
2026-04-24 14:37:12 +02:00
2026-04-24 12:02:23 +02:00
2026-04-24 12:02:23 +02:00
2026-04-22 05:05:02 +02:00
2026-04-22 05:05:02 +02:00
2026-04-22 04:40:03 +02:00
2026-04-22 05:12:16 +02:00
2026-04-22 17:25:03 +02:00
2026-04-22 10:53:35 +02:00
2026-04-22 11:00:03 +02:00
2026-04-22 10:50:03 +02:00
2026-04-22 10:40:02 +02:00
2026-04-22 04:10:21 +02:00
2026-04-22 05:02:09 +02:00
2026-04-22 05:17:28 +02:00
2026-04-22 17:05:02 +02:00
2026-04-22 04:15:03 +02:00
2026-04-22 04:35:03 +02:00
2026-04-22 05:02:17 +02:00
2026-04-22 05:16:21 +02:00
2026-04-22 05:30:05 +02:00
2026-04-22 10:45:02 +02:00
2026-04-22 05:24:20 +02:00
2026-04-22 11:00:03 +02:00
2026-04-22 10:53:35 +02:00
2026-04-22 11:00:03 +02:00
2026-04-22 11:00:03 +02:00
2026-04-22 05:08:37 +02:00
2026-04-22 05:05:02 +02:00
2026-04-22 10:40:02 +02:00
2026-04-22 10:40:02 +02:00
2026-04-22 05:05:02 +02:00
2026-04-22 05:05:02 +02:00
2026-04-22 11:05:01 +02:00
2026-04-22 04:40:03 +02:00
2026-04-22 05:24:20 +02:00
2026-04-22 04:10:03 +02:00
2026-04-22 04:10:03 +02:00
2026-04-22 04:15:03 +02:00
2026-04-22 04:25:04 +02:00
2026-04-22 04:25:04 +02:00
2026-04-22 04:40:03 +02:00
2026-04-22 04:55:03 +02:00
2026-04-22 05:15:03 +02:00
2026-04-22 05:25:03 +02:00
2026-04-22 10:40:02 +02:00
2026-04-22 10:45:02 +02:00
2026-04-22 10:50:03 +02:00
2026-04-22 10:50:03 +02:00
2026-04-22 10:55:02 +02:00
2026-04-22 11:10:03 +02:00
2026-04-22 11:10:03 +02:00
2026-04-22 11:00:03 +02:00
2026-04-22 05:05:02 +02:00
2026-04-22 04:36:12 +02:00
2026-04-22 11:00:03 +02:00
2026-04-22 04:55:03 +02:00
2026-04-22 05:08:37 +02:00
2026-04-22 05:24:20 +02:00
2026-04-22 10:53:35 +02:00
2026-04-22 11:05:01 +02:00
2026-04-22 11:05:01 +02:00
2026-04-22 11:05:01 +02:00
2026-04-22 17:05:02 +02:00
2026-04-22 10:40:02 +02:00
2026-04-24 12:02:23 +02:00
2026-04-22 04:45:03 +02:00
2026-04-22 04:30:07 +02:00
2026-04-22 04:25:04 +02:00
2026-04-22 04:55:03 +02:00
2026-04-22 10:50:03 +02:00
2026-04-22 10:50:03 +02:00
2026-04-22 04:40:03 +02:00
2026-04-22 15:58:53 +02:00
2026-04-24 14:37:12 +02:00
2026-04-24 14:47:02 +02:00
2026-04-24 14:37:12 +02:00
2026-04-24 14:00:46 +02:00
2026-04-24 16:09:13 +02:00
2026-04-24 14:37:12 +02:00
2026-04-24 12:02:23 +02:00
2026-04-24 12:40:35 +02:00
2026-04-24 12:40:35 +02:00
2026-04-22 05:00:04 +02:00
2026-04-24 10:00:14 +02:00
2026-04-24 11:07:36 +02:00
2026-04-24 06:05:08 +02:00
2026-04-24 14:41:04 +02:00
2026-04-23 03:40:06 +02:00
2026-04-24 12:18:16 +02:00
2026-04-24 11:26:27 +02:00
2026-04-24 02:05:03 +02:00
2026-04-24 01:50:03 +02:00
2026-04-22 05:08:37 +02:00
2026-04-24 02:45:01 +02:00
2026-04-23 20:27:49 +02:00
2026-04-23 22:10:02 +02:00
2026-04-22 05:04:01 +02:00
2026-04-23 22:00:05 +02:00
2026-04-24 16:04:42 +02:00
2026-04-23 22:00:05 +02:00
2026-04-24 12:02:23 +02:00
2026-04-24 09:05:05 +02:00
2026-04-24 02:50:03 +02:00
2026-04-24 10:44:16 +02:00
2026-04-24 01:47:15 +02:00
2026-04-24 03:20:06 +02:00
2026-04-23 21:12:35 +02:00
2026-04-24 00:05:03 +02:00
2026-04-24 00:05:03 +02:00
2026-04-24 00:05:03 +02:00
2026-04-23 21:35:02 +02:00
2026-04-22 13:25:01 +02:00
2026-04-23 20:45:03 +02:00
2026-04-24 12:02:23 +02:00
2026-04-24 16:19:46 +02:00
2026-04-24 14:38:17 +02:00
2026-04-24 12:16:01 +02:00
2026-04-24 12:40:35 +02:00
2026-04-24 02:45:01 +02:00
2026-04-24 15:41:37 +02:00
2026-04-24 15:41:37 +02:00
2026-04-24 14:47:02 +02:00
2026-04-23 05:15:01 +02:00
2026-04-23 04:20:03 +02:00
2026-04-24 03:20:06 +02:00
2026-04-24 16:09:52 +02:00
2026-04-24 18:33:47 +02:00
2026-04-24 13:02:27 +02:00
2026-04-24 15:57:08 +02:00
2026-04-24 16:02:11 +02:00
2026-04-24 12:02:23 +02:00
2026-04-24 12:08:11 +02:00
2026-04-24 01:24:15 +02:00
2026-04-23 22:40:03 +02:00
2026-04-24 12:08:11 +02:00
2026-04-22 05:18:23 +02:00
2026-04-23 04:15:02 +02:00
2026-04-24 14:37:12 +02:00
2026-04-24 12:40:35 +02:00
2026-04-24 12:40:35 +02:00
2026-04-24 14:41:04 +02:00
2026-04-22 04:30:07 +02:00
2026-04-23 01:25:02 +02:00
2026-04-23 22:40:03 +02:00
2026-04-23 04:15:02 +02:00
2026-04-22 21:00:07 +02:00
2026-04-23 22:14:02 +02:00
2026-04-23 21:35:02 +02:00
2026-04-22 20:51:22 +02:00
2026-04-23 21:55:04 +02:00
2026-04-23 22:10:02 +02:00
2026-04-23 22:25:02 +02:00
2026-04-23 21:45:04 +02:00
2026-04-24 01:45:41 +02:00
2026-04-24 04:20:06 +02:00
2026-04-22 04:16:54 +02:00
2026-04-22 04:24:50 +02:00
2026-04-22 04:24:50 +02:00
2026-04-22 04:35:03 +02:00
2026-04-22 04:35:03 +02:00
2026-04-22 04:36:12 +02:00
2026-04-22 04:39:00 +02:00
2026-04-22 04:55:03 +02:00
2026-04-22 04:39:00 +02:00
2026-04-22 04:54:21 +02:00
2026-04-22 05:02:17 +02:00
2026-04-22 05:03:54 +02:00
2026-04-22 05:15:03 +02:00
2026-04-22 05:18:30 +02:00
2026-04-24 01:59:30 +02:00
2026-04-24 17:53:46 +02:00
2026-04-24 12:02:23 +02:00
2026-04-24 03:00:11 +02:00
2026-04-24 03:00:11 +02:00
2026-04-24 03:20:06 +02:00
2026-04-24 02:12:31 +02:00
2026-04-23 22:10:02 +02:00
2026-04-24 12:02:23 +02:00
2026-04-22 04:19:57 +02:00
2026-04-24 03:20:06 +02:00
2026-04-24 01:35:02 +02:00
2026-04-22 21:35:02 +02:00
2026-04-24 14:37:12 +02:00
2026-04-24 12:02:23 +02:00
2026-04-24 02:45:01 +02:00
2026-04-22 15:58:53 +02:00
2026-04-24 14:41:04 +02:00
2026-04-22 05:13:50 +02:00
2026-04-24 17:30:36 +02:00
2026-04-24 18:57:42 +02:00
2026-04-24 01:35:43 +02:00
2026-04-24 14:41:04 +02:00
2026-04-24 16:07:48 +02:00
2026-04-23 21:55:04 +02:00
2026-04-23 20:27:49 +02:00
2026-04-24 19:59:10 +02:00
2026-04-23 23:45:03 +02:00
2026-04-24 19:59:10 +02:00
2026-04-24 02:12:31 +02:00
2026-04-22 04:57:20 +02:00
2026-04-23 21:45:04 +02:00
2026-04-24 20:29:44 +02:00
2026-04-23 22:55:02 +02:00
2026-04-23 23:13:48 +02:00
2026-04-24 06:05:08 +02:00
2026-04-24 13:21:59 +02:00
2026-04-22 05:29:23 +02:00
2026-04-22 16:02:17 +02:00
2026-04-24 18:33:06 +02:00
2026-04-24 16:59:00 +02:00
2026-04-23 21:27:16 +02:00
2026-04-24 00:17:12 +02:00
2026-04-24 15:26:54 +02:00
2026-04-23 21:35:02 +02:00
2026-04-24 19:47:09 +02:00
2026-04-24 19:59:10 +02:00
2026-04-24 03:00:11 +02:00
2026-04-23 23:54:56 +02:00
2026-04-24 12:02:23 +02:00
2026-04-24 12:40:35 +02:00
2026-04-24 01:35:02 +02:00
2026-04-24 20:29:44 +02:00
2026-04-24 19:54:50 +02:00
2026-04-23 22:49:43 +02:00
2026-04-24 03:20:06 +02:00
2026-04-24 18:33:06 +02:00
2026-04-24 17:21:38 +02:00
2026-04-24 18:33:06 +02:00
2026-04-24 16:59:00 +02:00
2026-04-23 23:38:30 +02:00
2026-04-23 23:38:30 +02:00
2026-04-23 23:38:30 +02:00
2026-04-23 23:27:22 +02:00
2026-04-23 23:27:22 +02:00
2026-04-23 23:27:22 +02:00
2026-04-23 23:25:04 +02:00
2026-04-24 03:29:43 +02:00
2026-04-24 00:36:59 +02:00
2026-04-24 00:18:04 +02:00