opencode-swarm 7.82.2 → 7.84.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (58) hide show
  1. package/README.md +3 -1
  2. package/dist/cli/capability-probe-jevmgwmf.js +18 -0
  3. package/dist/cli/config-doctor-4tcdd9vt.js +35 -0
  4. package/dist/cli/dispatch-k86d928w.js +477 -0
  5. package/dist/cli/evidence-summary-service-g2znnd33.js +320 -0
  6. package/dist/cli/explorer-gz70sm9b.js +16 -0
  7. package/dist/cli/gate-evidence-y8zn7fe2.js +29 -0
  8. package/dist/cli/guardrail-explain-tcamcdfy.js +30 -0
  9. package/dist/cli/guardrail-log-fd14n96q.js +15 -0
  10. package/dist/cli/index-293f68mj.js +13538 -0
  11. package/dist/cli/index-8ra2qpk8.js +29027 -0
  12. package/dist/cli/index-a76rekgs.js +67 -0
  13. package/dist/cli/index-a82d6d87.js +1241 -0
  14. package/dist/cli/index-b9v501fr.js +371 -0
  15. package/dist/cli/index-bcp79s17.js +1673 -0
  16. package/dist/cli/index-ckntc5gf.js +91 -0
  17. package/dist/cli/index-d9fbxaqd.js +2314 -0
  18. package/dist/cli/index-e7h9bb6v.js +233 -0
  19. package/dist/cli/index-e8pk68cc.js +540 -0
  20. package/dist/cli/index-eb85wtx9.js +242 -0
  21. package/dist/cli/index-f8r50m3h.js +14505 -0
  22. package/dist/cli/index-fjwwrwr5.js +37 -0
  23. package/dist/cli/index-hz59hg4h.js +452 -0
  24. package/dist/cli/index-j710h2ge.js +412 -0
  25. package/dist/cli/index-jfgr5gye.js +110 -0
  26. package/dist/cli/index-jtqkh8jf.js +119 -0
  27. package/dist/cli/index-p0arc26j.js +28 -0
  28. package/dist/cli/index-p0ye10nd.js +222 -0
  29. package/dist/cli/index-pv2xmc9k.js +2391 -0
  30. package/dist/cli/index-red8fm8p.js +2914 -0
  31. package/dist/cli/index-wg3r6acj.js +2042 -0
  32. package/dist/cli/index-xw0bcy0v.js +583 -0
  33. package/dist/cli/index-yhsmmv2z.js +339 -0
  34. package/dist/cli/index-yx44zd0p.js +40 -0
  35. package/dist/cli/index-zfsbaaqh.js +29 -0
  36. package/dist/cli/index.js +73 -69703
  37. package/dist/cli/knowledge-store-n4x6zyk7.js +73 -0
  38. package/dist/cli/pending-delegations-pz61mrsz.js +255 -0
  39. package/dist/cli/pr-subscriptions-y1nn36e5.js +33 -0
  40. package/dist/cli/schema-c2dbzhm8.js +168 -0
  41. package/dist/cli/skill-generator-a5ehggyg.js +55 -0
  42. package/dist/cli/task-envelope-qn0qtnh0.js +90 -0
  43. package/dist/cli/telemetry-9bbyxrvn.js +20 -0
  44. package/dist/cli/workspace-snapshot-w58jr2ga.js +90 -0
  45. package/dist/commands/guardrail-explain.d.ts +1 -0
  46. package/dist/commands/guardrail-log.d.ts +1 -0
  47. package/dist/commands/index.d.ts +2 -0
  48. package/dist/commands/registry.d.ts +14 -0
  49. package/dist/config/index.d.ts +2 -2
  50. package/dist/config/schema.d.ts +7 -0
  51. package/dist/hooks/guardrails/audit-log.d.ts +114 -0
  52. package/dist/hooks/repo-graph-builder.d.ts +4 -1
  53. package/dist/index.js +3615 -2378
  54. package/dist/services/diagnose-service.d.ts +5 -0
  55. package/dist/services/guardrail-explain-service.d.ts +42 -0
  56. package/dist/services/guardrail-log-service.d.ts +10 -0
  57. package/dist/tools/repo-graph/types.d.ts +6 -0
  58. package/package.json +2 -2
