@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.
- package/INSTALL.md +266 -0
- package/LICENSE +21 -0
- package/README.md +142 -0
- package/bin/openlife.js +3 -0
- package/dist/admin_panel_server.js +66 -0
- package/dist/cli/AgentManager.js +109 -0
- package/dist/cli/AutonomousInstaller.js +134 -0
- package/dist/cli/DreamOrganizer.js +88 -0
- package/dist/cli/HostInstaller.js +426 -0
- package/dist/cli/InstallBanner.js +16 -0
- package/dist/cli/InstallFlow.js +256 -0
- package/dist/cli/InstallHeadless.js +47 -0
- package/dist/cli/InstallModules.js +148 -0
- package/dist/cli/InstallStateStore.js +75 -0
- package/dist/cli/InstallWizard.js +364 -0
- package/dist/cli/ProfileManager.js +163 -0
- package/dist/cli/SystemInstaller.js +89 -0
- package/dist/cli/WorldClassCommands.js +208 -0
- package/dist/design/DesignMdImporter.js +82 -0
- package/dist/design/DesignMdMode.js +93 -0
- package/dist/design/DesignMdRegistry.js +67 -0
- package/dist/index.js +2575 -0
- package/dist/memory/ConversationMemory.js +33 -0
- package/dist/memory/LocalMemoryProvider.js +86 -0
- package/dist/memory/Mem0Provider.js +16 -0
- package/dist/memory/MemoryNamespacePolicy.js +27 -0
- package/dist/memory/MemoryOrchestrator.js +65 -0
- package/dist/memory/MemoryPromotionFlow.js +32 -0
- package/dist/memory/MemoryProvider.js +2 -0
- package/dist/memory/MemoryProviderRegistry.js +27 -0
- package/dist/memory/MemoryRetentionPolicy.js +60 -0
- package/dist/memory/MempalaceProvider.js +72 -0
- package/dist/memory/OmniMemory.js +106 -0
- package/dist/memory/RedisAgentMemoryProvider.js +16 -0
- package/dist/memory/SessionManager.js +86 -0
- package/dist/memory/ZepGraphitiProvider.js +16 -0
- package/dist/orchestrator/AgentRegistry.js +56 -0
- package/dist/orchestrator/AgentScoring.js +82 -0
- package/dist/orchestrator/AgentTeam.js +22 -0
- package/dist/orchestrator/ArbitrationAgent.js +43 -0
- package/dist/orchestrator/ArbitrationScorecard.js +17 -0
- package/dist/orchestrator/AssetPromotionEngine.js +65 -0
- package/dist/orchestrator/AssetReuseRouter.js +63 -0
- package/dist/orchestrator/BenchmarkEngine.js +75 -0
- package/dist/orchestrator/Brain.js +298 -0
- package/dist/orchestrator/CadenceEngine.js +76 -0
- package/dist/orchestrator/CapabilityRouter.js +36 -0
- package/dist/orchestrator/CommandLanguage.js +27 -0
- package/dist/orchestrator/CommandRouter.js +70 -0
- package/dist/orchestrator/ConsequenceForecaster.js +286 -0
- package/dist/orchestrator/CronManager.js +286 -0
- package/dist/orchestrator/DynamicAgentBuilder.js +48 -0
- package/dist/orchestrator/DynamicAgentExecutor.js +15 -0
- package/dist/orchestrator/EnterpriseAgenticCore.js +276 -0
- package/dist/orchestrator/ExecutionBoard.js +86 -0
- package/dist/orchestrator/ExecutionIntent.js +13 -0
- package/dist/orchestrator/ExecutionModePolicy.js +48 -0
- package/dist/orchestrator/ExecutionRouter.js +9 -0
- package/dist/orchestrator/ExecutionState.js +20 -0
- package/dist/orchestrator/ExecutorHealth.js +86 -0
- package/dist/orchestrator/ExternalCatalogRegistry.js +83 -0
- package/dist/orchestrator/Gatekeeper.js +414 -0
- package/dist/orchestrator/Gateway.js +508 -0
- package/dist/orchestrator/GovernanceConsentStore.js +66 -0
- package/dist/orchestrator/GovernanceLayer.js +179 -0
- package/dist/orchestrator/GovernancePolicyStore.js +53 -0
- package/dist/orchestrator/GovernanceScopeLedger.js +134 -0
- package/dist/orchestrator/GovernanceScopePolicy.js +67 -0
- package/dist/orchestrator/IntentClassifier.js +45 -0
- package/dist/orchestrator/JobLifecycle.js +91 -0
- package/dist/orchestrator/LearningRouter.js +24 -0
- package/dist/orchestrator/MediaManager.js +92 -0
- package/dist/orchestrator/MemoryCuratorAgent.js +41 -0
- package/dist/orchestrator/MissionState.js +155 -0
- package/dist/orchestrator/ModelManager.js +84 -0
- package/dist/orchestrator/OperatingSystem.js +71 -0
- package/dist/orchestrator/OperationalMemoryStore.js +94 -0
- package/dist/orchestrator/OptimizationLoop.js +72 -0
- package/dist/orchestrator/OrchestrationLoop.js +905 -0
- package/dist/orchestrator/OrgStructure.js +88 -0
- package/dist/orchestrator/OutcomeSimulator.js +46 -0
- package/dist/orchestrator/ParallelOrchestrationLoop.js +36 -0
- package/dist/orchestrator/PerformanceScorecard.js +105 -0
- package/dist/orchestrator/PlannerAgent.js +46 -0
- package/dist/orchestrator/ProcessSandbox.js +129 -0
- package/dist/orchestrator/PromotionPipeline.js +74 -0
- package/dist/orchestrator/PromotionReviewGate.js +11 -0
- package/dist/orchestrator/QueueScheduler.js +260 -0
- package/dist/orchestrator/ReleaseGate.js +36 -0
- package/dist/orchestrator/ReleaseWorkflow.js +68 -0
- package/dist/orchestrator/RemotePublisher.js +139 -0
- package/dist/orchestrator/ReuseEngine.js +89 -0
- package/dist/orchestrator/ReviewerAgent.js +49 -0
- package/dist/orchestrator/RoleHandoff.js +65 -0
- package/dist/orchestrator/RuntimeHealthMonitor.js +143 -0
- package/dist/orchestrator/RuntimePolicy.js +105 -0
- package/dist/orchestrator/RuntimeProbe.js +97 -0
- package/dist/orchestrator/RuntimeRegistry.js +73 -0
- package/dist/orchestrator/SandboxPolicy.js +22 -0
- package/dist/orchestrator/SecurityDownloadGuard.js +169 -0
- package/dist/orchestrator/SecurityEventStore.js +58 -0
- package/dist/orchestrator/ServiceCompletionPolicy.js +36 -0
- package/dist/orchestrator/ServiceState.js +195 -0
- package/dist/orchestrator/SkillCreator.js +404 -0
- package/dist/orchestrator/SkillLearningLoop.js +57 -0
- package/dist/orchestrator/SkillManager.js +75 -0
- package/dist/orchestrator/SkillNetwork.js +29 -0
- package/dist/orchestrator/SkillRegistryV2.js +28 -0
- package/dist/orchestrator/SkillScoring.js +70 -0
- package/dist/orchestrator/SquadAutoCreator.js +64 -0
- package/dist/orchestrator/SquadCreator.js +727 -0
- package/dist/orchestrator/SquadRegistry.js +28 -0
- package/dist/orchestrator/SquadRouter.js +33 -0
- package/dist/orchestrator/SquadScoring.js +70 -0
- package/dist/orchestrator/SubagentLifecycle.js +90 -0
- package/dist/orchestrator/SynthesizerAgent.js +48 -0
- package/dist/orchestrator/SystemDoctor.js +224 -0
- package/dist/orchestrator/TaskExecutor.js +422 -0
- package/dist/orchestrator/TeammateBoard.js +61 -0
- package/dist/orchestrator/TestHarness.js +184 -0
- package/dist/orchestrator/VoiceManager.js +203 -0
- package/dist/orchestrator/VoiceRouter.js +89 -0
- package/dist/orchestrator/capability/CapabilityGenesisEngine.js +278 -0
- package/dist/orchestrator/capability/CapabilityPackParser.js +223 -0
- package/dist/orchestrator/capability/CapabilityPackSchema.js +62 -0
- package/dist/orchestrator/capability/CapabilityPackState.js +163 -0
- package/dist/orchestrator/providers/AgentProvider.js +2 -0
- package/dist/orchestrator/providers/CapabilityProvider.js +12 -0
- package/dist/orchestrator/providers/CloudAgentProvider.js +55 -0
- package/dist/orchestrator/providers/CloudSkillProvider.js +55 -0
- package/dist/orchestrator/providers/CloudSquadProvider.js +55 -0
- package/dist/orchestrator/providers/CompositeAgentProvider.js +16 -0
- package/dist/orchestrator/providers/CompositeCapabilityProvider.js +25 -0
- package/dist/orchestrator/providers/CompositeSkillProvider.js +16 -0
- package/dist/orchestrator/providers/CompositeSquadProvider.js +16 -0
- package/dist/orchestrator/providers/CompositeWorkflowProvider.js +46 -0
- package/dist/orchestrator/providers/FileAgentProvider.js +105 -0
- package/dist/orchestrator/providers/FileCapabilityProvider.js +106 -0
- package/dist/orchestrator/providers/FileSkillProvider.js +65 -0
- package/dist/orchestrator/providers/FileSquadProvider.js +69 -0
- package/dist/orchestrator/providers/FileWorkflowProvider.js +103 -0
- package/dist/orchestrator/providers/SkillProvider.js +2 -0
- package/dist/orchestrator/providers/SquadProvider.js +2 -0
- package/dist/orchestrator/toolset/ToolsetGuard.js +69 -0
- package/dist/orchestrator/toolset/ToolsetRegistry.js +65 -0
- package/dist/orchestrator/toolset/ToolsetSchema.js +21 -0
- package/dist/orchestrator/util/AtomicWriter.js +204 -0
- package/dist/orchestrator/util/DistributedLock.js +232 -0
- package/dist/orchestrator/util/TemplateRenderer.js +87 -0
- package/dist/orchestrator/util/WatchdogHeartbeat.js +116 -0
- package/dist/orchestrator/workflow/ConditionParser.js +232 -0
- package/dist/orchestrator/workflow/WorkflowEngine.js +379 -0
- package/dist/orchestrator/workflow/WorkflowParser.js +368 -0
- package/dist/orchestrator/workflow/WorkflowSchema.js +65 -0
- package/dist/orchestrator/workflow/WorkflowState.js +11 -0
- package/dist/reversa/ReversaAgent.js +134 -0
- package/dist/reversa/ReversaContracts.js +62 -0
- package/dist/reversa/ReversaExecutors.js +65 -0
- package/dist/skills/SkillRegistry.js +71 -0
- package/dist/squads/SquadManager.js +87 -0
- package/dist/test_admin_teams_networks.js +54 -0
- package/dist/test_agent_team_skill_network.js +15 -0
- package/dist/test_aiobuilder_cli_parity.js +169 -0
- package/dist/test_ask_exit.js +73 -0
- package/dist/test_atomic_writer.js +209 -0
- package/dist/test_autonomous_soak.js +141 -0
- package/dist/test_benchmark_engine.js +41 -0
- package/dist/test_brain_error_diagnostics.js +51 -0
- package/dist/test_brain_fallback_chain.js +93 -0
- package/dist/test_capability_genesis_engine.js +225 -0
- package/dist/test_capability_pack_schema.js +214 -0
- package/dist/test_catalog_quality.js +150 -0
- package/dist/test_cli_crud_roundtrip.js +154 -0
- package/dist/test_cli_diagnostics.js +131 -0
- package/dist/test_cli_doc_parity.js +126 -0
- package/dist/test_cli_help_surface.js +106 -0
- package/dist/test_cli_service_commands.js +83 -0
- package/dist/test_consequence_forecast_brain.js +165 -0
- package/dist/test_consequence_forecaster.js +24 -0
- package/dist/test_conversation_memory.js +36 -0
- package/dist/test_create_entities.js +54 -0
- package/dist/test_creator_placeholders_completed.js +177 -0
- package/dist/test_cron_manager.js +123 -0
- package/dist/test_daemon_sigterm.js +72 -0
- package/dist/test_deep_research_capability.js +87 -0
- package/dist/test_designmd_import_registry.js +16 -0
- package/dist/test_designmd_mode.js +50 -0
- package/dist/test_designmd_mode_workspace.js +13 -0
- package/dist/test_dist_templates_layout.js +135 -0
- package/dist/test_distributed_lock.js +201 -0
- package/dist/test_distribution_installability.js +67 -0
- package/dist/test_doctor_sandbox_check.js +44 -0
- package/dist/test_dream_organizer.js +25 -0
- package/dist/test_dual_mode.js +15 -0
- package/dist/test_enterprise_agentic_core.js +128 -0
- package/dist/test_forecast_brain_wiring.js +87 -0
- package/dist/test_gateway_telegram_guardrails.js +52 -0
- package/dist/test_governance.js +34 -0
- package/dist/test_governance_advanced.js +75 -0
- package/dist/test_governance_scope_ledger.js +147 -0
- package/dist/test_governance_v13_policies.js +44 -0
- package/dist/test_guided_creator_cli.js +100 -0
- package/dist/test_host_install_e2e.js +324 -0
- package/dist/test_host_installer.js +259 -0
- package/dist/test_host_installers_gemini_codex.js +95 -0
- package/dist/test_host_uninstaller.js +295 -0
- package/dist/test_install_flow.js +70 -0
- package/dist/test_install_flow_host_validation.js +143 -0
- package/dist/test_install_wizard.js +272 -0
- package/dist/test_integration_gemini_live.js +95 -0
- package/dist/test_integration_http_trigger_live.js +154 -0
- package/dist/test_integration_telegram_live.js +102 -0
- package/dist/test_job_lifecycle.js +16 -0
- package/dist/test_memory_orchestrator.js +33 -0
- package/dist/test_memory_promotion.js +36 -0
- package/dist/test_memory_retention.js +37 -0
- package/dist/test_mission_checkpoint.js +204 -0
- package/dist/test_multi_host_docs_parity.js +125 -0
- package/dist/test_openlife_auto_creator_routing.js +69 -0
- package/dist/test_openlife_evolution_surface.js +77 -0
- package/dist/test_openlife_gatekeeper_routing.js +15 -0
- package/dist/test_openlife_routing_surface.js +27 -0
- package/dist/test_openlife_runtime_source_truth.js +25 -0
- package/dist/test_operating_system.js +45 -0
- package/dist/test_optimization_loop.js +38 -0
- package/dist/test_orchestration_assets_lifecycle.js +78 -0
- package/dist/test_outcome_simulator.js +38 -0
- package/dist/test_performance_latency.js +215 -0
- package/dist/test_performance_scorecard.js +38 -0
- package/dist/test_phase1_check_exit.js +103 -0
- package/dist/test_phase6_board.js +31 -0
- package/dist/test_phase6_cadence.js +29 -0
- package/dist/test_phase6_ops.js +37 -0
- package/dist/test_post_mission_evaluation.js +190 -0
- package/dist/test_process_sandbox.js +88 -0
- package/dist/test_profile_toolset_mcp.js +125 -0
- package/dist/test_queue_scheduler.js +239 -0
- package/dist/test_release_gate.js +23 -0
- package/dist/test_remote_publish.js +193 -0
- package/dist/test_reversa_contracts_e2e.js +48 -0
- package/dist/test_reversa_export_and_strict.js +51 -0
- package/dist/test_reversa_full_execution.js +12 -0
- package/dist/test_reversa_lite.js +9 -0
- package/dist/test_royal_stack_golden.js +179 -0
- package/dist/test_runtime_health_backoff.js +154 -0
- package/dist/test_runtime_policy.js +26 -0
- package/dist/test_runtime_probe.js +19 -0
- package/dist/test_runtime_profile_oauth_only.js +262 -0
- package/dist/test_runtime_registry.js +11 -0
- package/dist/test_security_download_and_scan.js +103 -0
- package/dist/test_security_download_guard.js +14 -0
- package/dist/test_service_command_surface.js +12 -0
- package/dist/test_service_completion_policy.js +32 -0
- package/dist/test_service_guardrails_delete.js +12 -0
- package/dist/test_service_mode_explicit_only.js +174 -0
- package/dist/test_sources_import_ref.js +46 -0
- package/dist/test_sources_scaffold.js +43 -0
- package/dist/test_squad_skill_creator.js +305 -0
- package/dist/test_squad_skill_design_llm.js +176 -0
- package/dist/test_subsystems_org_state.js +271 -0
- package/dist/test_subsystems_promotion_memory_assets.js +343 -0
- package/dist/test_subsystems_routing_governance.js +234 -0
- package/dist/test_task_executor_sandbox_optin.js +127 -0
- package/dist/test_teammate_learning.js +15 -0
- package/dist/test_telegram_delete_guardrail.js +21 -0
- package/dist/test_toolset_enforcement.js +188 -0
- package/dist/test_trigger_basic_auth.js +112 -0
- package/dist/test_util/doc_parity.js +120 -0
- package/dist/test_v15_e2e_integration.js +207 -0
- package/dist/test_watchdog_heartbeat.js +152 -0
- package/dist/test_workflow_condition_parser.js +63 -0
- package/dist/test_workflow_e2e.js +240 -0
- package/dist/test_workflow_engine.js +330 -0
- package/dist/test_workflow_parser.js +245 -0
- package/dist/test_workflow_schema_backward_compat.js +197 -0
- package/dist-templates/README.md +91 -0
- package/dist-templates/claude-code/agents/openlife-atlas.md +52 -0
- package/dist-templates/claude-code/agents/openlife-forge.md +42 -0
- package/dist-templates/claude-code/agents/openlife-genesis.md +59 -0
- package/dist-templates/claude-code/agents/openlife-lyra.md +40 -0
- package/dist-templates/claude-code/agents/openlife-maestro.md +45 -0
- package/dist-templates/claude-code/commands/openlife/ask.md +14 -0
- package/dist-templates/claude-code/commands/openlife/doctor.md +19 -0
- package/dist-templates/claude-code/commands/openlife/dream.md +20 -0
- package/dist-templates/claude-code/commands/openlife/status.md +14 -0
- package/dist-templates/claude-code/mcp/openlife-orchestrator.json +46 -0
- package/dist-templates/codex/README.md +7 -0
- package/dist-templates/codex/agents/openlife-atlas.md +52 -0
- package/dist-templates/codex/agents/openlife-forge.md +42 -0
- package/dist-templates/codex/agents/openlife-genesis.md +59 -0
- package/dist-templates/codex/agents/openlife-lyra.md +40 -0
- package/dist-templates/codex/agents/openlife-maestro.md +45 -0
- package/dist-templates/codex/commands/openlife/ask.md +14 -0
- package/dist-templates/codex/commands/openlife/doctor.md +19 -0
- package/dist-templates/codex/commands/openlife/dream.md +20 -0
- package/dist-templates/codex/commands/openlife/status.md +14 -0
- package/dist-templates/codex/mcp/openlife-orchestrator.json +46 -0
- package/dist-templates/gemini-cli/README.md +8 -0
- package/dist-templates/gemini-cli/agents/openlife-atlas.md +52 -0
- package/dist-templates/gemini-cli/agents/openlife-forge.md +42 -0
- package/dist-templates/gemini-cli/agents/openlife-genesis.md +59 -0
- package/dist-templates/gemini-cli/agents/openlife-lyra.md +40 -0
- package/dist-templates/gemini-cli/agents/openlife-maestro.md +45 -0
- package/dist-templates/gemini-cli/commands/openlife/ask.md +14 -0
- package/dist-templates/gemini-cli/commands/openlife/doctor.md +19 -0
- package/dist-templates/gemini-cli/commands/openlife/dream.md +20 -0
- package/dist-templates/gemini-cli/commands/openlife/status.md +14 -0
- package/dist-templates/gemini-cli/mcp/openlife-orchestrator.json +46 -0
- package/dist-templates/skill-template/README.md +34 -0
- package/dist-templates/skill-template/SKILL.md.template +59 -0
- package/dist-templates/squad-template/README.md +82 -0
- package/dist-templates/squad-template/SQUAD.md.template +51 -0
- package/dist-templates/squad-template/agent-template.md +51 -0
- package/dist-templates/squad-template/checklist-template.md +25 -0
- package/dist-templates/squad-template/task-template.md +36 -0
- package/dist-templates/workflows/PORTED_WORKFLOWS.md +60 -0
- package/dist-templates/workflows/brownfield-discovery.yaml +137 -0
- package/dist-templates/workflows/greenfield-fullstack.yaml +132 -0
- package/dist-templates/workflows/qa-loop.yaml +125 -0
- package/dist-templates/workflows/story-development-cycle.yaml +80 -0
- package/docs/CHANGELOG_FEATURE_ROLLOUT_DESIGNMD.md +43 -0
- package/docs/EXTERNAL_SOURCES_AND_SECURITY_GUARD.md +33 -0
- package/docs/OPENLIFE_AUDIT_2026-05-06.md +170 -0
- package/docs/OPENLIFE_CONSOLIDATED_PLAN_2026-05-06.md +299 -0
- package/docs/OPENLIFE_DUAL_MODE_IMPLEMENTATION_PLAN.md +205 -0
- package/docs/OPENLIFE_EVOLUTION_SURFACE_2026-05-07.md +53 -0
- package/docs/OPENLIFE_SKILLS_IMPORT_2026-05-07.json +223 -0
- package/docs/OPENLIFE_SQUADS_IMPORT_2026-05-07.json +184 -0
- package/docs/PAPERCLIP_OPENLIFE_INVESTIGATION.md +85 -0
- package/docs/README.md +28 -0
- package/docs/RELEASE_ORGANIZATION_PLAN.md +164 -0
- package/docs/audit/CLI-EXECUTION-RESULTS.md +113 -0
- package/docs/audit/CLI-MATRIX.md +556 -0
- package/docs/audit/DOC-PARITY-GAPS.md +351 -0
- package/docs/audit/ORCHESTRATOR-MATRIX.md +136 -0
- package/docs/audit/TEST-COVERAGE-GAPS.md +334 -0
- package/docs/audit/integrations/SKIPPED.md +101 -0
- package/docs/autonomous-install.md +79 -0
- package/docs/capability-genesis.md +137 -0
- package/docs/capability-pack-schema.md +157 -0
- package/docs/commands.md +82 -0
- package/docs/deep-research-capability.md +114 -0
- package/docs/development/typescript-conventions.md +95 -0
- package/docs/host-installers.md +68 -0
- package/docs/install/aiobuilder.md +70 -0
- package/docs/install/claude-code.md +83 -0
- package/docs/install/codex.md +64 -0
- package/docs/install/gemini-cli.md +64 -0
- package/docs/install/runtime-profiles.md +83 -0
- package/docs/openlife-agent-os-blueprint.md +114 -0
- package/docs/openlife-install-backlog.md +115 -0
- package/docs/openlife-install-spec.md +306 -0
- package/docs/operations/CLOUD_CUTOVER_AUDIT.md +37 -0
- package/docs/operations/PHASE_PROGRESS_CONTINUATION.md +24 -0
- package/docs/performance-benchmarks.md +83 -0
- package/docs/planning/v1.3-capability-genesis.md +157 -0
- package/docs/plans/2026-05-05-admin-interface-professional-dark-premium-plan.md +84 -0
- package/docs/plans/2026-05-05-openlife-autonomous-domain-marketplace-masterplan.md +122 -0
- package/docs/quickstart.md +60 -0
- package/docs/release-process.md +236 -0
- package/docs/roadmap/OPENLIFE_MASTER_PLAN_CLOUD_V3.md +97 -0
- package/docs/sandboxing-research.md +117 -0
- package/docs/stories/epic-feature-audit/1.1.story.md +84 -0
- package/docs/stories/epic-feature-audit/1.2.story.md +102 -0
- package/docs/stories/epic-feature-audit/1.3.story.md +93 -0
- package/docs/stories/epic-feature-audit/1.5.story.md +121 -0
- package/docs/stories/epic-feature-audit/1.6.story.md +80 -0
- package/docs/stories/epic-feature-completeness/2.1.story.md +70 -0
- package/docs/stories/epic-feature-completeness/2.2.story.md +49 -0
- package/docs/stories/epic-feature-completeness/2.3.story.md +74 -0
- package/docs/stories/epic-feature-completeness/2.4.story.md +71 -0
- package/docs/stories/epic-feature-completeness/3.1.story.md +56 -0
- package/docs/stories/epic-feature-completeness/3.2.story.md +80 -0
- package/docs/stories/epic-feature-completeness/3.3.story.md +68 -0
- package/docs/stories/epic-feature-completeness/3.4.story.md +71 -0
- package/docs/stories/epic-feature-completeness/3.5.story.md +72 -0
- package/docs/stories/epic-feature-completeness/3.6.story.md +69 -0
- package/docs/stories/epic-feature-completeness/3.7.story.md +68 -0
- package/docs/stories/epic-feature-completeness/3.8.story.md +57 -0
- package/docs/toolset-enforcement.md +122 -0
- package/docs/v1.4-changelog.md +159 -0
- package/docs/v1.5-changelog.md +106 -0
- package/docs/v1.5-roadmap.md +121 -0
- package/docs/v1.6-changelog.md +67 -0
- package/docs/v1.6-roadmap.md +89 -0
- package/docs/v1.7-changelog.md +98 -0
- package/docs/workflow-schema.md +177 -0
- package/package.json +177 -0
- package/scripts/clean-test-pollution.js +61 -0
- package/scripts/openlife-agent-start.sh +6 -0
- package/scripts/openlife-agent.service.example +13 -0
- package/scripts/openlife-agent.supervisord.conf.example +8 -0
- package/scripts/openlife-autonomous-install.sh +29 -0
- 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;
|