@openlife/cli 1.7.3

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 (394) hide show
  1. package/INSTALL.md +266 -0
  2. package/LICENSE +21 -0
  3. package/README.md +142 -0
  4. package/bin/openlife.js +3 -0
  5. package/dist/admin_panel_server.js +66 -0
  6. package/dist/cli/AgentManager.js +109 -0
  7. package/dist/cli/AutonomousInstaller.js +134 -0
  8. package/dist/cli/DreamOrganizer.js +88 -0
  9. package/dist/cli/HostInstaller.js +426 -0
  10. package/dist/cli/InstallBanner.js +16 -0
  11. package/dist/cli/InstallFlow.js +256 -0
  12. package/dist/cli/InstallHeadless.js +47 -0
  13. package/dist/cli/InstallModules.js +148 -0
  14. package/dist/cli/InstallStateStore.js +75 -0
  15. package/dist/cli/InstallWizard.js +364 -0
  16. package/dist/cli/ProfileManager.js +163 -0
  17. package/dist/cli/SystemInstaller.js +89 -0
  18. package/dist/cli/WorldClassCommands.js +208 -0
  19. package/dist/design/DesignMdImporter.js +82 -0
  20. package/dist/design/DesignMdMode.js +93 -0
  21. package/dist/design/DesignMdRegistry.js +67 -0
  22. package/dist/index.js +2575 -0
  23. package/dist/memory/ConversationMemory.js +33 -0
  24. package/dist/memory/LocalMemoryProvider.js +86 -0
  25. package/dist/memory/Mem0Provider.js +16 -0
  26. package/dist/memory/MemoryNamespacePolicy.js +27 -0
  27. package/dist/memory/MemoryOrchestrator.js +65 -0
  28. package/dist/memory/MemoryPromotionFlow.js +32 -0
  29. package/dist/memory/MemoryProvider.js +2 -0
  30. package/dist/memory/MemoryProviderRegistry.js +27 -0
  31. package/dist/memory/MemoryRetentionPolicy.js +60 -0
  32. package/dist/memory/MempalaceProvider.js +72 -0
  33. package/dist/memory/OmniMemory.js +106 -0
  34. package/dist/memory/RedisAgentMemoryProvider.js +16 -0
  35. package/dist/memory/SessionManager.js +86 -0
  36. package/dist/memory/ZepGraphitiProvider.js +16 -0
  37. package/dist/orchestrator/AgentRegistry.js +56 -0
  38. package/dist/orchestrator/AgentScoring.js +82 -0
  39. package/dist/orchestrator/AgentTeam.js +22 -0
  40. package/dist/orchestrator/ArbitrationAgent.js +43 -0
  41. package/dist/orchestrator/ArbitrationScorecard.js +17 -0
  42. package/dist/orchestrator/AssetPromotionEngine.js +65 -0
  43. package/dist/orchestrator/AssetReuseRouter.js +63 -0
  44. package/dist/orchestrator/BenchmarkEngine.js +75 -0
  45. package/dist/orchestrator/Brain.js +298 -0
  46. package/dist/orchestrator/CadenceEngine.js +76 -0
  47. package/dist/orchestrator/CapabilityRouter.js +36 -0
  48. package/dist/orchestrator/CommandLanguage.js +27 -0
  49. package/dist/orchestrator/CommandRouter.js +70 -0
  50. package/dist/orchestrator/ConsequenceForecaster.js +286 -0
  51. package/dist/orchestrator/CronManager.js +286 -0
  52. package/dist/orchestrator/DynamicAgentBuilder.js +48 -0
  53. package/dist/orchestrator/DynamicAgentExecutor.js +15 -0
  54. package/dist/orchestrator/EnterpriseAgenticCore.js +276 -0
  55. package/dist/orchestrator/ExecutionBoard.js +86 -0
  56. package/dist/orchestrator/ExecutionIntent.js +13 -0
  57. package/dist/orchestrator/ExecutionModePolicy.js +48 -0
  58. package/dist/orchestrator/ExecutionRouter.js +9 -0
  59. package/dist/orchestrator/ExecutionState.js +20 -0
  60. package/dist/orchestrator/ExecutorHealth.js +86 -0
  61. package/dist/orchestrator/ExternalCatalogRegistry.js +83 -0
  62. package/dist/orchestrator/Gatekeeper.js +414 -0
  63. package/dist/orchestrator/Gateway.js +508 -0
  64. package/dist/orchestrator/GovernanceConsentStore.js +66 -0
  65. package/dist/orchestrator/GovernanceLayer.js +179 -0
  66. package/dist/orchestrator/GovernancePolicyStore.js +53 -0
  67. package/dist/orchestrator/GovernanceScopeLedger.js +134 -0
  68. package/dist/orchestrator/GovernanceScopePolicy.js +67 -0
  69. package/dist/orchestrator/IntentClassifier.js +45 -0
  70. package/dist/orchestrator/JobLifecycle.js +91 -0
  71. package/dist/orchestrator/LearningRouter.js +24 -0
  72. package/dist/orchestrator/MediaManager.js +92 -0
  73. package/dist/orchestrator/MemoryCuratorAgent.js +41 -0
  74. package/dist/orchestrator/MissionState.js +155 -0
  75. package/dist/orchestrator/ModelManager.js +84 -0
  76. package/dist/orchestrator/OperatingSystem.js +71 -0
  77. package/dist/orchestrator/OperationalMemoryStore.js +94 -0
  78. package/dist/orchestrator/OptimizationLoop.js +72 -0
  79. package/dist/orchestrator/OrchestrationLoop.js +905 -0
  80. package/dist/orchestrator/OrgStructure.js +88 -0
  81. package/dist/orchestrator/OutcomeSimulator.js +46 -0
  82. package/dist/orchestrator/ParallelOrchestrationLoop.js +36 -0
  83. package/dist/orchestrator/PerformanceScorecard.js +105 -0
  84. package/dist/orchestrator/PlannerAgent.js +46 -0
  85. package/dist/orchestrator/ProcessSandbox.js +129 -0
  86. package/dist/orchestrator/PromotionPipeline.js +74 -0
  87. package/dist/orchestrator/PromotionReviewGate.js +11 -0
  88. package/dist/orchestrator/QueueScheduler.js +260 -0
  89. package/dist/orchestrator/ReleaseGate.js +36 -0
  90. package/dist/orchestrator/ReleaseWorkflow.js +68 -0
  91. package/dist/orchestrator/RemotePublisher.js +139 -0
  92. package/dist/orchestrator/ReuseEngine.js +89 -0
  93. package/dist/orchestrator/ReviewerAgent.js +49 -0
  94. package/dist/orchestrator/RoleHandoff.js +65 -0
  95. package/dist/orchestrator/RuntimeHealthMonitor.js +143 -0
  96. package/dist/orchestrator/RuntimePolicy.js +105 -0
  97. package/dist/orchestrator/RuntimeProbe.js +97 -0
  98. package/dist/orchestrator/RuntimeRegistry.js +73 -0
  99. package/dist/orchestrator/SandboxPolicy.js +22 -0
  100. package/dist/orchestrator/SecurityDownloadGuard.js +169 -0
  101. package/dist/orchestrator/SecurityEventStore.js +58 -0
  102. package/dist/orchestrator/ServiceCompletionPolicy.js +36 -0
  103. package/dist/orchestrator/ServiceState.js +195 -0
  104. package/dist/orchestrator/SkillCreator.js +404 -0
  105. package/dist/orchestrator/SkillLearningLoop.js +57 -0
  106. package/dist/orchestrator/SkillManager.js +75 -0
  107. package/dist/orchestrator/SkillNetwork.js +29 -0
  108. package/dist/orchestrator/SkillRegistryV2.js +28 -0
  109. package/dist/orchestrator/SkillScoring.js +70 -0
  110. package/dist/orchestrator/SquadAutoCreator.js +64 -0
  111. package/dist/orchestrator/SquadCreator.js +727 -0
  112. package/dist/orchestrator/SquadRegistry.js +28 -0
  113. package/dist/orchestrator/SquadRouter.js +33 -0
  114. package/dist/orchestrator/SquadScoring.js +70 -0
  115. package/dist/orchestrator/SubagentLifecycle.js +90 -0
  116. package/dist/orchestrator/SynthesizerAgent.js +48 -0
  117. package/dist/orchestrator/SystemDoctor.js +224 -0
  118. package/dist/orchestrator/TaskExecutor.js +422 -0
  119. package/dist/orchestrator/TeammateBoard.js +61 -0
  120. package/dist/orchestrator/TestHarness.js +184 -0
  121. package/dist/orchestrator/VoiceManager.js +203 -0
  122. package/dist/orchestrator/VoiceRouter.js +89 -0
  123. package/dist/orchestrator/capability/CapabilityGenesisEngine.js +278 -0
  124. package/dist/orchestrator/capability/CapabilityPackParser.js +223 -0
  125. package/dist/orchestrator/capability/CapabilityPackSchema.js +62 -0
  126. package/dist/orchestrator/capability/CapabilityPackState.js +163 -0
  127. package/dist/orchestrator/providers/AgentProvider.js +2 -0
  128. package/dist/orchestrator/providers/CapabilityProvider.js +12 -0
  129. package/dist/orchestrator/providers/CloudAgentProvider.js +55 -0
  130. package/dist/orchestrator/providers/CloudSkillProvider.js +55 -0
  131. package/dist/orchestrator/providers/CloudSquadProvider.js +55 -0
  132. package/dist/orchestrator/providers/CompositeAgentProvider.js +16 -0
  133. package/dist/orchestrator/providers/CompositeCapabilityProvider.js +25 -0
  134. package/dist/orchestrator/providers/CompositeSkillProvider.js +16 -0
  135. package/dist/orchestrator/providers/CompositeSquadProvider.js +16 -0
  136. package/dist/orchestrator/providers/CompositeWorkflowProvider.js +46 -0
  137. package/dist/orchestrator/providers/FileAgentProvider.js +105 -0
  138. package/dist/orchestrator/providers/FileCapabilityProvider.js +106 -0
  139. package/dist/orchestrator/providers/FileSkillProvider.js +65 -0
  140. package/dist/orchestrator/providers/FileSquadProvider.js +69 -0
  141. package/dist/orchestrator/providers/FileWorkflowProvider.js +103 -0
  142. package/dist/orchestrator/providers/SkillProvider.js +2 -0
  143. package/dist/orchestrator/providers/SquadProvider.js +2 -0
  144. package/dist/orchestrator/toolset/ToolsetGuard.js +69 -0
  145. package/dist/orchestrator/toolset/ToolsetRegistry.js +65 -0
  146. package/dist/orchestrator/toolset/ToolsetSchema.js +21 -0
  147. package/dist/orchestrator/util/AtomicWriter.js +204 -0
  148. package/dist/orchestrator/util/DistributedLock.js +232 -0
  149. package/dist/orchestrator/util/TemplateRenderer.js +87 -0
  150. package/dist/orchestrator/util/WatchdogHeartbeat.js +116 -0
  151. package/dist/orchestrator/workflow/ConditionParser.js +232 -0
  152. package/dist/orchestrator/workflow/WorkflowEngine.js +379 -0
  153. package/dist/orchestrator/workflow/WorkflowParser.js +368 -0
  154. package/dist/orchestrator/workflow/WorkflowSchema.js +65 -0
  155. package/dist/orchestrator/workflow/WorkflowState.js +11 -0
  156. package/dist/reversa/ReversaAgent.js +134 -0
  157. package/dist/reversa/ReversaContracts.js +62 -0
  158. package/dist/reversa/ReversaExecutors.js +65 -0
  159. package/dist/skills/SkillRegistry.js +71 -0
  160. package/dist/squads/SquadManager.js +87 -0
  161. package/dist/test_admin_teams_networks.js +54 -0
  162. package/dist/test_agent_team_skill_network.js +15 -0
  163. package/dist/test_aiobuilder_cli_parity.js +169 -0
  164. package/dist/test_ask_exit.js +73 -0
  165. package/dist/test_atomic_writer.js +209 -0
  166. package/dist/test_autonomous_soak.js +141 -0
  167. package/dist/test_benchmark_engine.js +41 -0
  168. package/dist/test_brain_error_diagnostics.js +51 -0
  169. package/dist/test_brain_fallback_chain.js +93 -0
  170. package/dist/test_capability_genesis_engine.js +225 -0
  171. package/dist/test_capability_pack_schema.js +214 -0
  172. package/dist/test_catalog_quality.js +150 -0
  173. package/dist/test_cli_crud_roundtrip.js +154 -0
  174. package/dist/test_cli_diagnostics.js +131 -0
  175. package/dist/test_cli_doc_parity.js +126 -0
  176. package/dist/test_cli_help_surface.js +106 -0
  177. package/dist/test_cli_service_commands.js +83 -0
  178. package/dist/test_consequence_forecast_brain.js +165 -0
  179. package/dist/test_consequence_forecaster.js +24 -0
  180. package/dist/test_conversation_memory.js +36 -0
  181. package/dist/test_create_entities.js +54 -0
  182. package/dist/test_creator_placeholders_completed.js +177 -0
  183. package/dist/test_cron_manager.js +123 -0
  184. package/dist/test_daemon_sigterm.js +72 -0
  185. package/dist/test_deep_research_capability.js +87 -0
  186. package/dist/test_designmd_import_registry.js +16 -0
  187. package/dist/test_designmd_mode.js +50 -0
  188. package/dist/test_designmd_mode_workspace.js +13 -0
  189. package/dist/test_dist_templates_layout.js +135 -0
  190. package/dist/test_distributed_lock.js +201 -0
  191. package/dist/test_distribution_installability.js +67 -0
  192. package/dist/test_doctor_sandbox_check.js +44 -0
  193. package/dist/test_dream_organizer.js +25 -0
  194. package/dist/test_dual_mode.js +15 -0
  195. package/dist/test_enterprise_agentic_core.js +128 -0
  196. package/dist/test_forecast_brain_wiring.js +87 -0
  197. package/dist/test_gateway_telegram_guardrails.js +52 -0
  198. package/dist/test_governance.js +34 -0
  199. package/dist/test_governance_advanced.js +75 -0
  200. package/dist/test_governance_scope_ledger.js +147 -0
  201. package/dist/test_governance_v13_policies.js +44 -0
  202. package/dist/test_guided_creator_cli.js +100 -0
  203. package/dist/test_host_install_e2e.js +324 -0
  204. package/dist/test_host_installer.js +259 -0
  205. package/dist/test_host_installers_gemini_codex.js +95 -0
  206. package/dist/test_host_uninstaller.js +295 -0
  207. package/dist/test_install_flow.js +70 -0
  208. package/dist/test_install_flow_host_validation.js +143 -0
  209. package/dist/test_install_wizard.js +272 -0
  210. package/dist/test_integration_gemini_live.js +95 -0
  211. package/dist/test_integration_http_trigger_live.js +154 -0
  212. package/dist/test_integration_telegram_live.js +102 -0
  213. package/dist/test_job_lifecycle.js +16 -0
  214. package/dist/test_memory_orchestrator.js +33 -0
  215. package/dist/test_memory_promotion.js +36 -0
  216. package/dist/test_memory_retention.js +37 -0
  217. package/dist/test_mission_checkpoint.js +204 -0
  218. package/dist/test_multi_host_docs_parity.js +125 -0
  219. package/dist/test_openlife_auto_creator_routing.js +69 -0
  220. package/dist/test_openlife_evolution_surface.js +77 -0
  221. package/dist/test_openlife_gatekeeper_routing.js +15 -0
  222. package/dist/test_openlife_routing_surface.js +27 -0
  223. package/dist/test_openlife_runtime_source_truth.js +25 -0
  224. package/dist/test_operating_system.js +45 -0
  225. package/dist/test_optimization_loop.js +38 -0
  226. package/dist/test_orchestration_assets_lifecycle.js +78 -0
  227. package/dist/test_outcome_simulator.js +38 -0
  228. package/dist/test_performance_latency.js +215 -0
  229. package/dist/test_performance_scorecard.js +38 -0
  230. package/dist/test_phase1_check_exit.js +103 -0
  231. package/dist/test_phase6_board.js +31 -0
  232. package/dist/test_phase6_cadence.js +29 -0
  233. package/dist/test_phase6_ops.js +37 -0
  234. package/dist/test_post_mission_evaluation.js +190 -0
  235. package/dist/test_process_sandbox.js +88 -0
  236. package/dist/test_profile_toolset_mcp.js +125 -0
  237. package/dist/test_queue_scheduler.js +239 -0
  238. package/dist/test_release_gate.js +23 -0
  239. package/dist/test_remote_publish.js +193 -0
  240. package/dist/test_reversa_contracts_e2e.js +48 -0
  241. package/dist/test_reversa_export_and_strict.js +51 -0
  242. package/dist/test_reversa_full_execution.js +12 -0
  243. package/dist/test_reversa_lite.js +9 -0
  244. package/dist/test_royal_stack_golden.js +179 -0
  245. package/dist/test_runtime_health_backoff.js +154 -0
  246. package/dist/test_runtime_policy.js +26 -0
  247. package/dist/test_runtime_probe.js +19 -0
  248. package/dist/test_runtime_profile_oauth_only.js +262 -0
  249. package/dist/test_runtime_registry.js +11 -0
  250. package/dist/test_security_download_and_scan.js +103 -0
  251. package/dist/test_security_download_guard.js +14 -0
  252. package/dist/test_service_command_surface.js +12 -0
  253. package/dist/test_service_completion_policy.js +32 -0
  254. package/dist/test_service_guardrails_delete.js +12 -0
  255. package/dist/test_service_mode_explicit_only.js +174 -0
  256. package/dist/test_sources_import_ref.js +46 -0
  257. package/dist/test_sources_scaffold.js +43 -0
  258. package/dist/test_squad_skill_creator.js +305 -0
  259. package/dist/test_squad_skill_design_llm.js +176 -0
  260. package/dist/test_subsystems_org_state.js +271 -0
  261. package/dist/test_subsystems_promotion_memory_assets.js +343 -0
  262. package/dist/test_subsystems_routing_governance.js +234 -0
  263. package/dist/test_task_executor_sandbox_optin.js +127 -0
  264. package/dist/test_teammate_learning.js +15 -0
  265. package/dist/test_telegram_delete_guardrail.js +21 -0
  266. package/dist/test_toolset_enforcement.js +188 -0
  267. package/dist/test_trigger_basic_auth.js +112 -0
  268. package/dist/test_util/doc_parity.js +120 -0
  269. package/dist/test_v15_e2e_integration.js +207 -0
  270. package/dist/test_watchdog_heartbeat.js +152 -0
  271. package/dist/test_workflow_condition_parser.js +63 -0
  272. package/dist/test_workflow_e2e.js +240 -0
  273. package/dist/test_workflow_engine.js +330 -0
  274. package/dist/test_workflow_parser.js +245 -0
  275. package/dist/test_workflow_schema_backward_compat.js +197 -0
  276. package/dist-templates/README.md +91 -0
  277. package/dist-templates/claude-code/agents/openlife-atlas.md +52 -0
  278. package/dist-templates/claude-code/agents/openlife-forge.md +42 -0
  279. package/dist-templates/claude-code/agents/openlife-genesis.md +59 -0
  280. package/dist-templates/claude-code/agents/openlife-lyra.md +40 -0
  281. package/dist-templates/claude-code/agents/openlife-maestro.md +45 -0
  282. package/dist-templates/claude-code/commands/openlife/ask.md +14 -0
  283. package/dist-templates/claude-code/commands/openlife/doctor.md +19 -0
  284. package/dist-templates/claude-code/commands/openlife/dream.md +20 -0
  285. package/dist-templates/claude-code/commands/openlife/status.md +14 -0
  286. package/dist-templates/claude-code/mcp/openlife-orchestrator.json +46 -0
  287. package/dist-templates/codex/README.md +7 -0
  288. package/dist-templates/codex/agents/openlife-atlas.md +52 -0
  289. package/dist-templates/codex/agents/openlife-forge.md +42 -0
  290. package/dist-templates/codex/agents/openlife-genesis.md +59 -0
  291. package/dist-templates/codex/agents/openlife-lyra.md +40 -0
  292. package/dist-templates/codex/agents/openlife-maestro.md +45 -0
  293. package/dist-templates/codex/commands/openlife/ask.md +14 -0
  294. package/dist-templates/codex/commands/openlife/doctor.md +19 -0
  295. package/dist-templates/codex/commands/openlife/dream.md +20 -0
  296. package/dist-templates/codex/commands/openlife/status.md +14 -0
  297. package/dist-templates/codex/mcp/openlife-orchestrator.json +46 -0
  298. package/dist-templates/gemini-cli/README.md +8 -0
  299. package/dist-templates/gemini-cli/agents/openlife-atlas.md +52 -0
  300. package/dist-templates/gemini-cli/agents/openlife-forge.md +42 -0
  301. package/dist-templates/gemini-cli/agents/openlife-genesis.md +59 -0
  302. package/dist-templates/gemini-cli/agents/openlife-lyra.md +40 -0
  303. package/dist-templates/gemini-cli/agents/openlife-maestro.md +45 -0
  304. package/dist-templates/gemini-cli/commands/openlife/ask.md +14 -0
  305. package/dist-templates/gemini-cli/commands/openlife/doctor.md +19 -0
  306. package/dist-templates/gemini-cli/commands/openlife/dream.md +20 -0
  307. package/dist-templates/gemini-cli/commands/openlife/status.md +14 -0
  308. package/dist-templates/gemini-cli/mcp/openlife-orchestrator.json +46 -0
  309. package/dist-templates/skill-template/README.md +34 -0
  310. package/dist-templates/skill-template/SKILL.md.template +59 -0
  311. package/dist-templates/squad-template/README.md +82 -0
  312. package/dist-templates/squad-template/SQUAD.md.template +51 -0
  313. package/dist-templates/squad-template/agent-template.md +51 -0
  314. package/dist-templates/squad-template/checklist-template.md +25 -0
  315. package/dist-templates/squad-template/task-template.md +36 -0
  316. package/dist-templates/workflows/PORTED_WORKFLOWS.md +60 -0
  317. package/dist-templates/workflows/brownfield-discovery.yaml +137 -0
  318. package/dist-templates/workflows/greenfield-fullstack.yaml +132 -0
  319. package/dist-templates/workflows/qa-loop.yaml +125 -0
  320. package/dist-templates/workflows/story-development-cycle.yaml +80 -0
  321. package/docs/CHANGELOG_FEATURE_ROLLOUT_DESIGNMD.md +43 -0
  322. package/docs/EXTERNAL_SOURCES_AND_SECURITY_GUARD.md +33 -0
  323. package/docs/OPENLIFE_AUDIT_2026-05-06.md +170 -0
  324. package/docs/OPENLIFE_CONSOLIDATED_PLAN_2026-05-06.md +299 -0
  325. package/docs/OPENLIFE_DUAL_MODE_IMPLEMENTATION_PLAN.md +205 -0
  326. package/docs/OPENLIFE_EVOLUTION_SURFACE_2026-05-07.md +53 -0
  327. package/docs/OPENLIFE_SKILLS_IMPORT_2026-05-07.json +223 -0
  328. package/docs/OPENLIFE_SQUADS_IMPORT_2026-05-07.json +184 -0
  329. package/docs/PAPERCLIP_OPENLIFE_INVESTIGATION.md +85 -0
  330. package/docs/README.md +28 -0
  331. package/docs/RELEASE_ORGANIZATION_PLAN.md +164 -0
  332. package/docs/audit/CLI-EXECUTION-RESULTS.md +113 -0
  333. package/docs/audit/CLI-MATRIX.md +556 -0
  334. package/docs/audit/DOC-PARITY-GAPS.md +351 -0
  335. package/docs/audit/ORCHESTRATOR-MATRIX.md +136 -0
  336. package/docs/audit/TEST-COVERAGE-GAPS.md +334 -0
  337. package/docs/audit/integrations/SKIPPED.md +101 -0
  338. package/docs/autonomous-install.md +79 -0
  339. package/docs/capability-genesis.md +137 -0
  340. package/docs/capability-pack-schema.md +157 -0
  341. package/docs/commands.md +82 -0
  342. package/docs/deep-research-capability.md +114 -0
  343. package/docs/development/typescript-conventions.md +95 -0
  344. package/docs/host-installers.md +68 -0
  345. package/docs/install/aiobuilder.md +70 -0
  346. package/docs/install/claude-code.md +83 -0
  347. package/docs/install/codex.md +64 -0
  348. package/docs/install/gemini-cli.md +64 -0
  349. package/docs/install/runtime-profiles.md +83 -0
  350. package/docs/openlife-agent-os-blueprint.md +114 -0
  351. package/docs/openlife-install-backlog.md +115 -0
  352. package/docs/openlife-install-spec.md +306 -0
  353. package/docs/operations/CLOUD_CUTOVER_AUDIT.md +37 -0
  354. package/docs/operations/PHASE_PROGRESS_CONTINUATION.md +24 -0
  355. package/docs/performance-benchmarks.md +83 -0
  356. package/docs/planning/v1.3-capability-genesis.md +157 -0
  357. package/docs/plans/2026-05-05-admin-interface-professional-dark-premium-plan.md +84 -0
  358. package/docs/plans/2026-05-05-openlife-autonomous-domain-marketplace-masterplan.md +122 -0
  359. package/docs/quickstart.md +60 -0
  360. package/docs/release-process.md +236 -0
  361. package/docs/roadmap/OPENLIFE_MASTER_PLAN_CLOUD_V3.md +97 -0
  362. package/docs/sandboxing-research.md +117 -0
  363. package/docs/stories/epic-feature-audit/1.1.story.md +84 -0
  364. package/docs/stories/epic-feature-audit/1.2.story.md +102 -0
  365. package/docs/stories/epic-feature-audit/1.3.story.md +93 -0
  366. package/docs/stories/epic-feature-audit/1.5.story.md +121 -0
  367. package/docs/stories/epic-feature-audit/1.6.story.md +80 -0
  368. package/docs/stories/epic-feature-completeness/2.1.story.md +70 -0
  369. package/docs/stories/epic-feature-completeness/2.2.story.md +49 -0
  370. package/docs/stories/epic-feature-completeness/2.3.story.md +74 -0
  371. package/docs/stories/epic-feature-completeness/2.4.story.md +71 -0
  372. package/docs/stories/epic-feature-completeness/3.1.story.md +56 -0
  373. package/docs/stories/epic-feature-completeness/3.2.story.md +80 -0
  374. package/docs/stories/epic-feature-completeness/3.3.story.md +68 -0
  375. package/docs/stories/epic-feature-completeness/3.4.story.md +71 -0
  376. package/docs/stories/epic-feature-completeness/3.5.story.md +72 -0
  377. package/docs/stories/epic-feature-completeness/3.6.story.md +69 -0
  378. package/docs/stories/epic-feature-completeness/3.7.story.md +68 -0
  379. package/docs/stories/epic-feature-completeness/3.8.story.md +57 -0
  380. package/docs/toolset-enforcement.md +122 -0
  381. package/docs/v1.4-changelog.md +159 -0
  382. package/docs/v1.5-changelog.md +106 -0
  383. package/docs/v1.5-roadmap.md +121 -0
  384. package/docs/v1.6-changelog.md +67 -0
  385. package/docs/v1.6-roadmap.md +89 -0
  386. package/docs/v1.7-changelog.md +98 -0
  387. package/docs/workflow-schema.md +177 -0
  388. package/package.json +177 -0
  389. package/scripts/clean-test-pollution.js +61 -0
  390. package/scripts/openlife-agent-start.sh +6 -0
  391. package/scripts/openlife-agent.service.example +13 -0
  392. package/scripts/openlife-agent.supervisord.conf.example +8 -0
  393. package/scripts/openlife-autonomous-install.sh +29 -0
  394. package/scripts/postinstall-check.sh +37 -0