@@ -0,0 +1,2042 @@
1
+ // @bun
2
+ import {
3
+ exports_external
4
+ } from "./index-293f68mj.js";
5
+
6
+ // src/config/agent-names.ts
7
+ var QA_AGENTS = ["reviewer", "critic", "critic_oversight"];
8
+ var PIPELINE_AGENTS = ["explorer", "coder", "test_engineer"];
9
+ var ORCHESTRATOR_NAME = "architect";
10
+ var ALL_SUBAGENT_NAMES = [
11
+ "sme",
12
+ "researcher",
13
+ "docs",
14
+ "docs_design",
15
+ "designer",
16
+ "critic_sounding_board",
17
+ "critic_drift_verifier",
18
+ "critic_hallucination_verifier",
19
+ "critic_architecture_supervisor",
20
+ "curator_init",
21
+ "curator_phase",
22
+ "curator_postmortem",
23
+ "council_generalist",
24
+ "council_skeptic",
25
+ "council_domain_expert",
26
+ "skill_improver",
27
+ "spec_writer",
28
+ ...QA_AGENTS,
29
+ ...PIPELINE_AGENTS
30
+ ];
31
+ var ALL_AGENT_NAMES = [
32
+ ORCHESTRATOR_NAME,
33
+ ...ALL_SUBAGENT_NAMES
34
+ ];
35
+
36
+ // src/tools/tool-metadata.ts
37
+ var TOOL_METADATA = {
38
+ diff: {
39
+ description: "structured git diff with contract change detection",
40
+ agents: [
41
+ "architect",
42
+ "reviewer",
43
+ "critic_oversight",
44
+ "coder",
45
+ "test_engineer"
46
+ ]
47
+ },
48
+ diff_summary: {
49
+ description: "filter classified AST changes by category, risk level, or file for reviewer drill-down",
50
+ agents: ["architect", "reviewer", "critic_oversight"]
51
+ },
52
+ syntax_check: {
53
+ description: "check syntax of source files using tree-sitter parsers across multiple languages, returning per-file errors",
54
+ agents: ["architect", "coder", "test_engineer"]
55
+ },
56
+ placeholder_scan: {
57
+ description: "todo and FIXME comment detection",
58
+ agents: ["architect", "reviewer"]
59
+ },
60
+ imports: {
61
+ description: "find all consumers that import from a given file \u2014 use before refactoring shared modules to avoid breaking unseen dependents",
62
+ agents: [
63
+ "architect",
64
+ "sme",
65
+ "researcher",
66
+ "docs",
67
+ "docs_design",
68
+ "critic_sounding_board",
69
+ "critic_drift_verifier",
70
+ "critic_hallucination_verifier",
71
+ "reviewer",
72
+ "critic",
73
+ "critic_oversight",
74
+ "explorer",
75
+ "coder",
76
+ "test_engineer"
77
+ ]
78
+ },
79
+ lint: {
80
+ description: "run project linter in check or fix mode; supports biome, eslint, ruff, clippy, and more, returns structured results",
81
+ agents: ["architect", "reviewer", "coder"]
82
+ },
83
+ secretscan: {
84
+ description: "scan for secrets (API keys, tokens, passwords) via regex and entropy; returns redacted previews, excludes common dirs",
85
+ agents: ["architect", "reviewer", "critic_oversight"]
86
+ },
87
+ sast_scan: {
88
+ description: "static analysis security scan",
89
+ agents: ["architect", "reviewer", "critic_oversight"]
90
+ },
91
+ build_check: {
92
+ description: "discover and run build, typecheck, and test commands for various project ecosystems in the working directory",
93
+ agents: ["architect", "coder", "test_engineer"]
94
+ },
95
+ pre_check_batch: {
96
+ description: "parallel verification: lint:check + secretscan + sast_scan + quality_budget",
97
+ agents: ["architect", "reviewer"]
98
+ },
99
+ quality_budget: {
100
+ description: "code quality budget check",
101
+ agents: ["architect"]
102
+ },
103
+ symbols: {
104
+ description: "extract exported symbols (functions, classes, interfaces, types) from source files; supports TypeScript, JavaScript, and Python",
105
+ agents: [
106
+ "architect",
107
+ "sme",
108
+ "researcher",
109
+ "docs",
110
+ "docs_design",
111
+ "designer",
112
+ "critic_sounding_board",
113
+ "critic_drift_verifier",
114
+ "critic_hallucination_verifier",
115
+ "spec_writer",
116
+ "reviewer",
117
+ "critic",
118
+ "critic_oversight",
119
+ "explorer",
120
+ "coder",
121
+ "test_engineer"
122
+ ]
123
+ },
124
+ complexity_hotspots: {
125
+ description: "git churn \xD7 complexity risk map",
126
+ agents: [
127
+ "architect",
128
+ "sme",
129
+ "researcher",
130
+ "critic_sounding_board",
131
+ "critic_drift_verifier",
132
+ "critic_hallucination_verifier",
133
+ "reviewer",
134
+ "critic",
135
+ "critic_oversight",
136
+ "explorer",
137
+ "test_engineer"
138
+ ]
139
+ },
140
+ schema_drift: {
141
+ description: "OpenAPI spec vs route drift",
142
+ agents: ["architect", "sme", "researcher", "docs", "explorer"]
143
+ },
144
+ todo_extract: {
145
+ description: "structured TODO/FIXME extraction",
146
+ agents: ["architect", "researcher", "docs", "explorer"]
147
+ },
148
+ evidence_check: {
149
+ description: "verify task evidence completeness",
150
+ agents: ["architect", "critic_oversight"]
151
+ },
152
+ check_gate_status: {
153
+ description: "check the gate status of a specific task",
154
+ agents: ["architect", "critic_oversight"]
155
+ },
156
+ completion_verify: {
157
+ description: "verify completed tasks have required evidence",
158
+ agents: ["architect", "critic_oversight"]
159
+ },
160
+ submit_council_verdicts: {
161
+ description: "submit pre-collected council member verdicts for synthesis (architect MUST dispatch critic/reviewer/sme/test_engineer/explorer as Agent tasks first; this tool synthesizes only, it does not contact members)",
162
+ agents: []
163
+ },
164
+ submit_phase_council_verdicts: {
165
+ description: "submit pre-collected phase-level council member verdicts for holistic phase synthesis (architect MUST dispatch all 5 council members with phase-scoped context first; this tool synthesizes only, it does not contact members)",
166
+ agents: []
167
+ },
168
+ declare_council_criteria: {
169
+ description: "pre-declare acceptance criteria for a task before the coder starts work; criteria are read back during council evaluation",
170
+ agents: []
171
+ },
172
+ sbom_generate: {
173
+ description: "SBOM generation for dependency inventory",
174
+ agents: ["architect"]
175
+ },
176
+ checkpoint: {
177
+ description: "create named git checkpoints for save, restore, and delete \u2014 use before risky operations to enable rollback",
178
+ agents: ["architect"]
179
+ },
180
+ pkg_audit: {
181
+ description: "dependency vulnerability scan \u2014 npm/pip/cargo",
182
+ agents: [
183
+ "architect",
184
+ "critic_hallucination_verifier",
185
+ "reviewer",
186
+ "critic_oversight",
187
+ "test_engineer"
188
+ ]
189
+ },
190
+ test_runner: {
191
+ description: "auto-detect and run tests",
192
+ agents: ["architect", "reviewer", "test_engineer"]
193
+ },
194
+ test_impact: {
195
+ description: "identify test files impacted by changed source files via import analysis",
196
+ agents: ["architect", "reviewer", "critic_oversight", "test_engineer"]
197
+ },
198
+ mutation_test: {
199
+ description: "executes pre-generated mutation patches against tests, evaluates kill rate against quality gate thresholds",
200
+ agents: ["architect", "test_engineer"]
201
+ },
202
+ generate_mutants: {
203
+ description: "generate LLM-based mutation testing patches for source files; returns MutationPatch[] for direct consumption by the mutation_test tool",
204
+ agents: ["architect"]
205
+ },
206
+ detect_domains: {
207
+ description: "detect which SME domains are relevant for a given text",
208
+ agents: [
209
+ "architect",
210
+ "sme",
211
+ "docs",
212
+ "docs_design",
213
+ "critic_sounding_board",
214
+ "critic_drift_verifier",
215
+ "critic_hallucination_verifier",
216
+ "critic",
217
+ "critic_oversight",
218
+ "explorer"
219
+ ]
220
+ },
221
+ git_blame: {
222
+ description: "per-line git blame metadata: sha, author, date, summary for each line in a file",
223
+ agents: ["reviewer", "explorer", "architect"]
224
+ },
225
+ gitingest: {
226
+ description: "fetch a GitHub repository full content via gitingest.com",
227
+ agents: ["architect", "docs", "explorer"]
228
+ },
229
+ retrieve_summary: {
230
+ description: "retrieve the full content of a stored tool output summary",
231
+ agents: [
232
+ "architect",
233
+ "sme",
234
+ "docs",
235
+ "docs_design",
236
+ "designer",
237
+ "critic_sounding_board",
238
+ "critic_drift_verifier",
239
+ "critic_hallucination_verifier",
240
+ "critic_architecture_supervisor",
241
+ "spec_writer",
242
+ "reviewer",
243
+ "critic",
244
+ "critic_oversight",
245
+ "explorer",
246
+ "coder",
247
+ "test_engineer"
248
+ ]
249
+ },
250
+ extract_code_blocks: {
251
+ description: "extract code blocks from text content and save them to files",
252
+ agents: [
253
+ "architect",
254
+ "sme",
255
+ "docs",
256
+ "docs_design",
257
+ "designer",
258
+ "spec_writer",
259
+ "reviewer",
260
+ "explorer",
261
+ "coder",
262
+ "test_engineer"
263
+ ]
264
+ },
265
+ phase_complete: {
266
+ description: "mark a phase as complete and track dispatched agents",
267
+ agents: ["architect"]
268
+ },
269
+ save_plan: {
270
+ description: "save a structured implementation plan",
271
+ agents: ["architect"]
272
+ },
273
+ update_task_status: {
274
+ description: "mark tasks complete, track phase progress",
275
+ agents: ["architect"]
276
+ },
277
+ lint_spec: {
278
+ description: "validate .swarm/spec.md format and required fields",
279
+ agents: ["architect", "spec_writer"]
280
+ },
281
+ write_retro: {
282
+ description: "document phase retrospectives via phase_complete workflow, capture lessons learned",
283
+ agents: ["architect"]
284
+ },
285
+ write_drift_evidence: {
286
+ description: "write drift verification evidence for a completed phase",
287
+ agents: ["architect"]
288
+ },
289
+ write_hallucination_evidence: {
290
+ description: "write hallucination verification evidence for a completed phase",
291
+ agents: ["architect"]
292
+ },
293
+ write_mutation_evidence: {
294
+ description: "write mutation gate evidence for a completed phase; normalizes PASS/WARN/FAIL/SKIP verdicts and writes .swarm/evidence/{phase}/mutation-gate.json",
295
+ agents: ["architect"]
296
+ },
297
+ declare_scope: {
298
+ description: "declare file scope for next coder delegation",
299
+ agents: ["architect"]
300
+ },
301
+ knowledge_query: {
302
+ description: "query swarm or hive knowledge with optional filters",
303
+ agents: ["architect", "skill_improver", "spec_writer"]
304
+ },
305
+ doc_scan: {
306
+ description: "scan project documentation files and build an index manifest",
307
+ agents: [
308
+ "architect",
309
+ "docs_design",
310
+ "skill_improver",
311
+ "spec_writer",
312
+ "explorer"
313
+ ]
314
+ },
315
+ doc_extract: {
316
+ description: "extract actionable constraints from project documentation",
317
+ agents: ["architect", "docs_design", "skill_improver", "spec_writer"]
318
+ },
319
+ curator_analyze: {
320
+ description: "run curator phase analysis and optionally apply knowledge recommendations",
321
+ agents: ["architect"]
322
+ },
323
+ knowledge_add: {
324
+ description: "store a new lesson in the knowledge base",
325
+ agents: ["architect", "coder"]
326
+ },
327
+ knowledge_recall: {
328
+ description: "search the knowledge base for relevant past decisions",
329
+ agents: [
330
+ "architect",
331
+ "sme",
332
+ "docs",
333
+ "docs_design",
334
+ "designer",
335
+ "critic_sounding_board",
336
+ "critic_drift_verifier",
337
+ "critic_hallucination_verifier",
338
+ "critic_architecture_supervisor",
339
+ "curator_init",
340
+ "curator_phase",
341
+ "skill_improver",
342
+ "spec_writer",
343
+ "reviewer",
344
+ "critic",
345
+ "critic_oversight",
346
+ "explorer",
347
+ "coder",
348
+ "test_engineer"
349
+ ]
350
+ },
351
+ knowledge_remove: {
352
+ description: "delete an outdated swarm knowledge entry by ID (swarm tier only)",
353
+ agents: ["architect"]
354
+ },
355
+ co_change_analyzer: {
356
+ description: "detect hidden couplings by analyzing git history",
357
+ agents: ["architect"]
358
+ },
359
+ search: {
360
+ description: "Workspace-scoped ripgrep-style text search with structured JSON output. Supports literal and regex modes, glob filtering, and result limits. NOTE: This is text search, not structural AST search \u2014 use symbols and imports tools for structural queries.",
361
+ agents: [
362
+ "architect",
363
+ "sme",
364
+ "docs",
365
+ "docs_design",
366
+ "designer",
367
+ "critic_hallucination_verifier",
368
+ "skill_improver",
369
+ "spec_writer",
370
+ "reviewer",
371
+ "critic_oversight",
372
+ "explorer",
373
+ "coder",
374
+ "test_engineer",
375
+ "researcher"
376
+ ]
377
+ },
378
+ batch_symbols: {
379
+ description: "Batched symbol extraction across multiple files. Returns per-file symbol summaries with isolated error handling.",
380
+ agents: [
381
+ "architect",
382
+ "critic_hallucination_verifier",
383
+ "reviewer",
384
+ "critic_oversight",
385
+ "explorer"
386
+ ]
387
+ },
388
+ suggest_patch: {
389
+ description: "Reviewer-safe structured patch suggestion tool. Produces context-anchored patch artifacts without file modification. Returns structured diagnostics on context mismatch.",
390
+ agents: ["architect", "reviewer"]
391
+ },
392
+ req_coverage: {
393
+ description: "query requirement coverage status for tracked functional requirements",
394
+ agents: [
395
+ "critic_sounding_board",
396
+ "critic_drift_verifier",
397
+ "critic_hallucination_verifier",
398
+ "spec_writer",
399
+ "critic",
400
+ "critic_oversight"
401
+ ]
402
+ },
403
+ get_approved_plan: {
404
+ description: "retrieve the last critic-approved immutable plan snapshot for baseline drift comparison",
405
+ agents: ["critic_drift_verifier", "critic", "critic_oversight"]
406
+ },
407
+ repo_map: {
408
+ description: "query the repo code graph: importers, dependencies, blast radius, localization, ontology facts, package boundaries, and heuristic preflight packets before refactoring; ontology findings are advisory, not formal proofs",
409
+ agents: [
410
+ "architect",
411
+ "critic_sounding_board",
412
+ "critic_drift_verifier",
413
+ "critic_hallucination_verifier",
414
+ "critic_architecture_supervisor",
415
+ "reviewer",
416
+ "critic",
417
+ "critic_oversight",
418
+ "explorer",
419
+ "coder"
420
+ ]
421
+ },
422
+ get_qa_gate_profile: {
423
+ description: "retrieve the QA gate profile for the current plan: gates (reviewer, test_engineer, sme_enabled, critic_pre_plan, sast_enabled, council_mode, hallucination_guard, mutation_test, phase_council, drift_check, final_council), lock state, and profile hash. Read-only.",
424
+ agents: ["architect"]
425
+ },
426
+ set_qa_gates: {
427
+ description: "configure the QA gate profile for the current plan. Architect-only. Ratchet-tighter only \u2014 rejected once the profile is locked after critic approval. Supports: reviewer, test_engineer, sme_enabled, critic_pre_plan, sast_enabled, council_mode, hallucination_guard, mutation_test, phase_council, drift_check, final_council.",
428
+ agents: ["architect"]
429
+ },
430
+ web_search: {
431
+ description: "External web search (Tavily or Brave) for architect-driven council research, SME domain research, researcher auto-research, and skill-improver research. Returns titled results with snippets, URLs, normalized query metadata, temporal intent, freshness, and removed stale years. Config-gated on council.general.enabled in the resolved config: global ~/.config/opencode/opencode-swarm.json, then project .opencode/opencode-swarm.json overrides. Requires a search API key. Used by the architect in MODE: COUNCIL to gather a RESEARCH CONTEXT before dispatching council agents, by SME for opt-in external skill/source evaluation, and by the researcher agent for multi-source auto-research.",
432
+ agents: ["sme", "researcher", "skill_improver"]
433
+ },
434
+ web_fetch: {
435
+ description: "Fetch the readable text of a single http(s) URL (architect-only). Returns decoded page text, document title, final URL after redirects, and an evidence reference. Reads primary sources that web_search only surfaces as snippets. Config-gated on council.general.enabled. Blocks private/loopback/link-local/metadata addresses (re-validated and re-pinned across redirects); enforces timeout and body size cap.",
436
+ agents: []
437
+ },
438
+ convene_general_council: {
439
+ description: "Synthesize responses from a multi-model General Council. Accepts parallel member responses (Round 1, optionally Round 2), detects disagreements, and returns consensus points, persisting disagreements, and a structured synthesis. Architect-only. Config-gated on council.general.enabled in the resolved config: global ~/.config/opencode/opencode-swarm.json, then project .opencode/opencode-swarm.json overrides.",
440
+ agents: []
441
+ },
442
+ write_final_council_evidence: {
443
+ description: "Persist project-scoped final council evidence to .swarm/evidence/final-council.json. PREREQUISITE: dispatch critic, reviewer, sme, test_engineer, and explorer as project-scoped Agent tasks and collect their CouncilMemberVerdict JSON \u2014 this tool synthesizes only. Rejects on insufficient quorum or CONCERNS with unresolved requiredFixes; normalizes verdicts to approved/concerns/rejected. Architect-only.",
444
+ agents: []
445
+ },
446
+ skill_generate: {
447
+ description: "compile knowledge entries into a structured SKILL.md draft",
448
+ agents: ["architect", "skill_improver"]
449
+ },
450
+ skill_list: {
451
+ description: "list generated skill files and their status",
452
+ agents: ["architect", "skill_improver"]
453
+ },
454
+ skill_apply: {
455
+ description: "activate a draft skill proposal",
456
+ agents: ["architect"]
457
+ },
458
+ skill_inspect: {
459
+ description: "inspect the content and source entries of a skill file",
460
+ agents: ["architect", "skill_improver"]
461
+ },
462
+ skill_regenerate: {
463
+ description: "regenerate an active skill by re-clustering its source knowledge entries and updating the SKILL.md in place",
464
+ agents: ["architect"]
465
+ },
466
+ skill_retire: {
467
+ description: "retire a generated skill by adding a retired.marker file; retired skills are excluded from scoring and injection",
468
+ agents: ["architect"]
469
+ },
470
+ skill_improve: {
471
+ description: "run the skill_improver agent to review and refine skills",
472
+ agents: ["architect", "skill_improver"]
473
+ },
474
+ spec_write: {
475
+ description: "author or update .swarm/spec.md for the current project",
476
+ agents: ["spec_writer"]
477
+ },
478
+ knowledge_receipt: {
479
+ description: "file a receipt for retrieved knowledge (applied/ignored/contradicted + new lessons), recorded as immutable knowledge events",
480
+ agents: ["architect", "coder"]
481
+ },
482
+ knowledge_archive: {
483
+ description: "archive (default), quarantine, or purge a swarm or hive knowledge entry by ID with an immutable audit tombstone; purge requires an admin flag",
484
+ agents: ["architect"]
485
+ },
486
+ swarm_memory_recall: {
487
+ description: "recall scoped Swarm memory for the current repository as untrusted background",
488
+ agents: []
489
+ },
490
+ swarm_memory_propose: {
491
+ description: "create a pending Swarm memory proposal; does not write durable memory directly",
492
+ agents: []
493
+ },
494
+ swarm_command: {
495
+ description: "run supported /swarm commands through the canonical command registry",
496
+ agents: [
497
+ "architect",
498
+ "sme",
499
+ "researcher",
500
+ "docs",
501
+ "docs_design",
502
+ "designer",
503
+ "reviewer",
504
+ "critic",
505
+ "explorer",
506
+ "coder",
507
+ "test_engineer"
508
+ ]
509
+ },
510
+ dispatch_lanes: {
511
+ description: "dispatch read-only exploration/review lanes concurrently and BLOCK until all finish; prefer dispatch_lanes_async for non-blocking dispatch, use this only when promptAsync is unavailable",
512
+ agents: ["architect"]
513
+ },
514
+ dispatch_lanes_async: {
515
+ description: "launch read-only advisory lanes non-blockingly and return a batch id immediately so you can keep working; join later with collect_lane_results",
516
+ agents: ["architect"]
517
+ },
518
+ collect_lane_results: {
519
+ description: "collect or poll results for a dispatch_lanes_async batch; this is the required join barrier for advisory lane workflows and does not advance workflow gates",
520
+ agents: ["architect"]
521
+ },
522
+ summarize_work: {
523
+ description: "emit a short structured summary of completed work (key decisions, assumptions, risks, constraints) at task completion; rolls up per phase for architecture-supervisor review. Advisory, never blocks.",
524
+ agents: [
525
+ "architect",
526
+ "sme",
527
+ "researcher",
528
+ "docs",
529
+ "docs_design",
530
+ "designer",
531
+ "explorer",
532
+ "coder",
533
+ "test_engineer"
534
+ ]
535
+ },
536
+ write_architecture_supervisor_evidence: {
537
+ description: "persist the architecture supervisor verdict for a phase (architect MUST dispatch critic_architecture_supervisor first and collect its JSON verdict; this tool persists only, it does not contact the supervisor)",
538
+ agents: ["architect"]
539
+ },
540
+ lean_turbo_plan_lanes: {
541
+ description: "partition phase tasks into parallel lanes based on file-scope conflicts for Lean Turbo execution",
542
+ agents: []
543
+ },
544
+ lean_turbo_acquire_locks: {
545
+ description: "acquire file locks for all files in a lane (all-or-nothing) before lane execution",
546
+ agents: []
547
+ },
548
+ lean_turbo_runner_status: {
549
+ description: "read Lean Turbo run state from .swarm/turbo-state.json",
550
+ agents: []
551
+ },
552
+ lean_turbo_review: {
553
+ description: "dispatch a read-only reviewer agent to evaluate a completed Lean Turbo phase",
554
+ agents: []
555
+ },
556
+ lean_turbo_run_phase: {
557
+ description: "Execute a phase using Lean Turbo parallel lane execution. Plans lanes, acquires file locks, and dispatches coder agents concurrently. Use when Lean Turbo is active and you want to execute all tasks in a phase in parallel lanes.",
558
+ agents: []
559
+ },
560
+ lean_turbo_status: {
561
+ description: "returns Lean Turbo configuration and active status for the current session",
562
+ agents: []
563
+ },
564
+ apply_patch: {
565
+ description: "Apply a unified diff patch to workspace files with exact context matching, atomic writes, and path validation",
566
+ agents: ["coder", "test_engineer"]
567
+ },
568
+ external_skill_discover: {
569
+ description: "Discover external skill candidates from configured sources. Returns a disabled message when external_skills.curation_enabled is false.",
570
+ agents: []
571
+ },
572
+ external_skill_list: {
573
+ description: "List external skill candidates in the quarantine store. Returns a disabled message when external_skills.curation_enabled is false.",
574
+ agents: []
575
+ },
576
+ external_skill_inspect: {
577
+ description: "Inspect a specific external skill candidate by ID. Returns a disabled message when external_skills.curation_enabled is false.",
578
+ agents: []
579
+ },
580
+ external_skill_promote: {
581
+ description: "Promote a validated external skill candidate to an active generated skill. Returns a disabled message when external_skills.curation_enabled is false.",
582
+ agents: []
583
+ },
584
+ external_skill_reject: {
585
+ description: "Reject an external skill candidate after evaluation. Returns a disabled message when external_skills.curation_enabled is false.",
586
+ agents: []
587
+ },
588
+ external_skill_delete: {
589
+ description: "Delete an external skill candidate from the quarantine store. Returns a disabled message when external_skills.curation_enabled is false.",
590
+ agents: []
591
+ },
592
+ external_skill_revoke: {
593
+ description: "Revoke a previously promoted external skill. Returns a disabled message when external_skills.curation_enabled is false.",
594
+ agents: []
595
+ }
596
+ };
597
+ var TOOL_NAMES = Object.keys(TOOL_METADATA);
598
+ var TOOL_NAME_SET = new Set(TOOL_NAMES);
599
+ var TOOL_DESCRIPTIONS = Object.fromEntries(Object.entries(TOOL_METADATA).map(([name, meta]) => [
600
+ name,
601
+ meta.description
602
+ ]));
603
+ var AGENT_TOOL_MAP = (() => {
604
+ const map = Object.fromEntries(ALL_AGENT_NAMES.map((agent) => [agent, []]));
605
+ for (const [name, meta] of Object.entries(TOOL_METADATA)) {
606
+ for (const agent of meta.agents) {
607
+ map[agent].push(name);
608
+ }
609
+ }
610
+ return map;
611
+ })();
612
+ // src/config/constants.ts
613
+ var OPENCODE_NATIVE_AGENTS = new Set([
614
+ "build",
615
+ "plan",
616
+ "general",
617
+ "explore",
618
+ "compaction",
619
+ "title",
620
+ "summary"
621
+ ]);
622
+ function freezeSet(items) {
623
+ const set = new Set(items);
624
+ const proxy = new Proxy(set, {
625
+ get(target, prop) {
626
+ if (prop === "add" || prop === "delete" || prop === "clear") {
627
+ return () => {
628
+ throw new TypeError("CLAUDE_CODE_NATIVE_COMMANDS is readonly");
629
+ };
630
+ }
631
+ if (prop === "forEach") {
632
+ return (callback, thisArg) => {
633
+ const wrapped = (v, k) => callback.call(thisArg ?? undefined, v, k, proxy);
634
+ return set.forEach(wrapped);
635
+ };
636
+ }
637
+ const value = Reflect.get(target, prop);
638
+ return typeof value === "function" ? value.bind(target) : value;
639
+ },
640
+ set() {
641
+ throw new TypeError("CLAUDE_CODE_NATIVE_COMMANDS is readonly");
642
+ },
643
+ deleteProperty() {
644
+ throw new TypeError("CLAUDE_CODE_NATIVE_COMMANDS is readonly");
645
+ },
646
+ defineProperty() {
647
+ throw new TypeError("CLAUDE_CODE_NATIVE_COMMANDS is readonly");
648
+ },
649
+ setPrototypeOf() {
650
+ throw new TypeError("CLAUDE_CODE_NATIVE_COMMANDS is readonly");
651
+ }
652
+ });
653
+ return proxy;
654
+ }
655
+ var CLAUDE_CODE_NATIVE_COMMANDS = freezeSet([
656
+ "clear",
657
+ "new",
658
+ "reset",
659
+ "resume",
660
+ "continue",
661
+ "exit",
662
+ "quit",
663
+ "compact",
664
+ "fork",
665
+ "branch",
666
+ "undo",
667
+ "checkpoint",
668
+ "rewind",
669
+ "rename",
670
+ "doctor",
671
+ "help",
672
+ "status",
673
+ "statusline",
674
+ "cost",
675
+ "usage",
676
+ "stats",
677
+ "context",
678
+ "debug",
679
+ "insights",
680
+ "recap",
681
+ "release-notes",
682
+ "heapdump",
683
+ "powerup",
684
+ "config",
685
+ "settings",
686
+ "model",
687
+ "effort",
688
+ "fast",
689
+ "theme",
690
+ "color",
691
+ "keybindings",
692
+ "privacy-settings",
693
+ "init",
694
+ "focus",
695
+ "sandbox",
696
+ "terminal-setup",
697
+ "permissions",
698
+ "allowed-tools",
699
+ "security-review",
700
+ "fewer-permission-prompts",
701
+ "plugin",
702
+ "reload-plugins",
703
+ "hooks",
704
+ "mcp",
705
+ "ide",
706
+ "chrome",
707
+ "desktop",
708
+ "app",
709
+ "mobile",
710
+ "ios",
711
+ "android",
712
+ "remote-control",
713
+ "rc",
714
+ "remote-env",
715
+ "login",
716
+ "logout",
717
+ "review",
718
+ "pr-comments",
719
+ "agents",
720
+ "batch",
721
+ "loop",
722
+ "proactive",
723
+ "claude-api",
724
+ "schedule",
725
+ "routines",
726
+ "autofix-pr",
727
+ "plan",
728
+ "diff",
729
+ "export",
730
+ "copy",
731
+ "feedback",
732
+ "bug",
733
+ "btw",
734
+ "add-dir",
735
+ "memory",
736
+ "skills",
737
+ "upgrade",
738
+ "vim",
739
+ "voice",
740
+ "extra-usage",
741
+ "install-github-app",
742
+ "install-slack-app",
743
+ "passes",
744
+ "setup-bedrock",
745
+ "install",
746
+ "tasks",
747
+ "history",
748
+ "term",
749
+ "teleport",
750
+ "ultrareview",
751
+ "ultraplan",
752
+ "web-setup",
753
+ "setup-vertex",
754
+ "tui",
755
+ "simplify",
756
+ "summary",
757
+ "stickers",
758
+ "tp",
759
+ "team-onboarding",
760
+ "bashes"
761
+ ]);
762
+ var EXTERNAL_SKILL_TOOL_NAMES = [
763
+ "external_skill_discover",
764
+ "external_skill_list",
765
+ "external_skill_inspect",
766
+ "external_skill_promote",
767
+ "external_skill_reject",
768
+ "external_skill_delete",
769
+ "external_skill_revoke"
770
+ ];
771
+ var EXTERNAL_SKILL_AGENT_TOOL_MAP = {
772
+ architect: [...EXTERNAL_SKILL_TOOL_NAMES]
773
+ };
774
+ var COUNCIL_TOOL_NAMES = [
775
+ "submit_council_verdicts",
776
+ "submit_phase_council_verdicts",
777
+ "declare_council_criteria",
778
+ "write_final_council_evidence"
779
+ ];
780
+ var COUNCIL_AGENT_TOOL_MAP = {
781
+ architect: [...COUNCIL_TOOL_NAMES]
782
+ };
783
+ var GENERAL_COUNCIL_TOOL_NAMES = [
784
+ "convene_general_council",
785
+ "web_search",
786
+ "web_fetch"
787
+ ];
788
+ var GENERAL_COUNCIL_AGENT_TOOL_MAP = {
789
+ architect: [...GENERAL_COUNCIL_TOOL_NAMES]
790
+ };
791
+ var TURBO_TOOL_NAMES = [
792
+ "lean_turbo_plan_lanes",
793
+ "lean_turbo_acquire_locks",
794
+ "lean_turbo_runner_status",
795
+ "lean_turbo_review",
796
+ "lean_turbo_run_phase",
797
+ "lean_turbo_status"
798
+ ];
799
+ var TURBO_AGENT_TOOL_MAP = {
800
+ architect: [...TURBO_TOOL_NAMES]
801
+ };
802
+ var DEFAULT_AGENT_CONFIGS = {
803
+ coder: {
804
+ model: "opencode/minimax-m2.5-free",
805
+ fallback_models: ["opencode/gpt-5-nano", "opencode/big-pickle"]
806
+ },
807
+ reviewer: {
808
+ model: "opencode/big-pickle",
809
+ fallback_models: ["opencode/gpt-5-nano", "opencode/big-pickle"]
810
+ },
811
+ test_engineer: {
812
+ model: "opencode/gpt-5-nano",
813
+ fallback_models: ["opencode/big-pickle"]
814
+ },
815
+ explorer: {
816
+ model: "opencode/big-pickle",
817
+ fallback_models: ["opencode/gpt-5-nano", "opencode/big-pickle"]
818
+ },
819
+ sme: {
820
+ model: "opencode/big-pickle",
821
+ fallback_models: ["opencode/gpt-5-nano", "opencode/big-pickle"]
822
+ },
823
+ researcher: {
824
+ model: "opencode/big-pickle",
825
+ fallback_models: ["opencode/gpt-5-nano", "opencode/big-pickle"]
826
+ },
827
+ critic: {
828
+ model: "opencode/big-pickle",
829
+ fallback_models: ["opencode/gpt-5-nano", "opencode/big-pickle"]
830
+ },
831
+ docs: {
832
+ model: "opencode/big-pickle",
833
+ fallback_models: ["opencode/gpt-5-nano", "opencode/big-pickle"]
834
+ },
835
+ docs_design: {
836
+ model: "opencode/big-pickle",
837
+ fallback_models: ["opencode/gpt-5-nano", "opencode/big-pickle"]
838
+ },
839
+ designer: {
840
+ model: "opencode/big-pickle",
841
+ fallback_models: ["opencode/gpt-5-nano", "opencode/big-pickle"]
842
+ },
843
+ critic_sounding_board: {
844
+ model: "opencode/gpt-5-nano",
845
+ fallback_models: ["opencode/big-pickle"]
846
+ },
847
+ critic_drift_verifier: {
848
+ model: "opencode/gpt-5-nano",
849
+ fallback_models: ["opencode/big-pickle"]
850
+ },
851
+ critic_hallucination_verifier: {
852
+ model: "opencode/gpt-5-nano",
853
+ fallback_models: ["opencode/big-pickle"]
854
+ },
855
+ critic_oversight: {
856
+ model: "opencode/gpt-5-nano",
857
+ fallback_models: ["opencode/big-pickle"]
858
+ },
859
+ critic_architecture_supervisor: {
860
+ model: "opencode/big-pickle",
861
+ fallback_models: ["opencode/gpt-5-nano"]
862
+ },
863
+ curator_init: {
864
+ model: "opencode/gpt-5-nano",
865
+ fallback_models: ["opencode/big-pickle"]
866
+ },
867
+ curator_phase: {
868
+ model: "opencode/gpt-5-nano",
869
+ fallback_models: ["opencode/big-pickle"]
870
+ },
871
+ curator_postmortem: {
872
+ model: "opencode/gpt-5-nano",
873
+ fallback_models: ["opencode/big-pickle"]
874
+ },
875
+ skill_improver: {
876
+ model: "opencode/big-pickle",
877
+ fallback_models: ["opencode/gpt-5-nano"]
878
+ },
879
+ spec_writer: {
880
+ model: "opencode/big-pickle",
881
+ fallback_models: ["opencode/gpt-5-nano"]
882
+ }
883
+ };
884
+
885
+ // src/config/schema.ts
886
+ var _internals = {
887
+ stripKnownSwarmPrefix,
888
+ getCanonicalAgentRole,
889
+ resolveGuardrailsConfig
890
+ };
891
+ var SEPARATORS = ["_", "-", " "];
892
+ var CANONICAL_ROLES_LONGEST_FIRST = [
893
+ ...ALL_AGENT_NAMES
894
+ ].sort((a, b) => b.length - a.length);
895
+ var CANONICAL_ROLES_SET = new Set(ALL_AGENT_NAMES);
896
+ function isKnownCanonicalRole(role) {
897
+ if (!role)
898
+ return false;
899
+ return CANONICAL_ROLES_SET.has(role);
900
+ }
901
+ function getCanonicalAgentRole(agentName, generatedAgentNames) {
902
+ if (!agentName)
903
+ return agentName;
904
+ const normalized = agentName.toLowerCase();
905
+ if (CANONICAL_ROLES_SET.has(normalized)) {
906
+ return normalized;
907
+ }
908
+ if (generatedAgentNames) {
909
+ const registry = new Set;
910
+ for (const n of generatedAgentNames)
911
+ registry.add(n.toLowerCase());
912
+ if (!registry.has(normalized)) {
913
+ return agentName;
914
+ }
915
+ }
916
+ for (const role of CANONICAL_ROLES_LONGEST_FIRST) {
917
+ for (const sep of SEPARATORS) {
918
+ const suffix = sep + role;
919
+ if (normalized.endsWith(suffix)) {
920
+ return role;
921
+ }
922
+ }
923
+ }
924
+ return agentName;
925
+ }
926
+ function resolveGeneratedAgentRole(agentName, generatedAgentNames) {
927
+ return _internals.getCanonicalAgentRole(agentName, generatedAgentNames);
928
+ }
929
+ function stripKnownSwarmPrefix(agentName) {
930
+ return getCanonicalAgentRole(agentName);
931
+ }
932
+ var AgentReasoningConfigSchema = exports_external.object({
933
+ effort: exports_external.enum(["low", "medium", "high", "max"]).optional()
934
+ });
935
+ var AgentThinkingConfigSchema = exports_external.object({
936
+ type: exports_external.enum(["enabled", "disabled"]).optional(),
937
+ budget_tokens: exports_external.number().int().positive().optional()
938
+ });
939
+ var AgentOverrideConfigSchema = exports_external.object({
940
+ model: exports_external.string().optional(),
941
+ variant: exports_external.string().min(1).optional(),
942
+ temperature: exports_external.number().min(0).max(2).optional(),
943
+ disabled: exports_external.boolean().optional(),
944
+ fallback_models: exports_external.array(exports_external.string()).max(3).optional(),
945
+ reasoning: AgentReasoningConfigSchema.optional(),
946
+ thinking: AgentThinkingConfigSchema.optional()
947
+ });
948
+ var SwarmConfigSchema = exports_external.object({
949
+ name: exports_external.string().optional(),
950
+ agents: exports_external.record(exports_external.string(), AgentOverrideConfigSchema).optional()
951
+ });
952
+ var HooksConfigSchema = exports_external.object({
953
+ system_enhancer: exports_external.boolean().default(true),
954
+ compaction: exports_external.boolean().default(true),
955
+ agent_activity: exports_external.boolean().default(true),
956
+ delegation_tracker: exports_external.boolean().default(false),
957
+ agent_awareness_max_chars: exports_external.number().min(50).max(2000).default(300),
958
+ delegation_gate: exports_external.boolean().default(true),
959
+ delegation_max_chars: exports_external.number().min(500).max(20000).default(4000),
960
+ background_subagents: exports_external.boolean().default(false),
961
+ background_pending_timeout_minutes: exports_external.number().int().min(1).max(1440).default(30)
962
+ });
963
+ var ScoringWeightsSchema = exports_external.object({
964
+ phase: exports_external.number().min(0).max(5).default(1),
965
+ current_task: exports_external.number().min(0).max(5).default(2),
966
+ blocked_task: exports_external.number().min(0).max(5).default(1.5),
967
+ recent_failure: exports_external.number().min(0).max(5).default(2.5),
968
+ recent_success: exports_external.number().min(0).max(5).default(0.5),
969
+ evidence_presence: exports_external.number().min(0).max(5).default(1),
970
+ decision_recency: exports_external.number().min(0).max(5).default(1.5),
971
+ dependency_proximity: exports_external.number().min(0).max(5).default(1)
972
+ });
973
+ var DecisionDecaySchema = exports_external.object({
974
+ mode: exports_external.enum(["linear", "exponential"]).default("exponential"),
975
+ half_life_hours: exports_external.number().min(1).max(168).default(24)
976
+ });
977
+ var TokenRatiosSchema = exports_external.object({
978
+ prose: exports_external.number().min(0.1).max(1).default(0.25),
979
+ code: exports_external.number().min(0.1).max(1).default(0.4),
980
+ markdown: exports_external.number().min(0.1).max(1).default(0.3),
981
+ json: exports_external.number().min(0.1).max(1).default(0.35)
982
+ });
983
+ var ScoringConfigSchema = exports_external.object({
984
+ enabled: exports_external.boolean().default(false),
985
+ max_candidates: exports_external.number().min(10).max(500).default(100),
986
+ weights: ScoringWeightsSchema.optional(),
987
+ decision_decay: DecisionDecaySchema.optional(),
988
+ token_ratios: TokenRatiosSchema.optional()
989
+ });
990
+ var ContextBudgetConfigSchema = exports_external.object({
991
+ enabled: exports_external.boolean().default(true),
992
+ warn_threshold: exports_external.number().min(0).max(1).default(0.7),
993
+ critical_threshold: exports_external.number().min(0).max(1).default(0.9),
994
+ model_limits: exports_external.record(exports_external.string(), exports_external.number().min(1000)).default({ default: 128000 }),
995
+ max_injection_tokens: exports_external.number().min(100).max(50000).default(4000),
996
+ tracked_agents: exports_external.array(exports_external.string()).default(["architect"]),
997
+ scoring: ScoringConfigSchema.optional(),
998
+ enforce: exports_external.boolean().default(true),
999
+ prune_target: exports_external.number().min(0).max(1).default(0.7),
1000
+ preserve_last_n_turns: exports_external.number().min(0).max(100).default(4),
1001
+ recent_window: exports_external.number().min(1).max(100).default(10),
1002
+ enforce_on_agent_switch: exports_external.boolean().default(true),
1003
+ tool_output_mask_threshold: exports_external.number().min(100).max(1e5).default(2000)
1004
+ });
1005
+ var EvidenceConfigSchema = exports_external.object({
1006
+ enabled: exports_external.boolean().default(true),
1007
+ max_age_days: exports_external.number().min(1).max(365).default(90),
1008
+ max_bundles: exports_external.number().min(10).max(1e4).default(1000),
1009
+ auto_archive: exports_external.boolean().default(false)
1010
+ });
1011
+ var GateFeatureSchema = exports_external.object({
1012
+ enabled: exports_external.boolean().default(true)
1013
+ });
1014
+ var PlaceholderScanConfigSchema = GateFeatureSchema.extend({
1015
+ deny_patterns: exports_external.array(exports_external.string()).default([
1016
+ "TODO",
1017
+ "FIXME",
1018
+ "TBD",
1019
+ "XXX",
1020
+ "placeholder",
1021
+ "stub",
1022
+ "wip",
1023
+ "not implemented"
1024
+ ]),
1025
+ allow_globs: exports_external.array(exports_external.string()).default([
1026
+ "docs/**",
1027
+ "examples/**",
1028
+ "tests/**",
1029
+ "**/*.test.*",
1030
+ "**/*.spec.*",
1031
+ "**/mocks/**",
1032
+ "**/__tests__/**"
1033
+ ]),
1034
+ max_allowed_findings: exports_external.number().min(0).default(0)
1035
+ });
1036
+ var QualityBudgetConfigSchema = GateFeatureSchema.extend({
1037
+ max_complexity_delta: exports_external.number().default(5),
1038
+ max_public_api_delta: exports_external.number().default(10),
1039
+ max_duplication_ratio: exports_external.number().default(0.05),
1040
+ min_test_to_code_ratio: exports_external.number().default(0.3),
1041
+ enforce_on_globs: exports_external.array(exports_external.string()).default(["src/**"]),
1042
+ exclude_globs: exports_external.array(exports_external.string()).default(["docs/**", "tests/**", "**/*.test.*"])
1043
+ });
1044
+ var GateConfigSchema = exports_external.object({
1045
+ syntax_check: GateFeatureSchema.default({ enabled: true }),
1046
+ placeholder_scan: PlaceholderScanConfigSchema.default({
1047
+ enabled: true,
1048
+ deny_patterns: [
1049
+ "TODO",
1050
+ "FIXME",
1051
+ "TBD",
1052
+ "XXX",
1053
+ "placeholder",
1054
+ "stub",
1055
+ "wip",
1056
+ "not implemented"
1057
+ ],
1058
+ allow_globs: [
1059
+ "docs/**",
1060
+ "examples/**",
1061
+ "tests/**",
1062
+ "**/*.test.*",
1063
+ "**/*.spec.*",
1064
+ "**/mocks/**",
1065
+ "**/__tests__/**"
1066
+ ],
1067
+ max_allowed_findings: 0
1068
+ }),
1069
+ sast_scan: GateFeatureSchema.default({ enabled: true }),
1070
+ sbom_generate: GateFeatureSchema.default({ enabled: true }),
1071
+ build_check: GateFeatureSchema.default({ enabled: true }),
1072
+ quality_budget: QualityBudgetConfigSchema
1073
+ });
1074
+ var PipelineConfigSchema = exports_external.object({
1075
+ parallel_precheck: exports_external.boolean().default(true)
1076
+ });
1077
+ var PhaseCompleteConfigSchema = exports_external.object({
1078
+ enabled: exports_external.boolean().default(true),
1079
+ required_agents: exports_external.array(exports_external.enum(["coder", "reviewer", "test_engineer"])).default(["coder", "reviewer", "test_engineer"]),
1080
+ require_docs: exports_external.boolean().default(true),
1081
+ policy: exports_external.enum(["enforce", "warn"]).default("enforce"),
1082
+ regression_sweep: exports_external.object({
1083
+ enforce: exports_external.boolean().default(false)
1084
+ }).optional()
1085
+ });
1086
+ var SummaryConfigSchema = exports_external.object({
1087
+ enabled: exports_external.boolean().default(true),
1088
+ threshold_bytes: exports_external.number().min(1024).max(1048576).default(16384),
1089
+ max_summary_chars: exports_external.number().min(100).max(5000).default(1000),
1090
+ max_stored_bytes: exports_external.number().min(10240).max(104857600).default(10485760),
1091
+ retention_days: exports_external.number().min(1).max(365).default(7),
1092
+ exempt_tools: exports_external.array(exports_external.string()).default(["retrieve_summary", "task", "read"])
1093
+ });
1094
+ var ReviewPassesConfigSchema = exports_external.object({
1095
+ always_security_review: exports_external.boolean().default(false),
1096
+ security_globs: exports_external.array(exports_external.string()).default([
1097
+ "**/auth/**",
1098
+ "**/api/**",
1099
+ "**/crypto/**",
1100
+ "**/security/**",
1101
+ "**/middleware/**",
1102
+ "**/session/**",
1103
+ "**/token/**"
1104
+ ])
1105
+ });
1106
+ var AutoReviewConfigSchema = exports_external.object({
1107
+ enabled: exports_external.boolean().default(false),
1108
+ trigger: exports_external.enum(["task_completion", "phase_boundary", "both"]).default("phase_boundary"),
1109
+ timeout_ms: exports_external.number().int().min(1e4).max(1800000).default(300000),
1110
+ max_diff_kb: exports_external.number().int().min(16).max(2048).default(256)
1111
+ });
1112
+ var AdversarialDetectionConfigSchema = exports_external.object({
1113
+ enabled: exports_external.boolean().default(true),
1114
+ policy: exports_external.enum(["warn", "gate", "ignore"]).default("warn"),
1115
+ pairs: exports_external.array(exports_external.tuple([exports_external.string(), exports_external.string()])).default([["coder", "reviewer"]])
1116
+ });
1117
+ var AdversarialTestingConfigSchemaBase = exports_external.object({
1118
+ enabled: exports_external.boolean().default(true),
1119
+ scope: exports_external.enum(["all", "security-only"]).default("all")
1120
+ });
1121
+ var AdversarialTestingConfigSchema = AdversarialTestingConfigSchemaBase.default(() => ({
1122
+ enabled: true,
1123
+ scope: "all"
1124
+ }));
1125
+ var IntegrationAnalysisConfigSchema = exports_external.object({
1126
+ enabled: exports_external.boolean().default(true)
1127
+ });
1128
+ var DocsConfigSchema = exports_external.object({
1129
+ enabled: exports_external.boolean().default(true),
1130
+ doc_patterns: exports_external.array(exports_external.string()).default([
1131
+ "README.md",
1132
+ "CONTRIBUTING.md",
1133
+ "docs/**/*.md",
1134
+ "docs/**/*.rst",
1135
+ "**/CHANGELOG.md"
1136
+ ])
1137
+ });
1138
+ var DesignDocsConfigSchema = exports_external.object({
1139
+ enabled: exports_external.boolean().default(false),
1140
+ out_dir: exports_external.string().default("docs").refine((v) => v.length > 0 && v !== "." && !v.includes("..") && !v.startsWith("/") && !v.startsWith("\\") && !/^[A-Za-z]:/.test(v), {
1141
+ message: 'design_docs.out_dir must be a non-empty project-relative path with no "..", leading slash, or drive letter'
1142
+ }),
1143
+ language: exports_external.string().optional()
1144
+ });
1145
+ var UIReviewConfigSchema = exports_external.object({
1146
+ enabled: exports_external.boolean().default(false),
1147
+ trigger_paths: exports_external.array(exports_external.string()).default([
1148
+ "**/pages/**",
1149
+ "**/components/**",
1150
+ "**/views/**",
1151
+ "**/screens/**",
1152
+ "**/ui/**",
1153
+ "**/layouts/**"
1154
+ ]),
1155
+ trigger_keywords: exports_external.array(exports_external.string()).default([
1156
+ "new page",
1157
+ "new screen",
1158
+ "new component",
1159
+ "redesign",
1160
+ "layout change",
1161
+ "form",
1162
+ "modal",
1163
+ "dialog",
1164
+ "dropdown",
1165
+ "sidebar",
1166
+ "navbar",
1167
+ "dashboard",
1168
+ "landing page",
1169
+ "signup",
1170
+ "login form",
1171
+ "settings page",
1172
+ "profile page"
1173
+ ])
1174
+ });
1175
+ var CompactionAdvisoryConfigSchema = exports_external.object({
1176
+ enabled: exports_external.boolean().default(true),
1177
+ thresholds: exports_external.array(exports_external.number().int().min(10).max(500)).default([50, 75, 100, 125, 150]),
1178
+ message: exports_external.string().default("[SWARM HINT] Session has " + "$" + "{totalToolCalls} tool calls. Consider compacting at next phase boundary to maintain context quality.")
1179
+ });
1180
+ var LintConfigSchema = exports_external.object({
1181
+ enabled: exports_external.boolean().default(true),
1182
+ mode: exports_external.enum(["check", "fix"]).default("check"),
1183
+ linter: exports_external.enum(["biome", "eslint", "auto"]).default("auto"),
1184
+ patterns: exports_external.array(exports_external.string()).default([
1185
+ "**/*.{ts,tsx,js,jsx,mjs,cjs}",
1186
+ "**/biome.json",
1187
+ "**/biome.jsonc"
1188
+ ]),
1189
+ exclude: exports_external.array(exports_external.string()).default([
1190
+ "**/node_modules/**",
1191
+ "**/dist/**",
1192
+ "**/.git/**",
1193
+ "**/coverage/**",
1194
+ "**/*.min.js"
1195
+ ])
1196
+ });
1197
+ var SecretscanConfigSchema = exports_external.object({
1198
+ enabled: exports_external.boolean().default(true),
1199
+ patterns: exports_external.array(exports_external.string()).default([
1200
+ "**/*.{env,properties,yml,yaml,json,js,ts}",
1201
+ "**/.env*",
1202
+ "**/secrets/**",
1203
+ "**/credentials/**",
1204
+ "**/config/**/*.ts",
1205
+ "**/config/**/*.js"
1206
+ ]),
1207
+ exclude: exports_external.array(exports_external.string()).default([
1208
+ "**/node_modules/**",
1209
+ "**/dist/**",
1210
+ "**/.git/**",
1211
+ "**/coverage/**",
1212
+ "**/test/**",
1213
+ "**/tests/**",
1214
+ "**/__tests__/**",
1215
+ "**/*.test.ts",
1216
+ "**/*.test.js",
1217
+ "**/*.spec.ts",
1218
+ "**/*.spec.js"
1219
+ ]),
1220
+ extensions: exports_external.array(exports_external.string()).default([
1221
+ ".env",
1222
+ ".properties",
1223
+ ".yml",
1224
+ ".yaml",
1225
+ ".json",
1226
+ ".js",
1227
+ ".ts",
1228
+ ".py",
1229
+ ".rb",
1230
+ ".go",
1231
+ ".java",
1232
+ ".cs",
1233
+ ".php"
1234
+ ])
1235
+ });
1236
+ var GuardrailsProfileSchema = exports_external.object({
1237
+ max_tool_calls: exports_external.number().min(0).max(1000).optional(),
1238
+ max_duration_minutes: exports_external.number().min(0).max(480).optional(),
1239
+ max_repetitions: exports_external.number().min(3).max(50).optional(),
1240
+ max_consecutive_errors: exports_external.number().min(2).max(20).optional(),
1241
+ warning_threshold: exports_external.number().min(0.1).max(0.9).optional(),
1242
+ idle_timeout_minutes: exports_external.number().min(5).max(240).optional(),
1243
+ max_transient_retries: exports_external.number().min(0).max(20).optional()
1244
+ });
1245
+ var DEFAULT_AGENT_PROFILES = {
1246
+ architect: {
1247
+ max_tool_calls: 0,
1248
+ max_duration_minutes: 0,
1249
+ max_consecutive_errors: 8,
1250
+ warning_threshold: 0.75
1251
+ },
1252
+ coder: {
1253
+ max_tool_calls: 400,
1254
+ max_duration_minutes: 45,
1255
+ max_consecutive_errors: 8,
1256
+ warning_threshold: 0.85
1257
+ },
1258
+ test_engineer: {
1259
+ max_tool_calls: 400,
1260
+ max_duration_minutes: 45,
1261
+ max_consecutive_errors: 8,
1262
+ warning_threshold: 0.85
1263
+ },
1264
+ explorer: {
1265
+ max_tool_calls: 150,
1266
+ max_duration_minutes: 20,
1267
+ max_consecutive_errors: 8,
1268
+ warning_threshold: 0.75
1269
+ },
1270
+ reviewer: {
1271
+ max_tool_calls: 200,
1272
+ max_duration_minutes: 30,
1273
+ max_consecutive_errors: 8,
1274
+ warning_threshold: 0.65
1275
+ },
1276
+ critic: {
1277
+ max_tool_calls: 200,
1278
+ max_duration_minutes: 30,
1279
+ warning_threshold: 0.65
1280
+ },
1281
+ sme: {
1282
+ max_tool_calls: 200,
1283
+ max_duration_minutes: 30,
1284
+ warning_threshold: 0.65
1285
+ },
1286
+ docs: {
1287
+ max_tool_calls: 200,
1288
+ max_duration_minutes: 30,
1289
+ warning_threshold: 0.75
1290
+ },
1291
+ designer: {
1292
+ max_tool_calls: 150,
1293
+ max_duration_minutes: 20,
1294
+ warning_threshold: 0.75
1295
+ }
1296
+ };
1297
+ var DEFAULT_ARCHITECT_PROFILE = DEFAULT_AGENT_PROFILES.architect;
1298
+ var GuardrailsConfigSchema = exports_external.object({
1299
+ enabled: exports_external.boolean().default(true),
1300
+ max_tool_calls: exports_external.number().min(0).max(1000).default(200),
1301
+ max_duration_minutes: exports_external.number().min(0).max(480).default(30),
1302
+ max_repetitions: exports_external.number().min(3).max(50).default(10),
1303
+ max_consecutive_errors: exports_external.number().min(2).max(20).default(5),
1304
+ max_transient_retries: exports_external.number().min(0).max(20).default(5),
1305
+ warning_threshold: exports_external.number().min(0.1).max(0.9).default(0.75),
1306
+ idle_timeout_minutes: exports_external.number().min(5).max(240).default(60),
1307
+ no_op_warning_threshold: exports_external.number().min(1).max(100).default(15),
1308
+ max_coder_revisions: exports_external.number().int().min(1).max(20).default(5),
1309
+ runaway_output_max_turns: exports_external.number().int().min(1).max(20).default(5),
1310
+ qa_gates: exports_external.object({
1311
+ required_tools: exports_external.array(exports_external.string().min(1)).default([
1312
+ "diff",
1313
+ "syntax_check",
1314
+ "placeholder_scan",
1315
+ "lint",
1316
+ "pre_check_batch"
1317
+ ]),
1318
+ require_reviewer_test_engineer: exports_external.boolean().default(true)
1319
+ }).optional(),
1320
+ profiles: exports_external.record(exports_external.string(), GuardrailsProfileSchema).optional(),
1321
+ block_destructive_commands: exports_external.boolean().default(true),
1322
+ interpreter_allowed_agents: exports_external.array(exports_external.string().min(1)).optional(),
1323
+ shell_audit_log: exports_external.boolean().default(true)
1324
+ });
1325
+ var WatchdogConfigSchema = exports_external.object({
1326
+ scope_guard: exports_external.boolean().default(true),
1327
+ skip_in_turbo: exports_external.boolean().default(false),
1328
+ delegation_ledger: exports_external.boolean().default(true)
1329
+ });
1330
+ var SelfReviewConfigSchema = exports_external.object({
1331
+ enabled: exports_external.boolean().default(true),
1332
+ skip_in_turbo: exports_external.boolean().default(true)
1333
+ });
1334
+ function resolveGuardrailsConfig(config, agentName) {
1335
+ if (!agentName) {
1336
+ return config;
1337
+ }
1338
+ const canonicalName = _internals.stripKnownSwarmPrefix(agentName);
1339
+ const hasBuiltInProfile = canonicalName in DEFAULT_AGENT_PROFILES;
1340
+ const userProfile = config.profiles?.[agentName] ?? config.profiles?.[canonicalName];
1341
+ if (!hasBuiltInProfile) {
1342
+ if (userProfile) {
1343
+ return { ...config, ...userProfile };
1344
+ }
1345
+ return config;
1346
+ }
1347
+ const builtInProfile = DEFAULT_AGENT_PROFILES[canonicalName];
1348
+ const resolved = {
1349
+ ...config,
1350
+ ...builtInProfile,
1351
+ ...userProfile || {}
1352
+ };
1353
+ return resolved;
1354
+ }
1355
+ var ToolFilterConfigSchema = exports_external.object({
1356
+ enabled: exports_external.boolean().default(true),
1357
+ overrides: exports_external.record(exports_external.string(), exports_external.array(exports_external.string())).default({})
1358
+ });
1359
+ var PlanCursorConfigSchema = exports_external.object({
1360
+ enabled: exports_external.boolean().default(true),
1361
+ max_tokens: exports_external.number().min(500).max(4000).default(1500),
1362
+ lookahead_tasks: exports_external.number().min(0).max(5).default(2)
1363
+ });
1364
+ var ContextMapConfigSchema = exports_external.object({
1365
+ enabled: exports_external.boolean().default(false),
1366
+ mode: exports_external.enum(["conservative", "balanced", "aggressive"]).default("balanced"),
1367
+ max_capsule_tokens: exports_external.number().int().positive().default(2000),
1368
+ invalidate_on_hash_change: exports_external.boolean().default(true),
1369
+ agent_profiles: exports_external.record(exports_external.string(), exports_external.string()).default({})
1370
+ });
1371
+ var RepoGraphConfigSchema = exports_external.object({
1372
+ exclude_dirs: exports_external.array(exports_external.string().trim().min(1)).default([])
1373
+ });
1374
+ var CheckpointConfigSchema = exports_external.object({
1375
+ enabled: exports_external.boolean().default(true),
1376
+ auto_checkpoint_threshold: exports_external.number().int().min(1).max(20).default(3),
1377
+ allow_empty_commits: exports_external.boolean().default(false)
1378
+ }).strict();
1379
+ var AutomationModeSchema = exports_external.enum(["manual", "hybrid", "auto"]);
1380
+ var AutomationCapabilitiesSchema = exports_external.object({
1381
+ plan_sync: exports_external.boolean().default(true),
1382
+ phase_preflight: exports_external.boolean().default(false),
1383
+ config_doctor_on_startup: exports_external.boolean().default(false),
1384
+ config_doctor_autofix: exports_external.boolean().default(false),
1385
+ evidence_auto_summaries: exports_external.boolean().default(true),
1386
+ decision_drift_detection: exports_external.boolean().default(true)
1387
+ });
1388
+ var AutomationConfigSchemaBase = exports_external.object({
1389
+ mode: AutomationModeSchema.default("manual"),
1390
+ capabilities: AutomationCapabilitiesSchema.default({
1391
+ plan_sync: true,
1392
+ phase_preflight: false,
1393
+ config_doctor_on_startup: false,
1394
+ config_doctor_autofix: false,
1395
+ evidence_auto_summaries: true,
1396
+ decision_drift_detection: true
1397
+ })
1398
+ });
1399
+ var AutomationConfigSchema = AutomationConfigSchemaBase;
1400
+ var KnowledgeConfigSchema = exports_external.object({
1401
+ enabled: exports_external.boolean().default(true),
1402
+ swarm_max_entries: exports_external.number().min(1).max(1e4).default(100),
1403
+ hive_max_entries: exports_external.number().min(1).max(1e5).default(200),
1404
+ auto_promote_days: exports_external.number().min(1).max(3650).default(90),
1405
+ max_inject_count: exports_external.number().min(0).max(50).default(5),
1406
+ delegate_max_inject_count: exports_external.number().min(0).max(50).default(8),
1407
+ inject_char_budget: exports_external.number().min(200).max(1e4).default(2000),
1408
+ context_budget_threshold: exports_external.number().int().positive().optional(),
1409
+ max_lesson_display_chars: exports_external.number().min(40).max(280).default(120),
1410
+ dedup_threshold: exports_external.number().min(0).max(1).default(0.6),
1411
+ scope_filter: exports_external.array(exports_external.string()).default(["global"]),
1412
+ hive_enabled: exports_external.boolean().default(true),
1413
+ rejected_max_entries: exports_external.number().min(1).max(1000).default(20),
1414
+ validation_enabled: exports_external.boolean().default(true),
1415
+ evergreen_confidence: exports_external.number().min(0).max(1).default(0.9),
1416
+ evergreen_utility: exports_external.number().min(0).max(1).default(0.8),
1417
+ low_utility_threshold: exports_external.number().min(0).max(1).default(0.3),
1418
+ min_retrievals_for_utility: exports_external.number().min(1).max(100).default(3),
1419
+ schema_version: exports_external.number().int().min(1).default(1),
1420
+ directive_min_confidence: exports_external.number().min(0).max(1).default(0.75),
1421
+ same_project_weight: exports_external.number().min(0).max(5).default(1),
1422
+ cross_project_weight: exports_external.number().min(0).max(5).default(0.5),
1423
+ min_encounter_score: exports_external.number().min(0).max(1).default(0.1),
1424
+ initial_encounter_score: exports_external.number().min(0).max(5).default(1),
1425
+ encounter_increment: exports_external.number().min(0).max(1).default(0.1),
1426
+ max_encounter_score: exports_external.number().min(1).max(20).default(10),
1427
+ default_max_phases: exports_external.number().int().positive().default(10),
1428
+ todo_max_phases: exports_external.number().int().positive().default(3),
1429
+ sweep_enabled: exports_external.boolean().default(true),
1430
+ retrieval: exports_external.object({
1431
+ mmr_lambda: exports_external.number().min(0).max(1).default(0.5),
1432
+ cold_start_bonus: exports_external.number().min(0).max(0.5).default(0.08),
1433
+ cold_start_max_age_phases: exports_external.number().int().min(0).max(100).default(3),
1434
+ synonym_min_cooccurrence: exports_external.number().int().min(1).max(100).default(3),
1435
+ synonym_map_max_pairs: exports_external.number().int().min(1).max(1e4).default(500)
1436
+ }).optional(),
1437
+ enrichment: exports_external.object({
1438
+ max_calls_per_day: exports_external.number().int().min(0).max(1000).default(30),
1439
+ quota_window: exports_external.enum(["utc", "local"]).default("utc"),
1440
+ batch_size: exports_external.number().int().min(1).max(100).optional()
1441
+ }).default({ max_calls_per_day: 30, quota_window: "utc" })
1442
+ });
1443
+ var MemoryConfigSchema = exports_external.object({
1444
+ enabled: exports_external.boolean().default(false),
1445
+ provider: exports_external.enum(["local-jsonl", "sqlite"]).default("sqlite"),
1446
+ storageDir: exports_external.string().default(".swarm/memory"),
1447
+ sqlite: exports_external.object({
1448
+ path: exports_external.string().default(".swarm/memory/memory.db"),
1449
+ busyTimeoutMs: exports_external.number().int().min(0).max(60000).default(5000)
1450
+ }).default({ path: ".swarm/memory/memory.db", busyTimeoutMs: 5000 }),
1451
+ recall: exports_external.object({
1452
+ defaultMaxItems: exports_external.number().int().min(1).max(20).default(8),
1453
+ defaultTokenBudget: exports_external.number().int().min(100).max(5000).default(1200),
1454
+ minScore: exports_external.number().min(0).max(1).default(0.05),
1455
+ injection: exports_external.object({
1456
+ enabled: exports_external.boolean().default(true),
1457
+ minScore: exports_external.number().min(0).max(1).default(0.25),
1458
+ requireQuerySignal: exports_external.boolean().default(true),
1459
+ maxItems: exports_external.number().int().min(1).max(20).default(6),
1460
+ tokenBudget: exports_external.number().int().min(100).max(5000).default(1000)
1461
+ }).default({
1462
+ enabled: true,
1463
+ minScore: 0.25,
1464
+ requireQuerySignal: true,
1465
+ maxItems: 6,
1466
+ tokenBudget: 1000
1467
+ })
1468
+ }).default({
1469
+ defaultMaxItems: 8,
1470
+ defaultTokenBudget: 1200,
1471
+ minScore: 0.05,
1472
+ injection: {
1473
+ enabled: true,
1474
+ minScore: 0.25,
1475
+ requireQuerySignal: true,
1476
+ maxItems: 6,
1477
+ tokenBudget: 1000
1478
+ }
1479
+ }),
1480
+ writes: exports_external.object({
1481
+ mode: exports_external.literal("propose").default("propose")
1482
+ }).default({ mode: "propose" }),
1483
+ redaction: exports_external.object({
1484
+ rejectDurableSecrets: exports_external.boolean().default(true)
1485
+ }).default({ rejectDurableSecrets: true }),
1486
+ maintenance: exports_external.object({
1487
+ lowUtilityMaxConfidence: exports_external.number().min(0).max(1).default(0.45),
1488
+ lowUtilityMinAgeDays: exports_external.number().int().min(1).max(3650).default(30)
1489
+ }).default({
1490
+ lowUtilityMaxConfidence: 0.45,
1491
+ lowUtilityMinAgeDays: 30
1492
+ }),
1493
+ hardDelete: exports_external.boolean().default(false)
1494
+ });
1495
+ var CuratorConfigSchema = exports_external.object({
1496
+ enabled: exports_external.boolean().default(true),
1497
+ init_enabled: exports_external.boolean().default(true),
1498
+ phase_enabled: exports_external.boolean().default(true),
1499
+ postmortem_enabled: exports_external.boolean().default(true),
1500
+ max_summary_tokens: exports_external.number().min(500).max(8000).default(2000),
1501
+ min_knowledge_confidence: exports_external.number().min(0).max(1).default(0.7),
1502
+ compliance_report: exports_external.boolean().default(true),
1503
+ suppress_warnings: exports_external.boolean().default(true),
1504
+ drift_inject_max_chars: exports_external.number().min(100).max(2000).default(500),
1505
+ llm_timeout_ms: exports_external.number().int().min(5000).max(600000).default(300000),
1506
+ skill_generation_enabled: exports_external.boolean().default(true),
1507
+ skill_generation_mode: exports_external.enum(["draft", "active"]).default("draft"),
1508
+ min_skill_confidence: exports_external.number().min(0).max(1).default(0.7),
1509
+ min_skill_confirmations: exports_external.number().int().min(1).max(50).default(2)
1510
+ });
1511
+ var ArchitecturalSupervisionConfigSchema = exports_external.object({
1512
+ enabled: exports_external.boolean().default(false),
1513
+ mode: exports_external.enum(["advisory", "gate"]).default("advisory"),
1514
+ run_on: exports_external.enum(["phase_complete"]).default("phase_complete"),
1515
+ summary_model: exports_external.string().min(1).optional(),
1516
+ max_agent_summary_words: exports_external.number().int().min(20).max(500).default(100),
1517
+ max_phase_summary_words: exports_external.number().int().min(50).max(1000).default(250),
1518
+ allow_concerns_to_complete: exports_external.boolean().default(true),
1519
+ persist_knowledge_recommendations: exports_external.boolean().default(false),
1520
+ provenance_verify: exports_external.boolean().default(false)
1521
+ });
1522
+ var KnowledgeApplicationConfigSchema = exports_external.object({
1523
+ enabled: exports_external.boolean().default(true),
1524
+ mode: exports_external.enum(["warn", "enforce"]).default("warn"),
1525
+ min_confidence: exports_external.number().min(0).max(1).default(0.85),
1526
+ critical_requires_ack: exports_external.boolean().default(true),
1527
+ require_skill_refs: exports_external.boolean().default(true),
1528
+ high_risk_tools: exports_external.array(exports_external.string()).default([
1529
+ "save_plan",
1530
+ "update_task_status",
1531
+ "phase_complete",
1532
+ "task",
1533
+ "Task"
1534
+ ])
1535
+ });
1536
+ var SkillPropagationConfigSchema = exports_external.object({
1537
+ enabled: exports_external.boolean().default(true),
1538
+ enforce: exports_external.boolean().default(false)
1539
+ });
1540
+ var SkillImproverConfigSchema = exports_external.object({
1541
+ enabled: exports_external.boolean().default(false),
1542
+ model: exports_external.string().nullable().default(null),
1543
+ fallback_models: exports_external.array(exports_external.string()).default([]),
1544
+ max_calls_per_day: exports_external.number().int().min(1).max(1000).default(10),
1545
+ trigger: exports_external.enum(["manual", "scheduled"]).default("manual"),
1546
+ consolidation_interval_hours: exports_external.number().int().min(1).max(24 * 30).default(24),
1547
+ consolidation_max_calls_per_run: exports_external.number().int().min(1).max(100).default(1),
1548
+ targets: exports_external.array(exports_external.enum(["skills", "spec", "architect_prompt", "knowledge"])).default(["skills", "spec", "architect_prompt", "knowledge"]),
1549
+ write_mode: exports_external.enum(["proposal", "draft_skills"]).default("proposal"),
1550
+ require_user_approval: exports_external.boolean().default(true),
1551
+ quota_window: exports_external.enum(["utc", "local"]).default("utc"),
1552
+ allow_deterministic_fallback: exports_external.boolean().default(true)
1553
+ });
1554
+ var SpecWriterConfigSchema = exports_external.object({
1555
+ enabled: exports_external.boolean().default(true),
1556
+ model: exports_external.string().nullable().default(null),
1557
+ fallback_models: exports_external.array(exports_external.string()).default([]),
1558
+ allow_spec_write: exports_external.boolean().default(true)
1559
+ });
1560
+ var SlopDetectorConfigSchema = exports_external.object({
1561
+ enabled: exports_external.boolean().default(true),
1562
+ classThreshold: exports_external.number().int().min(1).default(3),
1563
+ commentStripThreshold: exports_external.number().int().min(1).default(5),
1564
+ diffLineThreshold: exports_external.number().int().min(10).default(200),
1565
+ importHygieneThreshold: exports_external.number().int().min(1).default(2)
1566
+ });
1567
+ var IncrementalVerifyConfigSchema = exports_external.object({
1568
+ enabled: exports_external.boolean().default(true),
1569
+ command: exports_external.union([exports_external.string(), exports_external.array(exports_external.string())]).nullable().default(null),
1570
+ timeoutMs: exports_external.number().int().min(1000).max(300000).default(30000),
1571
+ triggerAgents: exports_external.array(exports_external.string()).default(["coder"])
1572
+ });
1573
+ var CompactionConfigSchema = exports_external.object({
1574
+ enabled: exports_external.boolean().default(true),
1575
+ observationThreshold: exports_external.number().min(1).max(99).default(40),
1576
+ reflectionThreshold: exports_external.number().min(1).max(99).default(60),
1577
+ emergencyThreshold: exports_external.number().min(1).max(99).default(80),
1578
+ preserveLastNTurns: exports_external.number().int().min(1).default(5)
1579
+ });
1580
+ var PrmConfigSchema = exports_external.object({
1581
+ enabled: exports_external.boolean().default(true),
1582
+ pattern_thresholds: exports_external.object({
1583
+ repetition_loop: exports_external.number().min(1).default(2),
1584
+ ping_pong: exports_external.number().min(1).default(2),
1585
+ expansion_drift: exports_external.number().min(1).default(3),
1586
+ stuck_on_test: exports_external.number().min(1).default(3),
1587
+ context_thrash: exports_external.number().min(1).default(3)
1588
+ }).default(() => ({
1589
+ repetition_loop: 2,
1590
+ ping_pong: 2,
1591
+ expansion_drift: 3,
1592
+ stuck_on_test: 3,
1593
+ context_thrash: 3
1594
+ })),
1595
+ max_trajectory_lines: exports_external.number().min(10).default(1000),
1596
+ escalation_enabled: exports_external.boolean().default(true),
1597
+ detection_timeout_ms: exports_external.number().min(10).default(100)
1598
+ });
1599
+ var AgentAuthorityRuleSchema = exports_external.object({
1600
+ readOnly: exports_external.boolean().optional(),
1601
+ blockedExact: exports_external.array(exports_external.string()).optional(),
1602
+ allowedExact: exports_external.array(exports_external.string()).optional(),
1603
+ blockedPrefix: exports_external.array(exports_external.string()).optional(),
1604
+ allowedPrefix: exports_external.array(exports_external.string()).optional(),
1605
+ blockedZones: exports_external.array(exports_external.enum(["production", "test", "config", "generated", "docs", "build"])).optional(),
1606
+ blockedGlobs: exports_external.array(exports_external.string()).optional(),
1607
+ allowedGlobs: exports_external.array(exports_external.string()).optional(),
1608
+ allowedCaseSensitiveGlobs: exports_external.array(exports_external.string()).optional()
1609
+ });
1610
+ var AuthorityConfigSchema = exports_external.object({
1611
+ enabled: exports_external.boolean().default(true),
1612
+ rules: exports_external.record(exports_external.string(), AgentAuthorityRuleSchema).default({}),
1613
+ universal_deny_prefixes: exports_external.array(exports_external.string().min(1)).default([]),
1614
+ verifier_config_paths: exports_external.array(exports_external.string()).optional().describe("Additional glob patterns for verifier config files that are merged into the architect agent's blockedGlobs at plugin init. Writes to matching files are blocked by the authority layer.")
1615
+ });
1616
+ var GeneralCouncilMemberConfigSchema = exports_external.object({
1617
+ memberId: exports_external.string().min(1),
1618
+ model: exports_external.string().min(1),
1619
+ role: exports_external.enum([
1620
+ "generalist",
1621
+ "skeptic",
1622
+ "domain_expert",
1623
+ "devil_advocate",
1624
+ "synthesizer"
1625
+ ]),
1626
+ persona: exports_external.string().optional()
1627
+ }).strict();
1628
+ var GeneralCouncilConfigSchema = exports_external.object({
1629
+ enabled: exports_external.boolean().default(false),
1630
+ searchProvider: exports_external.enum(["tavily", "brave"]).default("tavily"),
1631
+ searchApiKey: exports_external.string().optional(),
1632
+ members: exports_external.array(GeneralCouncilMemberConfigSchema).default([]),
1633
+ presets: exports_external.record(exports_external.string(), exports_external.array(GeneralCouncilMemberConfigSchema)).default({}),
1634
+ deliberate: exports_external.boolean().default(true),
1635
+ moderator: exports_external.boolean().default(true),
1636
+ moderatorModel: exports_external.string().optional(),
1637
+ maxSourcesPerMember: exports_external.number().int().min(1).max(20).default(5)
1638
+ }).strict();
1639
+ var CouncilConfigSchema = exports_external.object({
1640
+ enabled: exports_external.boolean().default(false),
1641
+ maxRounds: exports_external.number().int().min(1).max(10).default(3),
1642
+ parallelTimeoutMs: exports_external.number().int().min(5000).max(120000).default(30000),
1643
+ vetoPriority: exports_external.boolean().default(true),
1644
+ requireAllMembers: exports_external.boolean().default(false).describe("When true, submit_council_verdicts rejects if fewer than 5 member verdicts are provided. Equivalent to minimumMembers: 5."),
1645
+ minimumMembers: exports_external.number().int().min(1).max(5).default(3).describe("Minimum distinct council member verdicts required for synthesis. Default 3. Set to 1 to disable quorum enforcement. requireAllMembers: true overrides this to 5 (stricter constraint wins)."),
1646
+ escalateOnMaxRounds: exports_external.string().optional().describe("Optional webhook URL or handler name invoked when maxRounds is reached without APPROVE. Declared for forward compatibility; no behavior is implemented yet."),
1647
+ phaseConcernsAllowComplete: exports_external.boolean().default(true).describe("When true, a phase-level council CONCERNS verdict with only MEDIUM/LOW findings does NOT block phase completion \u2014 the advisory notes are logged as warnings and the phase proceeds. When false, CONCERNS blocks like REJECT. Note: HIGH/CRITICAL findings from CONCERNS members are always promoted to requiredFixes and block at the tool level regardless of this setting. Default: true."),
1648
+ general: GeneralCouncilConfigSchema.optional()
1649
+ }).strict();
1650
+ var PrMonitorConfigSchema = exports_external.object({
1651
+ enabled: exports_external.boolean().default(false),
1652
+ poll_interval_seconds: exports_external.number().int().min(30).max(300).default(60),
1653
+ max_subscriptions: exports_external.number().int().min(1).max(100).default(20),
1654
+ max_prs_per_cycle: exports_external.number().int().min(1).max(20).default(5),
1655
+ max_concurrent_pr_polls: exports_external.number().int().min(1).max(10).default(3),
1656
+ poll_timeout_ms: exports_external.number().int().min(5000).max(120000).default(30000),
1657
+ failure_threshold: exports_external.number().int().min(1).max(20).default(5),
1658
+ cooldown_seconds: exports_external.number().int().min(5).max(600).default(30),
1659
+ max_cooldown_seconds: exports_external.number().int().min(30).max(3600).default(300),
1660
+ cleanup_ttl_days: exports_external.number().int().min(1).max(90).default(7),
1661
+ auto_unsubscribe_on_merge: exports_external.boolean().default(true),
1662
+ auto_unsubscribe_on_close: exports_external.boolean().default(true),
1663
+ notify_ci_failure: exports_external.boolean().default(true),
1664
+ notify_new_comments: exports_external.boolean().default(true),
1665
+ notify_merge_conflict: exports_external.boolean().default(true),
1666
+ auto_pr_feedback: exports_external.boolean().default(false)
1667
+ }).strict();
1668
+ var ParallelizationConfigSchema = exports_external.object({
1669
+ enabled: exports_external.boolean().default(false),
1670
+ maxConcurrentTasks: exports_external.number().int().min(1).max(64).default(1),
1671
+ evidenceLockTimeoutMs: exports_external.number().int().min(1000).max(300000).default(60000),
1672
+ max_coders: exports_external.number().int().min(1).max(16).default(3),
1673
+ max_reviewers: exports_external.number().int().min(1).max(16).default(2)
1674
+ });
1675
+ var WorktreeIsolationConfigSchema = exports_external.object({
1676
+ policy: exports_external.enum(["auto", "required", "disabled"]).default("auto"),
1677
+ merge_strategy: exports_external.enum(["merge", "rebase", "cherry-pick"]).default("merge"),
1678
+ worktree_dir: exports_external.string().optional(),
1679
+ deps_strategy: exports_external.enum(["skip", "copy", "link"]).default("skip")
1680
+ });
1681
+ var LeanTurboConfigSchema = exports_external.object({
1682
+ max_parallel_coders: exports_external.number().int().min(1).max(6).default(4),
1683
+ require_declared_scope: exports_external.boolean().default(true),
1684
+ conflict_policy: exports_external.enum(["serialize", "degrade"]).default("serialize"),
1685
+ degrade_on_risk: exports_external.boolean().default(true),
1686
+ phase_reviewer: exports_external.boolean().default(true),
1687
+ phase_critic: exports_external.boolean().default(true),
1688
+ integrated_diff_required: exports_external.boolean().default(true),
1689
+ allow_docs_only_without_reviewer: exports_external.boolean().default(false),
1690
+ worktree_isolation: exports_external.boolean().default(false),
1691
+ merge_strategy: exports_external.enum(["merge", "rebase", "cherry-pick"]).default("merge").optional(),
1692
+ worktree_dir: exports_external.string().optional()
1693
+ });
1694
+ var StandardTurboConfigSchema = exports_external.object({
1695
+ strategy: exports_external.literal("standard"),
1696
+ lean: LeanTurboConfigSchema.optional()
1697
+ });
1698
+ var LeanTurboStrategyConfigSchema = exports_external.object({
1699
+ strategy: exports_external.literal("lean"),
1700
+ lean: LeanTurboConfigSchema
1701
+ });
1702
+ var TurboConfigSchema = exports_external.discriminatedUnion("strategy", [
1703
+ StandardTurboConfigSchema,
1704
+ LeanTurboStrategyConfigSchema
1705
+ ]);
1706
+ var ExternalSkillCandidateSourceTypeSchema = exports_external.enum([
1707
+ "github",
1708
+ "url",
1709
+ "collection",
1710
+ "manual_import"
1711
+ ]);
1712
+ var ExternalSkillCandidateEvaluationVerdictSchema = exports_external.enum([
1713
+ "pending",
1714
+ "in_review",
1715
+ "quarantined",
1716
+ "passed",
1717
+ "rejected",
1718
+ "promoted",
1719
+ "revoked"
1720
+ ]);
1721
+ var DiscoverySourceSchema = exports_external.object({
1722
+ type: ExternalSkillCandidateSourceTypeSchema,
1723
+ location: exports_external.string().min(1),
1724
+ enabled: exports_external.boolean().default(true),
1725
+ trust_level: exports_external.enum(["low", "medium", "high"]).default("low").optional()
1726
+ });
1727
+ var ExternalSkillCandidateSchema = exports_external.object({
1728
+ id: exports_external.string().uuid(),
1729
+ source_url: exports_external.string().url(),
1730
+ source_type: ExternalSkillCandidateSourceTypeSchema,
1731
+ publisher: exports_external.string().min(1),
1732
+ sha256: exports_external.string().regex(/^[a-f0-9]{64}$/),
1733
+ fetched_at: exports_external.string().datetime(),
1734
+ skill_name: exports_external.string().optional(),
1735
+ skill_description: exports_external.string().optional(),
1736
+ skill_body: exports_external.string(),
1737
+ risk_flags: exports_external.array(exports_external.string()).default([]),
1738
+ evaluation_verdict: ExternalSkillCandidateEvaluationVerdictSchema.default("pending"),
1739
+ evaluation_history: exports_external.array(exports_external.object({
1740
+ verdict: ExternalSkillCandidateEvaluationVerdictSchema,
1741
+ timestamp: exports_external.string().datetime(),
1742
+ actor: exports_external.string(),
1743
+ reason: exports_external.string().optional(),
1744
+ candidate_id: exports_external.string().optional(),
1745
+ original_verdict: ExternalSkillCandidateEvaluationVerdictSchema.optional(),
1746
+ gate_results: exports_external.array(exports_external.object({
1747
+ gate: exports_external.string(),
1748
+ verdict: exports_external.string()
1749
+ })).optional(),
1750
+ risk_assessment: exports_external.object({
1751
+ total_flags: exports_external.number().int().nonnegative(),
1752
+ findings: exports_external.array(exports_external.object({
1753
+ severity: exports_external.enum(["error", "warning"]),
1754
+ category: exports_external.string()
1755
+ }))
1756
+ }).optional(),
1757
+ risk_flags_count: exports_external.number().int().nonnegative().optional(),
1758
+ provenance_snapshot: exports_external.object({
1759
+ sha256: exports_external.string(),
1760
+ source_url: exports_external.string(),
1761
+ publisher: exports_external.string(),
1762
+ fetched_at: exports_external.string().datetime().optional()
1763
+ }).optional(),
1764
+ target_path: exports_external.string().optional(),
1765
+ promoted_content_hash: exports_external.string().regex(/^[a-f0-9]{64}$/).optional(),
1766
+ original_evaluation: exports_external.record(exports_external.string(), exports_external.unknown()).optional()
1767
+ })).default([])
1768
+ });
1769
+ var ExternalSkillsConfigSchema = exports_external.object({
1770
+ curation_enabled: exports_external.boolean().default(false),
1771
+ max_candidates: exports_external.number().int().min(1).max(1e4).default(500),
1772
+ max_bytes_per_candidate: exports_external.number().int().min(1024).max(10485760).default(1048576),
1773
+ eviction_policy: exports_external.enum(["fifo"]).default("fifo"),
1774
+ ttl_days: exports_external.number().int().min(1).max(3650).default(90),
1775
+ evaluation_enabled: exports_external.boolean().default(false),
1776
+ sources: exports_external.array(DiscoverySourceSchema).default([]),
1777
+ max_candidates_per_discovery: exports_external.number().int().min(1).max(1000).default(50),
1778
+ max_concurrent_fetches: exports_external.number().int().min(1).max(20).default(5),
1779
+ fetch_timeout_ms: exports_external.number().int().min(1000).max(300000).default(30000)
1780
+ });
1781
+ var DEFAULT_EXTERNAL_SKILLS_CONFIG = {
1782
+ curation_enabled: false,
1783
+ max_candidates: 500,
1784
+ max_bytes_per_candidate: 1048576,
1785
+ eviction_policy: "fifo",
1786
+ ttl_days: 90,
1787
+ evaluation_enabled: false,
1788
+ sources: [],
1789
+ max_candidates_per_discovery: 50,
1790
+ max_concurrent_fetches: 5,
1791
+ fetch_timeout_ms: 30000
1792
+ };
1793
+ function resolveExternalSkillsConfig(input) {
1794
+ if (input === undefined || input === null || typeof input !== "object" || Array.isArray(input)) {
1795
+ return { ...DEFAULT_EXTERNAL_SKILLS_CONFIG };
1796
+ }
1797
+ const config = input;
1798
+ const merged = {
1799
+ curation_enabled: config.curation_enabled ?? DEFAULT_EXTERNAL_SKILLS_CONFIG.curation_enabled,
1800
+ max_candidates: config.max_candidates ?? DEFAULT_EXTERNAL_SKILLS_CONFIG.max_candidates,
1801
+ max_bytes_per_candidate: config.max_bytes_per_candidate ?? DEFAULT_EXTERNAL_SKILLS_CONFIG.max_bytes_per_candidate,
1802
+ eviction_policy: config.eviction_policy ?? DEFAULT_EXTERNAL_SKILLS_CONFIG.eviction_policy,
1803
+ ttl_days: config.ttl_days ?? DEFAULT_EXTERNAL_SKILLS_CONFIG.ttl_days,
1804
+ evaluation_enabled: config.evaluation_enabled ?? DEFAULT_EXTERNAL_SKILLS_CONFIG.evaluation_enabled,
1805
+ sources: Array.isArray(config.sources) ? config.sources : [],
1806
+ max_candidates_per_discovery: config.max_candidates_per_discovery ?? DEFAULT_EXTERNAL_SKILLS_CONFIG.max_candidates_per_discovery,
1807
+ max_concurrent_fetches: config.max_concurrent_fetches ?? DEFAULT_EXTERNAL_SKILLS_CONFIG.max_concurrent_fetches,
1808
+ fetch_timeout_ms: config.fetch_timeout_ms ?? DEFAULT_EXTERNAL_SKILLS_CONFIG.fetch_timeout_ms
1809
+ };
1810
+ return merged;
1811
+ }
1812
+ var PluginConfigSchema = exports_external.object({
1813
+ agents: exports_external.record(exports_external.string(), AgentOverrideConfigSchema).optional(),
1814
+ default_agent: exports_external.string().optional().transform((v) => {
1815
+ if (v === undefined)
1816
+ return;
1817
+ const trimmed = v.trim();
1818
+ return trimmed === "" ? undefined : trimmed;
1819
+ }),
1820
+ auto_select_architect: exports_external.union([exports_external.boolean(), exports_external.string()]).optional().transform((v) => {
1821
+ if (v === undefined)
1822
+ return;
1823
+ if (typeof v === "boolean")
1824
+ return v;
1825
+ const trimmed = v.trim();
1826
+ return trimmed === "" ? false : trimmed;
1827
+ }),
1828
+ swarms: exports_external.record(exports_external.string().regex(/^[^_]+$/, "Swarm ID must not contain underscores"), SwarmConfigSchema).optional(),
1829
+ max_iterations: exports_external.number().min(1).max(10).default(5),
1830
+ pipeline: PipelineConfigSchema.optional(),
1831
+ phase_complete: PhaseCompleteConfigSchema.optional(),
1832
+ qa_retry_limit: exports_external.number().min(1).max(10).default(3),
1833
+ execution_mode: exports_external.enum(["strict", "balanced", "fast"]).default("balanced"),
1834
+ inject_phase_reminders: exports_external.boolean().default(true),
1835
+ hooks: HooksConfigSchema.optional(),
1836
+ gates: GateConfigSchema.optional(),
1837
+ context_budget: ContextBudgetConfigSchema.optional(),
1838
+ guardrails: GuardrailsConfigSchema.optional(),
1839
+ watchdog: WatchdogConfigSchema.optional(),
1840
+ self_review: SelfReviewConfigSchema.optional(),
1841
+ auto_review: AutoReviewConfigSchema.optional(),
1842
+ tool_filter: ToolFilterConfigSchema.optional(),
1843
+ authority: AuthorityConfigSchema.optional(),
1844
+ plan_cursor: PlanCursorConfigSchema.optional(),
1845
+ context_map: ContextMapConfigSchema.optional(),
1846
+ repo_graph: RepoGraphConfigSchema.optional(),
1847
+ evidence: EvidenceConfigSchema.optional(),
1848
+ summaries: SummaryConfigSchema.optional(),
1849
+ review_passes: ReviewPassesConfigSchema.optional(),
1850
+ adversarial_detection: AdversarialDetectionConfigSchema.optional(),
1851
+ adversarial_testing: AdversarialTestingConfigSchema.optional(),
1852
+ integration_analysis: IntegrationAnalysisConfigSchema.optional(),
1853
+ docs: DocsConfigSchema.optional(),
1854
+ design_docs: DesignDocsConfigSchema.optional(),
1855
+ ui_review: UIReviewConfigSchema.optional(),
1856
+ compaction_advisory: CompactionAdvisoryConfigSchema.optional(),
1857
+ lint: LintConfigSchema.optional(),
1858
+ secretscan: SecretscanConfigSchema.optional(),
1859
+ checkpoint: CheckpointConfigSchema.optional(),
1860
+ automation: AutomationConfigSchema.optional(),
1861
+ knowledge: KnowledgeConfigSchema.optional(),
1862
+ memory: MemoryConfigSchema.optional(),
1863
+ curator: CuratorConfigSchema.optional(),
1864
+ architectural_supervision: ArchitecturalSupervisionConfigSchema.optional(),
1865
+ knowledge_application: KnowledgeApplicationConfigSchema.optional(),
1866
+ skillPropagation: SkillPropagationConfigSchema.optional(),
1867
+ skill_improver: SkillImproverConfigSchema.optional(),
1868
+ spec_writer: SpecWriterConfigSchema.optional(),
1869
+ tool_output: exports_external.object({
1870
+ truncation_enabled: exports_external.boolean().default(true),
1871
+ max_lines: exports_external.number().min(10).max(500).default(150),
1872
+ per_tool: exports_external.record(exports_external.string(), exports_external.number()).optional(),
1873
+ truncation_tools: exports_external.array(exports_external.string()).optional().describe("Tools to apply output truncation to. Defaults to diff, symbols, bash, shell, test_runner, lint, pre_check_batch, complexity_hotspots, pkg_audit, sbom_generate, schema_drift.")
1874
+ }).optional(),
1875
+ slop_detector: SlopDetectorConfigSchema.optional(),
1876
+ todo_gate: exports_external.object({
1877
+ enabled: exports_external.boolean().default(true),
1878
+ max_high_priority: exports_external.number().int().min(-1).default(0).describe("Max new high-priority TODOs (FIXME/HACK/XXX) before warning. 0 = warn on any. Set to -1 to disable."),
1879
+ block_on_threshold: exports_external.boolean().default(false).describe("If true, block phase completion when threshold exceeded. Default: advisory only.")
1880
+ }).optional(),
1881
+ incremental_verify: IncrementalVerifyConfigSchema.optional(),
1882
+ compaction_service: CompactionConfigSchema.optional(),
1883
+ prm: PrmConfigSchema.optional(),
1884
+ council: CouncilConfigSchema.optional(),
1885
+ parallelization: ParallelizationConfigSchema.optional(),
1886
+ worktree: WorktreeIsolationConfigSchema.optional(),
1887
+ turbo: TurboConfigSchema.optional(),
1888
+ turbo_mode: exports_external.boolean().default(false).optional(),
1889
+ quiet: exports_external.boolean().default(true).optional(),
1890
+ version_check: exports_external.boolean().default(true).optional(),
1891
+ full_auto: exports_external.object({
1892
+ enabled: exports_external.boolean().default(false),
1893
+ locked: exports_external.boolean().default(false),
1894
+ critic_model: exports_external.string().optional(),
1895
+ max_interactions_per_phase: exports_external.number().int().min(5).max(200).default(50),
1896
+ deadlock_threshold: exports_external.number().int().min(2).max(10).default(3),
1897
+ escalation_mode: exports_external.enum(["pause", "terminate"]).default("pause"),
1898
+ mode: exports_external.enum(["assisted", "supervised", "strict"]).default("supervised"),
1899
+ fail_closed: exports_external.boolean().default(true),
1900
+ permission_policy: exports_external.object({
1901
+ enabled: exports_external.boolean().default(true),
1902
+ trusted_roots: exports_external.array(exports_external.string()).default(["."]),
1903
+ trusted_domains: exports_external.array(exports_external.string()).default([]),
1904
+ protected_paths: exports_external.array(exports_external.string()).default([
1905
+ ".git",
1906
+ ".github/workflows",
1907
+ ".opencode",
1908
+ ".swarm",
1909
+ "package.json",
1910
+ "package-lock.json",
1911
+ "bun.lock",
1912
+ "CHANGELOG.md",
1913
+ ".release-please-manifest.json",
1914
+ "release-please-config.json",
1915
+ "src/index.ts",
1916
+ "src/hooks/guardrails.ts",
1917
+ "src/hooks/delegation-gate.ts",
1918
+ "src/hooks/scope-guard.ts",
1919
+ "src/hooks/full-auto-permission.ts",
1920
+ "src/hooks/full-auto-intercept.ts",
1921
+ "src/full-auto",
1922
+ "src/config/schema.ts",
1923
+ "src/config/constants.ts",
1924
+ "src/tools/phase-complete.ts",
1925
+ "dist"
1926
+ ]),
1927
+ allow_defaults: exports_external.boolean().default(true)
1928
+ }).default(() => ({
1929
+ enabled: true,
1930
+ trusted_roots: ["."],
1931
+ trusted_domains: [],
1932
+ protected_paths: [
1933
+ ".git",
1934
+ ".github/workflows",
1935
+ ".opencode",
1936
+ ".swarm",
1937
+ "package.json",
1938
+ "package-lock.json",
1939
+ "bun.lock",
1940
+ "CHANGELOG.md",
1941
+ ".release-please-manifest.json",
1942
+ "release-please-config.json",
1943
+ "src/index.ts",
1944
+ "src/hooks/guardrails.ts",
1945
+ "src/hooks/delegation-gate.ts",
1946
+ "src/hooks/scope-guard.ts",
1947
+ "src/hooks/full-auto-permission.ts",
1948
+ "src/hooks/full-auto-intercept.ts",
1949
+ "src/full-auto",
1950
+ "src/config/schema.ts",
1951
+ "src/config/constants.ts",
1952
+ "src/tools/phase-complete.ts",
1953
+ "dist"
1954
+ ],
1955
+ allow_defaults: true
1956
+ })),
1957
+ denials: exports_external.object({
1958
+ max_consecutive: exports_external.number().int().min(1).max(50).default(3),
1959
+ max_total: exports_external.number().int().min(1).max(500).default(20),
1960
+ on_limit: exports_external.enum(["pause", "terminate"]).default("pause")
1961
+ }).default(() => ({
1962
+ max_consecutive: 3,
1963
+ max_total: 20,
1964
+ on_limit: "pause"
1965
+ })),
1966
+ oversight: exports_external.object({
1967
+ on_plan_change: exports_external.boolean().default(true),
1968
+ on_task_completion: exports_external.boolean().default(false),
1969
+ on_phase_boundary: exports_external.boolean().default(true),
1970
+ on_high_risk_action: exports_external.boolean().default(true),
1971
+ on_subagent_return_warning: exports_external.boolean().default(true),
1972
+ every_tool_calls: exports_external.number().int().min(0).max(1e4).default(25),
1973
+ every_architect_turns: exports_external.number().int().min(0).max(1000).default(5),
1974
+ every_minutes: exports_external.number().int().min(0).max(1440).default(20)
1975
+ }).default(() => ({
1976
+ on_plan_change: true,
1977
+ on_task_completion: false,
1978
+ on_phase_boundary: true,
1979
+ on_high_risk_action: true,
1980
+ on_subagent_return_warning: true,
1981
+ every_tool_calls: 25,
1982
+ every_architect_turns: 5,
1983
+ every_minutes: 20
1984
+ }))
1985
+ }).optional().default(() => ({
1986
+ enabled: false,
1987
+ locked: false,
1988
+ max_interactions_per_phase: 50,
1989
+ deadlock_threshold: 3,
1990
+ escalation_mode: "pause",
1991
+ mode: "supervised",
1992
+ fail_closed: true,
1993
+ permission_policy: {
1994
+ enabled: true,
1995
+ trusted_roots: ["."],
1996
+ trusted_domains: [],
1997
+ protected_paths: [
1998
+ ".git",
1999
+ ".github/workflows",
2000
+ ".opencode",
2001
+ ".swarm",
2002
+ "package.json",
2003
+ "package-lock.json",
2004
+ "bun.lock",
2005
+ "CHANGELOG.md",
2006
+ ".release-please-manifest.json",
2007
+ "release-please-config.json",
2008
+ "src/index.ts",
2009
+ "src/hooks/guardrails.ts",
2010
+ "src/hooks/delegation-gate.ts",
2011
+ "src/hooks/scope-guard.ts",
2012
+ "src/hooks/full-auto-permission.ts",
2013
+ "src/hooks/full-auto-intercept.ts",
2014
+ "src/full-auto",
2015
+ "src/config/schema.ts",
2016
+ "src/config/constants.ts",
2017
+ "src/tools/phase-complete.ts",
2018
+ "dist"
2019
+ ],
2020
+ allow_defaults: true
2021
+ },
2022
+ denials: {
2023
+ max_consecutive: 3,
2024
+ max_total: 20,
2025
+ on_limit: "pause"
2026
+ },
2027
+ oversight: {
2028
+ on_plan_change: true,
2029
+ on_task_completion: false,
2030
+ on_phase_boundary: true,
2031
+ on_high_risk_action: true,
2032
+ on_subagent_return_warning: true,
2033
+ every_tool_calls: 25,
2034
+ every_architect_turns: 5,
2035
+ every_minutes: 20
2036
+ }
2037
+ })),
2038
+ pr_monitor: PrMonitorConfigSchema.optional(),
2039
+ external_skills: ExternalSkillsConfigSchema.optional()
2040
+ });
2041
+
2042
+ export { ORCHESTRATOR_NAME, ALL_SUBAGENT_NAMES, ALL_AGENT_NAMES, TOOL_NAMES, TOOL_NAME_SET, AGENT_TOOL_MAP, DEFAULT_AGENT_CONFIGS, _internals, isKnownCanonicalRole, getCanonicalAgentRole, resolveGeneratedAgentRole, stripKnownSwarmPrefix, AgentReasoningConfigSchema, AgentThinkingConfigSchema, AgentOverrideConfigSchema, SwarmConfigSchema, HooksConfigSchema, ScoringWeightsSchema, DecisionDecaySchema, TokenRatiosSchema, ScoringConfigSchema, ContextBudgetConfigSchema, EvidenceConfigSchema, GateFeatureSchema, PlaceholderScanConfigSchema, QualityBudgetConfigSchema, GateConfigSchema, PipelineConfigSchema, PhaseCompleteConfigSchema, SummaryConfigSchema, ReviewPassesConfigSchema, AutoReviewConfigSchema, AdversarialDetectionConfigSchema, AdversarialTestingConfigSchema, IntegrationAnalysisConfigSchema, DocsConfigSchema, DesignDocsConfigSchema, UIReviewConfigSchema, CompactionAdvisoryConfigSchema, LintConfigSchema, SecretscanConfigSchema, GuardrailsProfileSchema, DEFAULT_AGENT_PROFILES, DEFAULT_ARCHITECT_PROFILE, GuardrailsConfigSchema, WatchdogConfigSchema, SelfReviewConfigSchema, resolveGuardrailsConfig, ToolFilterConfigSchema, PlanCursorConfigSchema, ContextMapConfigSchema, RepoGraphConfigSchema, CheckpointConfigSchema, AutomationModeSchema, AutomationCapabilitiesSchema, AutomationConfigSchema, KnowledgeConfigSchema, MemoryConfigSchema, CuratorConfigSchema, ArchitecturalSupervisionConfigSchema, KnowledgeApplicationConfigSchema, SkillPropagationConfigSchema, SkillImproverConfigSchema, SpecWriterConfigSchema, SlopDetectorConfigSchema, IncrementalVerifyConfigSchema, CompactionConfigSchema, PrmConfigSchema, AgentAuthorityRuleSchema, AuthorityConfigSchema, GeneralCouncilConfigSchema, CouncilConfigSchema, PrMonitorConfigSchema, ParallelizationConfigSchema, WorktreeIsolationConfigSchema, LeanTurboConfigSchema, StandardTurboConfigSchema, LeanTurboStrategyConfigSchema, TurboConfigSchema, ExternalSkillCandidateSourceTypeSchema, ExternalSkillCandidateEvaluationVerdictSchema, DiscoverySourceSchema, ExternalSkillCandidateSchema, ExternalSkillsConfigSchema, DEFAULT_EXTERNAL_SKILLS_CONFIG, resolveExternalSkillsConfig, PluginConfigSchema };