@@ -0,0 +1,65 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.RoleHandoff = void 0;
37
+ const fs = __importStar(require("fs"));
38
+ const path = __importStar(require("path"));
39
+ class RoleHandoff {
40
+ filePath;
41
+ constructor() {
42
+ this.filePath = path.join(process.cwd(), '.artifacts', 'role-handoffs.json');
43
+ fs.mkdirSync(path.dirname(this.filePath), { recursive: true });
44
+ }
45
+ create(input) {
46
+ const all = this.getAll();
47
+ all.push({ ...input, createdAt: new Date().toISOString(), updatedAt: new Date().toISOString() });
48
+ fs.writeFileSync(this.filePath, JSON.stringify(all, null, 2), 'utf-8');
49
+ }
50
+ updateStatus(id, status) {
51
+ const all = this.getAll().map((item) => item.id === id ? { ...item, status, updatedAt: new Date().toISOString() } : item);
52
+ fs.writeFileSync(this.filePath, JSON.stringify(all, null, 2), 'utf-8');
53
+ }
54
+ getAll() {
55
+ if (!fs.existsSync(this.filePath))
56
+ return [];
57
+ try {
58
+ return JSON.parse(fs.readFileSync(this.filePath, 'utf-8'));
59
+ }
60
+ catch {
61
+ return [];
62
+ }
63
+ }
64
+ }
65
+ exports.RoleHandoff = RoleHandoff;
@@ -0,0 +1,143 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.RuntimeHealthMonitor = exports.RETRY_BUDGET_WINDOW_MS = exports.MAX_FAILURES = exports.MAX_DELAY_MS = exports.BASE_DELAY_MS = void 0;
37
+ exports.exponentialBackoffDelayMs = exponentialBackoffDelayMs;
38
+ const fs = __importStar(require("fs"));
39
+ const path = __importStar(require("path"));
40
+ const AtomicWriter_1 = require("./util/AtomicWriter");
41
+ /**
42
+ * Exponential backoff parameters.
43
+ *
44
+ * delay = min(BASE_DELAY_MS * 2^(failures-1), MAX_DELAY_MS)
45
+ *
46
+ * After MAX_FAILURES failures within RETRY_BUDGET_WINDOW_MS the executor
47
+ * is marked permanentlyDown until manual reset via markHealthy().
48
+ *
49
+ * Story 6.5 — OpenLife v1.2 Royal Stack.
50
+ */
51
+ exports.BASE_DELAY_MS = 10_000; // 10s for first failure
52
+ exports.MAX_DELAY_MS = 60 * 60 * 1000; // 1h cap
53
+ exports.MAX_FAILURES = 10; // budget
54
+ exports.RETRY_BUDGET_WINDOW_MS = 60 * 60 * 1000; // 1h window
55
+ function exponentialBackoffDelayMs(failures) {
56
+ if (failures <= 0)
57
+ return exports.BASE_DELAY_MS;
58
+ const exponent = Math.min(failures - 1, 30); // clamp to avoid 2^N overflow
59
+ const delay = exports.BASE_DELAY_MS * Math.pow(2, exponent);
60
+ return Math.min(delay, exports.MAX_DELAY_MS);
61
+ }
62
+ class RuntimeHealthMonitor {
63
+ root;
64
+ filePath;
65
+ constructor(root = process.cwd()) {
66
+ this.root = root;
67
+ this.filePath = path.join(this.root, '.openlife', 'runtime-health.json');
68
+ fs.mkdirSync(path.dirname(this.filePath), { recursive: true });
69
+ }
70
+ read() {
71
+ if (!fs.existsSync(this.filePath))
72
+ return {};
73
+ try {
74
+ return JSON.parse(fs.readFileSync(this.filePath, 'utf-8'));
75
+ }
76
+ catch {
77
+ return {};
78
+ }
79
+ }
80
+ write(payload) {
81
+ (0, AtomicWriter_1.writeJsonAtomic)(this.filePath, payload);
82
+ }
83
+ get(executor) {
84
+ return this.read()[executor] || null;
85
+ }
86
+ isCoolingDown(executor) {
87
+ const state = this.get(executor);
88
+ if (!state)
89
+ return false;
90
+ if (state.permanentlyDown)
91
+ return true;
92
+ if (!state.until)
93
+ return false;
94
+ return new Date(state.until).getTime() > Date.now();
95
+ }
96
+ /**
97
+ * Record an executor failure. The cooldown is computed via exponential
98
+ * backoff unless `cooldownMinutes` is explicitly provided (backward-
99
+ * compatible — pre-v1.2 callers passed a fixed 10-minute window).
100
+ */
101
+ markFailure(executor, reason, cooldownMinutes) {
102
+ const current = this.read();
103
+ const existing = current[executor];
104
+ const now = Date.now();
105
+ // Reset the failure window if more than RETRY_BUDGET_WINDOW_MS elapsed
106
+ // since the window started — gives intermittent failures a clean slate.
107
+ let failures = (existing?.failures || 0) + 1;
108
+ let budgetWindowStartedAt = existing?.budgetWindowStartedAt;
109
+ if (!budgetWindowStartedAt || now - budgetWindowStartedAt > exports.RETRY_BUDGET_WINDOW_MS) {
110
+ budgetWindowStartedAt = now;
111
+ failures = 1;
112
+ }
113
+ const permanentlyDown = failures > exports.MAX_FAILURES;
114
+ const delayMs = cooldownMinutes !== undefined
115
+ ? cooldownMinutes * 60 * 1000
116
+ : exponentialBackoffDelayMs(failures);
117
+ const until = permanentlyDown ? undefined : new Date(now + delayMs).toISOString();
118
+ current[executor] = {
119
+ executor,
120
+ failures,
121
+ until,
122
+ reason,
123
+ updatedAt: new Date().toISOString(),
124
+ permanentlyDown,
125
+ budgetWindowStartedAt,
126
+ };
127
+ this.write(current);
128
+ }
129
+ markHealthy(executor) {
130
+ const current = this.read();
131
+ current[executor] = {
132
+ executor,
133
+ failures: 0,
134
+ updatedAt: new Date().toISOString(),
135
+ permanentlyDown: false,
136
+ };
137
+ this.write(current);
138
+ }
139
+ all() {
140
+ return this.read();
141
+ }
142
+ }
143
+ exports.RuntimeHealthMonitor = RuntimeHealthMonitor;
@@ -0,0 +1,105 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.RuntimePolicy = void 0;
37
+ const fs = __importStar(require("fs"));
38
+ const path = __importStar(require("path"));
39
+ const ExecutorHealth_1 = require("./ExecutorHealth");
40
+ const RuntimeHealthMonitor_1 = require("./RuntimeHealthMonitor");
41
+ class RuntimePolicy {
42
+ executorHealth;
43
+ runtimeHealth;
44
+ constructor() {
45
+ this.executorHealth = new ExecutorHealth_1.ExecutorHealth();
46
+ this.runtimeHealth = new RuntimeHealthMonitor_1.RuntimeHealthMonitor();
47
+ }
48
+ decide(intent, explicitExecutors = []) {
49
+ const base = explicitExecutors.length
50
+ ? explicitExecutors
51
+ : intent === 'RESEARCH_ANALYSIS'
52
+ ? ['gemini', 'claude', 'codex']
53
+ : ['codex', 'claude', 'gemini'];
54
+ const allowedRaw = (process.env.OPENLIFE_ALLOWED_LLM_EXECUTORS || '').trim().toLowerCase();
55
+ const allowed = new Set();
56
+ if (allowedRaw) {
57
+ for (const entry of allowedRaw.split(',').map(s => s.trim()).filter(Boolean)) {
58
+ if (entry === 'codex' || entry === 'gemini' || entry === 'claude' || entry === 'openclaude') {
59
+ allowed.add(entry);
60
+ }
61
+ }
62
+ }
63
+ const allowFiltered = allowed.size > 0 ? base.filter(e => allowed.has(e)) : base;
64
+ const preferred = allowFiltered.filter((executor) => {
65
+ const health = this.executorHealth.get(executor);
66
+ if (this.runtimeHealth.isCoolingDown(executor))
67
+ return false;
68
+ if (!health)
69
+ return true;
70
+ return health.available !== false;
71
+ });
72
+ return {
73
+ preferred,
74
+ rationale: preferred.length
75
+ ? `Executores ordenados por policy + health atual${allowed.size > 0 ? ' + allowlist' : ''}.`
76
+ : 'Todos os executores da cadeia configurada estão indisponíveis no momento.'
77
+ };
78
+ }
79
+ recordResult(executor, ok, reason) {
80
+ this.executorHealth.set(executor, ok, reason);
81
+ if (ok) {
82
+ this.runtimeHealth.markHealthy(executor);
83
+ return;
84
+ }
85
+ const normalized = (reason || '').toLowerCase();
86
+ const shouldCooldown = /quota|429|capacity|rate limit|temporarily unavailable|overloaded|auth/i.test(normalized);
87
+ if (shouldCooldown) {
88
+ const cooldown = /auth/i.test(normalized) ? 30 : 10;
89
+ this.runtimeHealth.markFailure(executor, reason || 'runtime failure', cooldown);
90
+ }
91
+ }
92
+ status() {
93
+ return {
94
+ executors: this.executorHealth.getAll(),
95
+ cooldowns: this.runtimeHealth.all()
96
+ };
97
+ }
98
+ saveSnapshot() {
99
+ const snapshotPath = path.join(process.cwd(), '.openlife', 'runtime-policy-status.json');
100
+ fs.mkdirSync(path.dirname(snapshotPath), { recursive: true });
101
+ fs.writeFileSync(snapshotPath, JSON.stringify(this.status(), null, 2), 'utf-8');
102
+ return snapshotPath;
103
+ }
104
+ }
105
+ exports.RuntimePolicy = RuntimePolicy;
@@ -0,0 +1,97 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.RuntimeProbe = void 0;
37
+ const child_process = __importStar(require("child_process"));
38
+ const util_1 = require("util");
39
+ const ExecutorHealth_1 = require("./ExecutorHealth");
40
+ const execFile = (0, util_1.promisify)(child_process.execFile);
41
+ class RuntimeProbe {
42
+ executorHealth;
43
+ constructor() {
44
+ this.executorHealth = new ExecutorHealth_1.ExecutorHealth();
45
+ }
46
+ async probeAll() {
47
+ const executors = ['codex', 'gemini', 'claude', 'openclaude'];
48
+ const results = [];
49
+ for (const executor of executors) {
50
+ results.push(await this.probe(executor));
51
+ }
52
+ return results;
53
+ }
54
+ async probe(executor) {
55
+ try {
56
+ const command = this.commandFor(executor);
57
+ const { stdout, stderr } = await execFile(command[0], command.slice(1), { timeout: 15000, maxBuffer: 1024 * 1024 * 5 });
58
+ const detail = (stdout || stderr || 'ok').toString().trim().slice(0, 200) || 'ok';
59
+ this.executorHealth.set(executor, true, detail);
60
+ return {
61
+ executor,
62
+ available: true,
63
+ reason: detail,
64
+ category: 'ok',
65
+ updatedAt: new Date().toISOString(),
66
+ command
67
+ };
68
+ }
69
+ catch (error) {
70
+ const probeErr = error;
71
+ const reason = probeErr.stderr || probeErr.stdout || probeErr.message || 'probe failed';
72
+ this.executorHealth.set(executor, false, String(reason));
73
+ const state = this.executorHealth.get(executor);
74
+ return {
75
+ executor,
76
+ available: false,
77
+ reason: String(reason).slice(0, 300),
78
+ category: state.category,
79
+ updatedAt: new Date().toISOString(),
80
+ command: this.commandFor(executor)
81
+ };
82
+ }
83
+ }
84
+ commandFor(executor) {
85
+ switch (executor) {
86
+ case 'gemini':
87
+ return ['gemini', '--version'];
88
+ case 'claude':
89
+ return ['claude', '--version'];
90
+ case 'openclaude':
91
+ return ['openclaude', '--version'];
92
+ default:
93
+ return ['codex', '--version'];
94
+ }
95
+ }
96
+ }
97
+ exports.RuntimeProbe = RuntimeProbe;
@@ -0,0 +1,73 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.RuntimeRegistry = void 0;
37
+ const fs = __importStar(require("fs"));
38
+ const path = __importStar(require("path"));
39
+ const AtomicWriter_1 = require("./util/AtomicWriter");
40
+ class RuntimeRegistry {
41
+ filePath;
42
+ constructor(workspaceId = 'default') {
43
+ this.filePath = path.join(process.cwd(), '.artifacts', 'workspaces', workspaceId, 'runtime-registry.json');
44
+ fs.mkdirSync(path.dirname(this.filePath), { recursive: true });
45
+ }
46
+ probe() {
47
+ const now = new Date().toISOString();
48
+ const entries = [
49
+ { id: 'local-shell', kind: 'local', available: true, checkedAt: now },
50
+ { id: 'codex-cli', kind: 'cli', available: this.hasCmd('codex'), checkedAt: now },
51
+ { id: 'gemini-cli', kind: 'cli', available: this.hasCmd('gemini'), checkedAt: now },
52
+ { id: 'claude-cli', kind: 'cli', available: this.hasCmd('claude'), checkedAt: now }
53
+ ];
54
+ (0, AtomicWriter_1.writeJsonAtomic)(this.filePath, entries);
55
+ return entries;
56
+ }
57
+ list() {
58
+ if (!fs.existsSync(this.filePath))
59
+ return this.probe();
60
+ return JSON.parse(fs.readFileSync(this.filePath, 'utf-8'));
61
+ }
62
+ hasCmd(cmd) {
63
+ try {
64
+ const { execSync } = require('child_process');
65
+ execSync(`command -v ${cmd}`, { stdio: 'ignore' });
66
+ return true;
67
+ }
68
+ catch {
69
+ return false;
70
+ }
71
+ }
72
+ }
73
+ exports.RuntimeRegistry = RuntimeRegistry;
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.SandboxPolicy = void 0;
4
+ class SandboxPolicy {
5
+ evaluate(executor, riskLevel) {
6
+ if (riskLevel === 'high' && executor !== 'codex') {
7
+ return {
8
+ executor,
9
+ allowed: false,
10
+ mode: 'restricted',
11
+ rationale: 'Executores secundários não podem rodar missões de alto risco.'
12
+ };
13
+ }
14
+ return {
15
+ executor,
16
+ allowed: true,
17
+ mode: riskLevel === 'high' ? 'restricted' : 'baseline',
18
+ rationale: riskLevel === 'high' ? 'Missão de alto risco liberada apenas em modo restrito.' : 'Execução liberada no baseline atual.'
19
+ };
20
+ }
21
+ }
22
+ exports.SandboxPolicy = SandboxPolicy;
@@ -0,0 +1,169 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.SecurityDownloadGuard = void 0;
37
+ const fs = __importStar(require("fs"));
38
+ const path = __importStar(require("path"));
39
+ const os = __importStar(require("os"));
40
+ const ToolsetGuard_1 = require("./toolset/ToolsetGuard");
41
+ class SecurityDownloadGuard {
42
+ blockedPatterns = [
43
+ /(^|\/)\.git(\/|$)/i,
44
+ /(^|\/)node_modules(\/|$)/i,
45
+ /\.(exe|dll|bat|cmd|ps1|scr|com)$/i,
46
+ /(^|\/)__MACOSX(\/|$)/i,
47
+ /(^|\/)\.env/i,
48
+ ];
49
+ validateUrl(url) {
50
+ const trusted = [
51
+ 'https://skills.sh/',
52
+ 'https://clawhub.ai/',
53
+ 'https://mcpmarket.com/',
54
+ 'https://mcpservers.org/',
55
+ 'https://github.com/'
56
+ ];
57
+ const ok = trusted.some(t => url.startsWith(t));
58
+ return ok
59
+ ? { ok: true, blocked: [], warnings: [] }
60
+ : { ok: false, blocked: [url], warnings: ['untrusted_source'] };
61
+ }
62
+ scanFileList(paths) {
63
+ const blocked = paths.filter(p => this.blockedPatterns.some(rx => rx.test(p)));
64
+ const warnings = [];
65
+ if (paths.some(p => p.endsWith('.md') === false))
66
+ warnings.push('non_markdown_content_detected');
67
+ return { ok: blocked.length === 0, blocked, warnings };
68
+ }
69
+ scanExtractedDir(rootDir) {
70
+ const all = [];
71
+ const walk = (dir) => {
72
+ for (const e of fs.readdirSync(dir, { withFileTypes: true })) {
73
+ const full = `${dir}/${e.name}`;
74
+ if (e.isDirectory())
75
+ walk(full);
76
+ else
77
+ all.push(full.replace(`${rootDir}/`, ''));
78
+ }
79
+ };
80
+ walk(rootDir);
81
+ return this.scanFileList(all);
82
+ }
83
+ /**
84
+ * Story 9.1 — fetch a URL into a quarantine directory and run the
85
+ * existing scan pipeline before letting the caller move into `.catalog/`.
86
+ *
87
+ * Returns DownloadAndScanResult. Never throws. Caller is responsible
88
+ * for moving `downloadedTo` into its final home after inspecting the
89
+ * result.
90
+ *
91
+ * v1.4 supports single-file fetch only (markdown, YAML, JSON). Archive
92
+ * unpacking (zip / tar) is deferred to v1.5 — for v1.4, sources serve
93
+ * one manifest per import and we just trust the response body.
94
+ */
95
+ async downloadAndScan(url, targetDirOpt, opts = {}) {
96
+ (0, ToolsetGuard_1.assertToolsetAllowed)('web', 'SecurityDownloadGuard.downloadAndScan');
97
+ const errors = [];
98
+ const warnings = [];
99
+ const urlCheck = this.validateUrl(url);
100
+ if (!urlCheck.ok) {
101
+ return { ok: false, errors: ['untrusted_url'], warnings: urlCheck.warnings };
102
+ }
103
+ const targetDir = targetDirOpt || fs.mkdtempSync(path.join(os.tmpdir(), 'openlife-dl-'));
104
+ fs.mkdirSync(targetDir, { recursive: true });
105
+ const timeoutMs = opts.timeoutMs ?? 15000;
106
+ const maxBytes = opts.maxBytes ?? 5 * 1024 * 1024; // 5 MB cap
107
+ let body;
108
+ try {
109
+ const controller = new AbortController();
110
+ const timer = setTimeout(() => controller.abort(), timeoutMs);
111
+ const res = await fetch(url, { signal: controller.signal });
112
+ clearTimeout(timer);
113
+ if (!res.ok) {
114
+ errors.push(`fetch_status_${res.status}`);
115
+ return { ok: false, errors, warnings };
116
+ }
117
+ const contentLength = Number(res.headers.get('content-length') || '0');
118
+ if (contentLength > maxBytes) {
119
+ errors.push(`content_too_large:${contentLength}>max:${maxBytes}`);
120
+ return { ok: false, errors, warnings };
121
+ }
122
+ body = await res.arrayBuffer();
123
+ if (body.byteLength > maxBytes) {
124
+ errors.push(`body_too_large:${body.byteLength}`);
125
+ return { ok: false, errors, warnings };
126
+ }
127
+ }
128
+ catch (err) {
129
+ const msg = err instanceof Error ? err.message : String(err);
130
+ errors.push(`fetch_exception:${msg}`);
131
+ return { ok: false, errors, warnings };
132
+ }
133
+ // Choose a filename from the URL path (last segment, with fallback).
134
+ let filename = path.basename(new URL(url).pathname) || 'download.bin';
135
+ // Reject filenames that match blocked patterns (e.g. .exe, .dll).
136
+ const fileScan = this.scanFileList([filename]);
137
+ if (!fileScan.ok) {
138
+ errors.push(`filename_blocked:${fileScan.blocked.join(',')}`);
139
+ return { ok: false, errors, warnings: [...warnings, ...fileScan.warnings] };
140
+ }
141
+ const outPath = path.join(targetDir, filename);
142
+ try {
143
+ fs.writeFileSync(outPath, Buffer.from(body));
144
+ }
145
+ catch (err) {
146
+ const msg = err instanceof Error ? err.message : String(err);
147
+ errors.push(`write_exception:${msg}`);
148
+ return { ok: false, errors, warnings };
149
+ }
150
+ // Re-scan the dir for defence in depth.
151
+ const dirScan = this.scanExtractedDir(targetDir);
152
+ if (!dirScan.ok) {
153
+ errors.push(`dir_scan_blocked:${dirScan.blocked.join(',')}`);
154
+ try {
155
+ fs.unlinkSync(outPath);
156
+ }
157
+ catch { /* ignore */ }
158
+ return { ok: false, errors, warnings: [...warnings, ...dirScan.warnings] };
159
+ }
160
+ return {
161
+ ok: true,
162
+ downloadedTo: outPath,
163
+ bytesWritten: body.byteLength,
164
+ errors,
165
+ warnings: [...warnings, ...urlCheck.warnings, ...dirScan.warnings],
166
+ };
167
+ }
168
+ }
169
+ exports.SecurityDownloadGuard = SecurityDownloadGuard;