@moorline/core 0.0.1
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/dist/app/bootstrap/apiAdapterPackageLoader.d.ts +21 -0
- package/dist/app/bootstrap/apiAdapterPackageLoader.js +143 -0
- package/dist/app/bootstrap/apiAdapterPackageLoader.js.map +1 -0
- package/dist/app/bootstrap/officialCatalog.d.ts +1 -0
- package/dist/app/bootstrap/officialCatalog.js +2 -0
- package/dist/app/bootstrap/officialCatalog.js.map +1 -0
- package/dist/app/bootstrap/operatorPackageService.d.ts +79 -0
- package/dist/app/bootstrap/operatorPackageService.js +1025 -0
- package/dist/app/bootstrap/operatorPackageService.js.map +1 -0
- package/dist/app/bootstrap/providerPackageLoader.d.ts +12 -0
- package/dist/app/bootstrap/providerPackageLoader.js +139 -0
- package/dist/app/bootstrap/providerPackageLoader.js.map +1 -0
- package/dist/app/bootstrap/runtimeBootstrap.d.ts +12 -0
- package/dist/app/bootstrap/runtimeBootstrap.js +46 -0
- package/dist/app/bootstrap/runtimeBootstrap.js.map +1 -0
- package/dist/app/bootstrap/transportPackageLoader.d.ts +23 -0
- package/dist/app/bootstrap/transportPackageLoader.js +149 -0
- package/dist/app/bootstrap/transportPackageLoader.js.map +1 -0
- package/dist/app/control-api/services/actions.d.ts +140 -0
- package/dist/app/control-api/services/actions.js +312 -0
- package/dist/app/control-api/services/actions.js.map +1 -0
- package/dist/app/control-api/services/controlPlane.d.ts +245 -0
- package/dist/app/control-api/services/controlPlane.js +301 -0
- package/dist/app/control-api/services/controlPlane.js.map +1 -0
- package/dist/app/control-api/services/runtimeHost.d.ts +61 -0
- package/dist/app/control-api/services/runtimeHost.js +117 -0
- package/dist/app/control-api/services/runtimeHost.js.map +1 -0
- package/dist/app/control-api/services/state.d.ts +19 -0
- package/dist/app/control-api/services/state.js +177 -0
- package/dist/app/control-api/services/state.js.map +1 -0
- package/dist/core/domain/memory/operatorMemoryService.d.ts +36 -0
- package/dist/core/domain/memory/operatorMemoryService.js +81 -0
- package/dist/core/domain/memory/operatorMemoryService.js.map +1 -0
- package/dist/core/domain/memory/pathSafety.d.ts +2 -0
- package/dist/core/domain/memory/pathSafety.js +36 -0
- package/dist/core/domain/memory/pathSafety.js.map +1 -0
- package/dist/core/domain/memory/retrieval/fileWalker.d.ts +1 -0
- package/dist/core/domain/memory/retrieval/fileWalker.js +31 -0
- package/dist/core/domain/memory/retrieval/fileWalker.js.map +1 -0
- package/dist/core/domain/memory/retrieval/indexTargets.d.ts +3 -0
- package/dist/core/domain/memory/retrieval/indexTargets.js +43 -0
- package/dist/core/domain/memory/retrieval/indexTargets.js.map +1 -0
- package/dist/core/domain/memory/retrieval/markdownChunker.d.ts +3 -0
- package/dist/core/domain/memory/retrieval/markdownChunker.js +77 -0
- package/dist/core/domain/memory/retrieval/markdownChunker.js.map +1 -0
- package/dist/core/domain/memory/retrieval/parse.d.ts +2 -0
- package/dist/core/domain/memory/retrieval/parse.js +28 -0
- package/dist/core/domain/memory/retrieval/parse.js.map +1 -0
- package/dist/core/domain/memory/retrieval/ranking.d.ts +11 -0
- package/dist/core/domain/memory/retrieval/ranking.js +63 -0
- package/dist/core/domain/memory/retrieval/ranking.js.map +1 -0
- package/dist/core/domain/memory/retrieval/schema.d.ts +2 -0
- package/dist/core/domain/memory/retrieval/schema.js +105 -0
- package/dist/core/domain/memory/retrieval/schema.js.map +1 -0
- package/dist/core/domain/memory/retrieval/scope.d.ts +20 -0
- package/dist/core/domain/memory/retrieval/scope.js +38 -0
- package/dist/core/domain/memory/retrieval/scope.js.map +1 -0
- package/dist/core/domain/memory/retrieval/tokenEmbedding.d.ts +4 -0
- package/dist/core/domain/memory/retrieval/tokenEmbedding.js +44 -0
- package/dist/core/domain/memory/retrieval/tokenEmbedding.js.map +1 -0
- package/dist/core/domain/memory/retrieval/types.d.ts +88 -0
- package/dist/core/domain/memory/retrieval/types.js +7 -0
- package/dist/core/domain/memory/retrieval/types.js.map +1 -0
- package/dist/core/domain/memory/retrieval.d.ts +4 -0
- package/dist/core/domain/memory/retrieval.js +398 -0
- package/dist/core/domain/memory/retrieval.js.map +1 -0
- package/dist/core/domain/memory/store.d.ts +28 -0
- package/dist/core/domain/memory/store.js +52 -0
- package/dist/core/domain/memory/store.js.map +1 -0
- package/dist/core/domain/missions/missionDraftSetup.d.ts +12 -0
- package/dist/core/domain/missions/missionDraftSetup.js +92 -0
- package/dist/core/domain/missions/missionDraftSetup.js.map +1 -0
- package/dist/core/domain/missions/missionHookService.d.ts +41 -0
- package/dist/core/domain/missions/missionHookService.js +161 -0
- package/dist/core/domain/missions/missionHookService.js.map +1 -0
- package/dist/core/domain/missions/missionHookValidation.d.ts +8 -0
- package/dist/core/domain/missions/missionHookValidation.js +59 -0
- package/dist/core/domain/missions/missionHookValidation.js.map +1 -0
- package/dist/core/domain/missions/missionRegistry.d.ts +55 -0
- package/dist/core/domain/missions/missionRegistry.js +204 -0
- package/dist/core/domain/missions/missionRegistry.js.map +1 -0
- package/dist/core/domain/missions/missionSchedule.d.ts +24 -0
- package/dist/core/domain/missions/missionSchedule.js +441 -0
- package/dist/core/domain/missions/missionSchedule.js.map +1 -0
- package/dist/core/domain/sessions/lifecycleOrchestration.d.ts +23 -0
- package/dist/core/domain/sessions/lifecycleOrchestration.js +18 -0
- package/dist/core/domain/sessions/lifecycleOrchestration.js.map +1 -0
- package/dist/core/domain/sessions/managedWorkerSessions.d.ts +3 -0
- package/dist/core/domain/sessions/managedWorkerSessions.js +4 -0
- package/dist/core/domain/sessions/managedWorkerSessions.js.map +1 -0
- package/dist/core/domain/sessions/runtimeWorkManagementService.d.ts +129 -0
- package/dist/core/domain/sessions/runtimeWorkManagementService.js +627 -0
- package/dist/core/domain/sessions/runtimeWorkManagementService.js.map +1 -0
- package/dist/core/domain/sessions/sessionLifecycleService.d.ts +21 -0
- package/dist/core/domain/sessions/sessionLifecycleService.js +76 -0
- package/dist/core/domain/sessions/sessionLifecycleService.js.map +1 -0
- package/dist/core/domain/sessions/sessionState.d.ts +34 -0
- package/dist/core/domain/sessions/sessionState.js +154 -0
- package/dist/core/domain/sessions/sessionState.js.map +1 -0
- package/dist/core/domain/sessions/workManagement/managedSessionLimit.d.ts +3 -0
- package/dist/core/domain/sessions/workManagement/managedSessionLimit.js +15 -0
- package/dist/core/domain/sessions/workManagement/managedSessionLimit.js.map +1 -0
- package/dist/core/domain/sessions/workManagement/spaceNames.d.ts +2 -0
- package/dist/core/domain/sessions/workManagement/spaceNames.js +15 -0
- package/dist/core/domain/sessions/workManagement/spaceNames.js.map +1 -0
- package/dist/core/extension/capabilities/capabilities.d.ts +8 -0
- package/dist/core/extension/capabilities/capabilities.js +40 -0
- package/dist/core/extension/capabilities/capabilities.js.map +1 -0
- package/dist/core/extension/packages/archiveExtraction.d.ts +1 -0
- package/dist/core/extension/packages/archiveExtraction.js +194 -0
- package/dist/core/extension/packages/archiveExtraction.js.map +1 -0
- package/dist/core/extension/packages/npmRegistryClient.d.ts +24 -0
- package/dist/core/extension/packages/npmRegistryClient.js +261 -0
- package/dist/core/extension/packages/npmRegistryClient.js.map +1 -0
- package/dist/core/extension/packages/officialArchiveResolver.d.ts +2 -0
- package/dist/core/extension/packages/officialArchiveResolver.js +51 -0
- package/dist/core/extension/packages/officialArchiveResolver.js.map +1 -0
- package/dist/core/extension/packages/officialCatalog.d.ts +9 -0
- package/dist/core/extension/packages/officialCatalog.js +198 -0
- package/dist/core/extension/packages/officialCatalog.js.map +1 -0
- package/dist/core/extension/packages/packageActivation.d.ts +21 -0
- package/dist/core/extension/packages/packageActivation.js +81 -0
- package/dist/core/extension/packages/packageActivation.js.map +1 -0
- package/dist/core/extension/packages/packageApplyPlanner.d.ts +4 -0
- package/dist/core/extension/packages/packageApplyPlanner.js +79 -0
- package/dist/core/extension/packages/packageApplyPlanner.js.map +1 -0
- package/dist/core/extension/packages/packageBundleRoot.d.ts +1 -0
- package/dist/core/extension/packages/packageBundleRoot.js +34 -0
- package/dist/core/extension/packages/packageBundleRoot.js.map +1 -0
- package/dist/core/extension/packages/packageConfigSchema.d.ts +7 -0
- package/dist/core/extension/packages/packageConfigSchema.js +86 -0
- package/dist/core/extension/packages/packageConfigSchema.js.map +1 -0
- package/dist/core/extension/packages/packageDependencyResolver.d.ts +13 -0
- package/dist/core/extension/packages/packageDependencyResolver.js +128 -0
- package/dist/core/extension/packages/packageDependencyResolver.js.map +1 -0
- package/dist/core/extension/packages/packageDistroMetadata.d.ts +14 -0
- package/dist/core/extension/packages/packageDistroMetadata.js +153 -0
- package/dist/core/extension/packages/packageDistroMetadata.js.map +1 -0
- package/dist/core/extension/packages/packageInstaller.d.ts +27 -0
- package/dist/core/extension/packages/packageInstaller.js +269 -0
- package/dist/core/extension/packages/packageInstaller.js.map +1 -0
- package/dist/core/extension/packages/packageInventoryStore.d.ts +25 -0
- package/dist/core/extension/packages/packageInventoryStore.js +398 -0
- package/dist/core/extension/packages/packageInventoryStore.js.map +1 -0
- package/dist/core/extension/packages/packageManifest.d.ts +15 -0
- package/dist/core/extension/packages/packageManifest.js +65 -0
- package/dist/core/extension/packages/packageManifest.js.map +1 -0
- package/dist/core/extension/packages/packageRegistryBlocklist.d.ts +10 -0
- package/dist/core/extension/packages/packageRegistryBlocklist.js +13 -0
- package/dist/core/extension/packages/packageRegistryBlocklist.js.map +1 -0
- package/dist/core/extension/packages/packageRegistryService.d.ts +22 -0
- package/dist/core/extension/packages/packageRegistryService.js +123 -0
- package/dist/core/extension/packages/packageRegistryService.js.map +1 -0
- package/dist/core/extension/packages/packageRegistryTypes.d.ts +33 -0
- package/dist/core/extension/packages/packageRegistryTypes.js +2 -0
- package/dist/core/extension/packages/packageRegistryTypes.js.map +1 -0
- package/dist/core/extension/packages/packageSource.d.ts +8 -0
- package/dist/core/extension/packages/packageSource.js +116 -0
- package/dist/core/extension/packages/packageSource.js.map +1 -0
- package/dist/core/extension/packages/packageSourceLimits.d.ts +5 -0
- package/dist/core/extension/packages/packageSourceLimits.js +6 -0
- package/dist/core/extension/packages/packageSourceLimits.js.map +1 -0
- package/dist/core/extension/packages/packageValidation.d.ts +2 -0
- package/dist/core/extension/packages/packageValidation.js +67 -0
- package/dist/core/extension/packages/packageValidation.js.map +1 -0
- package/dist/core/extension/packages/packageVersionResolver.d.ts +28 -0
- package/dist/core/extension/packages/packageVersionResolver.js +78 -0
- package/dist/core/extension/packages/packageVersionResolver.js.map +1 -0
- package/dist/core/extension/packages/remoteArchiveDownloader.d.ts +10 -0
- package/dist/core/extension/packages/remoteArchiveDownloader.js +156 -0
- package/dist/core/extension/packages/remoteArchiveDownloader.js.map +1 -0
- package/dist/core/extension/packages/runtimeStartability.d.ts +16 -0
- package/dist/core/extension/packages/runtimeStartability.js +237 -0
- package/dist/core/extension/packages/runtimeStartability.js.map +1 -0
- package/dist/core/extension/plugins/pluginHost.d.ts +50 -0
- package/dist/core/extension/plugins/pluginHost.js +303 -0
- package/dist/core/extension/plugins/pluginHost.js.map +1 -0
- package/dist/core/extension/plugins/pluginId.d.ts +2 -0
- package/dist/core/extension/plugins/pluginId.js +8 -0
- package/dist/core/extension/plugins/pluginId.js.map +1 -0
- package/dist/core/extension/plugins/pluginManifest.d.ts +3 -0
- package/dist/core/extension/plugins/pluginManifest.js +17 -0
- package/dist/core/extension/plugins/pluginManifest.js.map +1 -0
- package/dist/core/extension/plugins/runtimePluginLoader.d.ts +7 -0
- package/dist/core/extension/plugins/runtimePluginLoader.js +160 -0
- package/dist/core/extension/plugins/runtimePluginLoader.js.map +1 -0
- package/dist/core/extension/skills/skillRegistry.d.ts +21 -0
- package/dist/core/extension/skills/skillRegistry.js +233 -0
- package/dist/core/extension/skills/skillRegistry.js.map +1 -0
- package/dist/core/extension/skills/skillWriter.d.ts +20 -0
- package/dist/core/extension/skills/skillWriter.js +150 -0
- package/dist/core/extension/skills/skillWriter.js.map +1 -0
- package/dist/core/runtime/execution/commandReactor.d.ts +31 -0
- package/dist/core/runtime/execution/commandReactor.js +38 -0
- package/dist/core/runtime/execution/commandReactor.js.map +1 -0
- package/dist/core/runtime/execution/defaultModelSelection.d.ts +4 -0
- package/dist/core/runtime/execution/defaultModelSelection.js +17 -0
- package/dist/core/runtime/execution/defaultModelSelection.js.map +1 -0
- package/dist/core/runtime/execution/drainableWorker.d.ts +27 -0
- package/dist/core/runtime/execution/drainableWorker.js +79 -0
- package/dist/core/runtime/execution/drainableWorker.js.map +1 -0
- package/dist/core/runtime/execution/orchestrationEngine.d.ts +16 -0
- package/dist/core/runtime/execution/orchestrationEngine.js +181 -0
- package/dist/core/runtime/execution/orchestrationEngine.js.map +1 -0
- package/dist/core/runtime/execution/orchestrationHealth.d.ts +45 -0
- package/dist/core/runtime/execution/orchestrationHealth.js +95 -0
- package/dist/core/runtime/execution/orchestrationHealth.js.map +1 -0
- package/dist/core/runtime/execution/pluginContext/defaultSessionOwner.d.ts +2 -0
- package/dist/core/runtime/execution/pluginContext/defaultSessionOwner.js +10 -0
- package/dist/core/runtime/execution/pluginContext/defaultSessionOwner.js.map +1 -0
- package/dist/core/runtime/execution/pluginContext/pluginCapabilities.d.ts +40 -0
- package/dist/core/runtime/execution/pluginContext/pluginCapabilities.js +73 -0
- package/dist/core/runtime/execution/pluginContext/pluginCapabilities.js.map +1 -0
- package/dist/core/runtime/execution/pluginContext/pluginContextFactory.d.ts +20 -0
- package/dist/core/runtime/execution/pluginContext/pluginContextFactory.js +18 -0
- package/dist/core/runtime/execution/pluginContext/pluginContextFactory.js.map +1 -0
- package/dist/core/runtime/execution/pluginContext/transportAuthor.d.ts +7 -0
- package/dist/core/runtime/execution/pluginContext/transportAuthor.js +15 -0
- package/dist/core/runtime/execution/pluginContext/transportAuthor.js.map +1 -0
- package/dist/core/runtime/execution/providerCoordination/providerCompactionCoordinator.d.ts +7 -0
- package/dist/core/runtime/execution/providerCoordination/providerCompactionCoordinator.js +25 -0
- package/dist/core/runtime/execution/providerCoordination/providerCompactionCoordinator.js.map +1 -0
- package/dist/core/runtime/execution/providerCoordination/providerPolicyTarget.d.ts +2 -0
- package/dist/core/runtime/execution/providerCoordination/providerPolicyTarget.js +5 -0
- package/dist/core/runtime/execution/providerCoordination/providerPolicyTarget.js.map +1 -0
- package/dist/core/runtime/execution/providerCoordination/providerRecoveryService.d.ts +7 -0
- package/dist/core/runtime/execution/providerCoordination/providerRecoveryService.js +6 -0
- package/dist/core/runtime/execution/providerCoordination/providerRecoveryService.js.map +1 -0
- package/dist/core/runtime/execution/providerCoordination/providerRequestAttributionService.d.ts +10 -0
- package/dist/core/runtime/execution/providerCoordination/providerRequestAttributionService.js +33 -0
- package/dist/core/runtime/execution/providerCoordination/providerRequestAttributionService.js.map +1 -0
- package/dist/core/runtime/execution/providerCoordination/providerSessionCoordinator.d.ts +5 -0
- package/dist/core/runtime/execution/providerCoordination/providerSessionCoordinator.js +9 -0
- package/dist/core/runtime/execution/providerCoordination/providerSessionCoordinator.js.map +1 -0
- package/dist/core/runtime/execution/providerCoordination/providerTurnCoordinator.d.ts +3 -0
- package/dist/core/runtime/execution/providerCoordination/providerTurnCoordinator.js +6 -0
- package/dist/core/runtime/execution/providerCoordination/providerTurnCoordinator.js.map +1 -0
- package/dist/core/runtime/execution/providerOrchestration/ports.d.ts +47 -0
- package/dist/core/runtime/execution/providerOrchestration/ports.js +2 -0
- package/dist/core/runtime/execution/providerOrchestration/ports.js.map +1 -0
- package/dist/core/runtime/execution/providerOrchestration/providerAttachmentResolver.d.ts +13 -0
- package/dist/core/runtime/execution/providerOrchestration/providerAttachmentResolver.js +57 -0
- package/dist/core/runtime/execution/providerOrchestration/providerAttachmentResolver.js.map +1 -0
- package/dist/core/runtime/execution/providerOrchestration/providerCompactionPolicy.d.ts +19 -0
- package/dist/core/runtime/execution/providerOrchestration/providerCompactionPolicy.js +129 -0
- package/dist/core/runtime/execution/providerOrchestration/providerCompactionPolicy.js.map +1 -0
- package/dist/core/runtime/execution/providerOrchestration/providerEventPipeline.d.ts +32 -0
- package/dist/core/runtime/execution/providerOrchestration/providerEventPipeline.js +67 -0
- package/dist/core/runtime/execution/providerOrchestration/providerEventPipeline.js.map +1 -0
- package/dist/core/runtime/execution/providerOrchestration/providerMissionEventProjector.d.ts +12 -0
- package/dist/core/runtime/execution/providerOrchestration/providerMissionEventProjector.js +71 -0
- package/dist/core/runtime/execution/providerOrchestration/providerMissionEventProjector.js.map +1 -0
- package/dist/core/runtime/execution/providerOrchestration/providerOrchestrator.d.ts +37 -0
- package/dist/core/runtime/execution/providerOrchestration/providerOrchestrator.js +53 -0
- package/dist/core/runtime/execution/providerOrchestration/providerOrchestrator.js.map +1 -0
- package/dist/core/runtime/execution/providerOrchestration/providerRequestProjector.d.ts +15 -0
- package/dist/core/runtime/execution/providerOrchestration/providerRequestProjector.js +93 -0
- package/dist/core/runtime/execution/providerOrchestration/providerRequestProjector.js.map +1 -0
- package/dist/core/runtime/execution/providerOrchestration/providerSessionOrchestrator.d.ts +37 -0
- package/dist/core/runtime/execution/providerOrchestration/providerSessionOrchestrator.js +104 -0
- package/dist/core/runtime/execution/providerOrchestration/providerSessionOrchestrator.js.map +1 -0
- package/dist/core/runtime/execution/providerOrchestration/providerTurnBroker.d.ts +62 -0
- package/dist/core/runtime/execution/providerOrchestration/providerTurnBroker.js +349 -0
- package/dist/core/runtime/execution/providerOrchestration/providerTurnBroker.js.map +1 -0
- package/dist/core/runtime/execution/providerProjectionTypes.d.ts +25 -0
- package/dist/core/runtime/execution/providerProjectionTypes.js +18 -0
- package/dist/core/runtime/execution/providerProjectionTypes.js.map +1 -0
- package/dist/core/runtime/execution/providerSessionDirectory.d.ts +12 -0
- package/dist/core/runtime/execution/providerSessionDirectory.js +94 -0
- package/dist/core/runtime/execution/providerSessionDirectory.js.map +1 -0
- package/dist/core/runtime/execution/runtimeDomain.d.ts +116 -0
- package/dist/core/runtime/execution/runtimeDomain.js +262 -0
- package/dist/core/runtime/execution/runtimeDomain.js.map +1 -0
- package/dist/core/runtime/execution/runtimeIngestion.d.ts +17 -0
- package/dist/core/runtime/execution/runtimeIngestion.js +254 -0
- package/dist/core/runtime/execution/runtimeIngestion.js.map +1 -0
- package/dist/core/runtime/execution/runtimeInteractionService.d.ts +66 -0
- package/dist/core/runtime/execution/runtimeInteractionService.js +230 -0
- package/dist/core/runtime/execution/runtimeInteractionService.js.map +1 -0
- package/dist/core/runtime/execution/runtimeOrchestrationRequestService.d.ts +64 -0
- package/dist/core/runtime/execution/runtimeOrchestrationRequestService.js +366 -0
- package/dist/core/runtime/execution/runtimeOrchestrationRequestService.js.map +1 -0
- package/dist/core/runtime/execution/runtimeOrchestrationRequests.d.ts +111 -0
- package/dist/core/runtime/execution/runtimeOrchestrationRequests.js +464 -0
- package/dist/core/runtime/execution/runtimeOrchestrationRequests.js.map +1 -0
- package/dist/core/runtime/execution/runtimeOrchestrationResult.d.ts +4 -0
- package/dist/core/runtime/execution/runtimeOrchestrationResult.js +7 -0
- package/dist/core/runtime/execution/runtimeOrchestrationResult.js.map +1 -0
- package/dist/core/runtime/execution/runtimePendingRequestService.d.ts +69 -0
- package/dist/core/runtime/execution/runtimePendingRequestService.js +360 -0
- package/dist/core/runtime/execution/runtimePendingRequestService.js.map +1 -0
- package/dist/core/runtime/execution/runtimePluginContextService.d.ts +100 -0
- package/dist/core/runtime/execution/runtimePluginContextService.js +576 -0
- package/dist/core/runtime/execution/runtimePluginContextService.js.map +1 -0
- package/dist/core/runtime/execution/runtimeReceiptBus.d.ts +17 -0
- package/dist/core/runtime/execution/runtimeReceiptBus.js +50 -0
- package/dist/core/runtime/execution/runtimeReceiptBus.js.map +1 -0
- package/dist/core/runtime/execution/runtimeWorkerQueues.d.ts +33 -0
- package/dist/core/runtime/execution/runtimeWorkerQueues.js +55 -0
- package/dist/core/runtime/execution/runtimeWorkerQueues.js.map +1 -0
- package/dist/core/runtime/graph/runtimePaths.d.ts +2 -0
- package/dist/core/runtime/graph/runtimePaths.js +22 -0
- package/dist/core/runtime/graph/runtimePaths.js.map +1 -0
- package/dist/core/runtime/hosting/managedSpaceMetadata.d.ts +7 -0
- package/dist/core/runtime/hosting/managedSpaceMetadata.js +14 -0
- package/dist/core/runtime/hosting/managedSpaceMetadata.js.map +1 -0
- package/dist/core/runtime/hosting/runtimeHostingService.d.ts +32 -0
- package/dist/core/runtime/hosting/runtimeHostingService.js +123 -0
- package/dist/core/runtime/hosting/runtimeHostingService.js.map +1 -0
- package/dist/core/runtime/hosting/runtimeLayout.d.ts +5 -0
- package/dist/core/runtime/hosting/runtimeLayout.js +133 -0
- package/dist/core/runtime/hosting/runtimeLayout.js.map +1 -0
- package/dist/core/runtime/hosting/runtimeManagementPort.d.ts +60 -0
- package/dist/core/runtime/hosting/runtimeManagementPort.js +28 -0
- package/dist/core/runtime/hosting/runtimeManagementPort.js.map +1 -0
- package/dist/core/runtime/hosting/runtimeTransportSurfaceService.d.ts +20 -0
- package/dist/core/runtime/hosting/runtimeTransportSurfaceService.js +82 -0
- package/dist/core/runtime/hosting/runtimeTransportSurfaceService.js.map +1 -0
- package/dist/core/runtime/hosting/systemEmbeds.d.ts +22 -0
- package/dist/core/runtime/hosting/systemEmbeds.js +25 -0
- package/dist/core/runtime/hosting/systemEmbeds.js.map +1 -0
- package/dist/core/runtime/lifecycle/managedChannelLifecycleService.d.ts +37 -0
- package/dist/core/runtime/lifecycle/managedChannelLifecycleService.js +256 -0
- package/dist/core/runtime/lifecycle/managedChannelLifecycleService.js.map +1 -0
- package/dist/core/runtime/lifecycle/runtimeLifecycleService.d.ts +43 -0
- package/dist/core/runtime/lifecycle/runtimeLifecycleService.js +322 -0
- package/dist/core/runtime/lifecycle/runtimeLifecycleService.js.map +1 -0
- package/dist/core/runtime/moorlineRuntime.d.ts +100 -0
- package/dist/core/runtime/moorlineRuntime.js +573 -0
- package/dist/core/runtime/moorlineRuntime.js.map +1 -0
- package/dist/core/runtime/moorlineRuntimeBuilder.d.ts +180 -0
- package/dist/core/runtime/moorlineRuntimeBuilder.js +681 -0
- package/dist/core/runtime/moorlineRuntimeBuilder.js.map +1 -0
- package/dist/core/runtime/runtimeAudit.d.ts +7 -0
- package/dist/core/runtime/runtimeAudit.js +32 -0
- package/dist/core/runtime/runtimeAudit.js.map +1 -0
- package/dist/core/runtime/runtimeBootstrapRegistry.d.ts +5 -0
- package/dist/core/runtime/runtimeBootstrapRegistry.js +15 -0
- package/dist/core/runtime/runtimeBootstrapRegistry.js.map +1 -0
- package/dist/core/runtime/runtimeStatus.d.ts +14 -0
- package/dist/core/runtime/runtimeStatus.js +16 -0
- package/dist/core/runtime/runtimeStatus.js.map +1 -0
- package/dist/core/runtime/supervision/managedSidecar.d.ts +71 -0
- package/dist/core/runtime/supervision/managedSidecar.js +13 -0
- package/dist/core/runtime/supervision/managedSidecar.js.map +1 -0
- package/dist/core/runtime/supervision/runtimeControl.d.ts +45 -0
- package/dist/core/runtime/supervision/runtimeControl.js +2 -0
- package/dist/core/runtime/supervision/runtimeControl.js.map +1 -0
- package/dist/core/runtime/supervision/runtimeControlService.d.ts +56 -0
- package/dist/core/runtime/supervision/runtimeControlService.js +315 -0
- package/dist/core/runtime/supervision/runtimeControlService.js.map +1 -0
- package/dist/core/runtime/supervision/runtimeSupervisor.d.ts +106 -0
- package/dist/core/runtime/supervision/runtimeSupervisor.js +425 -0
- package/dist/core/runtime/supervision/runtimeSupervisor.js.map +1 -0
- package/dist/core/runtime/supervision/sidecarLaunchDefinition.d.ts +3 -0
- package/dist/core/runtime/supervision/sidecarLaunchDefinition.js +24 -0
- package/dist/core/runtime/supervision/sidecarLaunchDefinition.js.map +1 -0
- package/dist/core/runtime/supervision/sidecarManager.d.ts +40 -0
- package/dist/core/runtime/supervision/sidecarManager.js +409 -0
- package/dist/core/runtime/supervision/sidecarManager.js.map +1 -0
- package/dist/core/shared/fs/atomicWrite.d.ts +6 -0
- package/dist/core/shared/fs/atomicWrite.js +48 -0
- package/dist/core/shared/fs/atomicWrite.js.map +1 -0
- package/dist/core/shared/fs/canonicalPathContainment.d.ts +8 -0
- package/dist/core/shared/fs/canonicalPathContainment.js +31 -0
- package/dist/core/shared/fs/canonicalPathContainment.js.map +1 -0
- package/dist/core/shared/fs/runtimeOwnedPath.d.ts +6 -0
- package/dist/core/shared/fs/runtimeOwnedPath.js +23 -0
- package/dist/core/shared/fs/runtimeOwnedPath.js.map +1 -0
- package/dist/core/shared/utils/childProcessEnv.d.ts +4 -0
- package/dist/core/shared/utils/childProcessEnv.js +66 -0
- package/dist/core/shared/utils/childProcessEnv.js.map +1 -0
- package/dist/core/shared/utils/commandRunner.d.ts +18 -0
- package/dist/core/shared/utils/commandRunner.js +51 -0
- package/dist/core/shared/utils/commandRunner.js.map +1 -0
- package/dist/core/shared/utils/payloadRedaction.d.ts +13 -0
- package/dist/core/shared/utils/payloadRedaction.js +91 -0
- package/dist/core/shared/utils/payloadRedaction.js.map +1 -0
- package/dist/core/shared/utils/remoteNetworkPolicy.d.ts +11 -0
- package/dist/core/shared/utils/remoteNetworkPolicy.js +137 -0
- package/dist/core/shared/utils/remoteNetworkPolicy.js.map +1 -0
- package/dist/core/shared/utils/runtimeMessageUtils.d.ts +27 -0
- package/dist/core/shared/utils/runtimeMessageUtils.js +383 -0
- package/dist/core/shared/utils/runtimeMessageUtils.js.map +1 -0
- package/dist/core/system/audit/auditLogger.d.ts +15 -0
- package/dist/core/system/audit/auditLogger.js +22 -0
- package/dist/core/system/audit/auditLogger.js.map +1 -0
- package/dist/core/system/backup/runtimeBackupService.d.ts +28 -0
- package/dist/core/system/backup/runtimeBackupService.js +284 -0
- package/dist/core/system/backup/runtimeBackupService.js.map +1 -0
- package/dist/core/system/config/configStore.d.ts +38 -0
- package/dist/core/system/config/configStore.js +672 -0
- package/dist/core/system/config/configStore.js.map +1 -0
- package/dist/core/system/policy/actorRulePolicy.d.ts +13 -0
- package/dist/core/system/policy/actorRulePolicy.js +87 -0
- package/dist/core/system/policy/actorRulePolicy.js.map +1 -0
- package/dist/core/system/policy/networkPolicy.d.ts +6 -0
- package/dist/core/system/policy/networkPolicy.js +71 -0
- package/dist/core/system/policy/networkPolicy.js.map +1 -0
- package/dist/core/system/policy/policyEngine.d.ts +22 -0
- package/dist/core/system/policy/policyEngine.js +41 -0
- package/dist/core/system/policy/policyEngine.js.map +1 -0
- package/dist/core/system/policy/policyProfile.d.ts +16 -0
- package/dist/core/system/policy/policyProfile.js +78 -0
- package/dist/core/system/policy/policyProfile.js.map +1 -0
- package/dist/core/system/policy/runtimeActionGuard.d.ts +24 -0
- package/dist/core/system/policy/runtimeActionGuard.js +64 -0
- package/dist/core/system/policy/runtimeActionGuard.js.map +1 -0
- package/dist/core/system/projection/managementReadModel/auditEvents.d.ts +9 -0
- package/dist/core/system/projection/managementReadModel/auditEvents.js +61 -0
- package/dist/core/system/projection/managementReadModel/auditEvents.js.map +1 -0
- package/dist/core/system/projection/managementReadModel/deps.d.ts +35 -0
- package/dist/core/system/projection/managementReadModel/deps.js +2 -0
- package/dist/core/system/projection/managementReadModel/deps.js.map +1 -0
- package/dist/core/system/projection/managementReadModel/objects/serviceObjects.d.ts +3 -0
- package/dist/core/system/projection/managementReadModel/objects/serviceObjects.js +129 -0
- package/dist/core/system/projection/managementReadModel/objects/serviceObjects.js.map +1 -0
- package/dist/core/system/projection/managementReadModel/pluginDiskRecords.d.ts +10 -0
- package/dist/core/system/projection/managementReadModel/pluginDiskRecords.js +55 -0
- package/dist/core/system/projection/managementReadModel/pluginDiskRecords.js.map +1 -0
- package/dist/core/system/projection/managementReadModel/providerAlignment.d.ts +7 -0
- package/dist/core/system/projection/managementReadModel/providerAlignment.js +48 -0
- package/dist/core/system/projection/managementReadModel/providerAlignment.js.map +1 -0
- package/dist/core/system/projection/managementReadModel/text.d.ts +1 -0
- package/dist/core/system/projection/managementReadModel/text.js +8 -0
- package/dist/core/system/projection/managementReadModel/text.js.map +1 -0
- package/dist/core/system/projection/managementReadModelService.d.ts +18 -0
- package/dist/core/system/projection/managementReadModelService.js +768 -0
- package/dist/core/system/projection/managementReadModelService.js.map +1 -0
- package/dist/core/system/projection/pendingRequestProjectionStore.d.ts +12 -0
- package/dist/core/system/projection/pendingRequestProjectionStore.js +113 -0
- package/dist/core/system/projection/pendingRequestProjectionStore.js.map +1 -0
- package/dist/core/system/projection/pendingRequestQuestions.d.ts +2 -0
- package/dist/core/system/projection/pendingRequestQuestions.js +51 -0
- package/dist/core/system/projection/pendingRequestQuestions.js.map +1 -0
- package/dist/core/system/projection/projectionStateStore.d.ts +17 -0
- package/dist/core/system/projection/projectionStateStore.js +60 -0
- package/dist/core/system/projection/projectionStateStore.js.map +1 -0
- package/dist/core/system/projection/runtimeActivityStore.d.ts +24 -0
- package/dist/core/system/projection/runtimeActivityStore.js +150 -0
- package/dist/core/system/projection/runtimeActivityStore.js.map +1 -0
- package/dist/core/system/projection/runtimeProjectionService.d.ts +41 -0
- package/dist/core/system/projection/runtimeProjectionService.js +209 -0
- package/dist/core/system/projection/runtimeProjectionService.js.map +1 -0
- package/dist/core/system/projection/runtimeReceiptStore.d.ts +11 -0
- package/dist/core/system/projection/runtimeReceiptStore.js +77 -0
- package/dist/core/system/projection/runtimeReceiptStore.js.map +1 -0
- package/dist/core/system/projection/runtimeReconciler.d.ts +25 -0
- package/dist/core/system/projection/runtimeReconciler.js +83 -0
- package/dist/core/system/projection/runtimeReconciler.js.map +1 -0
- package/dist/core/system/projection/runtimeSnapshotQuery.d.ts +46 -0
- package/dist/core/system/projection/runtimeSnapshotQuery.js +135 -0
- package/dist/core/system/projection/runtimeSnapshotQuery.js.map +1 -0
- package/dist/core/system/release/releaseArtifacts.d.ts +7 -0
- package/dist/core/system/release/releaseArtifacts.js +88 -0
- package/dist/core/system/release/releaseArtifacts.js.map +1 -0
- package/dist/core/system/release/runtimePackageLoadReport.d.ts +10 -0
- package/dist/core/system/release/runtimePackageLoadReport.js +31 -0
- package/dist/core/system/release/runtimePackageLoadReport.js.map +1 -0
- package/dist/core/system/state/canonicalEventLogStore.d.ts +16 -0
- package/dist/core/system/state/canonicalEventLogStore.js +156 -0
- package/dist/core/system/state/canonicalEventLogStore.js.map +1 -0
- package/dist/core/system/state/migrationRunner.d.ts +5 -0
- package/dist/core/system/state/migrationRunner.js +58 -0
- package/dist/core/system/state/migrationRunner.js.map +1 -0
- package/dist/core/system/state/safeJson.d.ts +8 -0
- package/dist/core/system/state/safeJson.js +36 -0
- package/dist/core/system/state/safeJson.js.map +1 -0
- package/dist/core/system/state/sqlite/connection.d.ts +2 -0
- package/dist/core/system/state/sqlite/connection.js +8 -0
- package/dist/core/system/state/sqlite/connection.js.map +1 -0
- package/dist/core/system/state/sqlite/domainEventLogRepository.d.ts +10 -0
- package/dist/core/system/state/sqlite/domainEventLogRepository.js +69 -0
- package/dist/core/system/state/sqlite/domainEventLogRepository.js.map +1 -0
- package/dist/core/system/state/sqlite/eventIntegrity.d.ts +6 -0
- package/dist/core/system/state/sqlite/eventIntegrity.js +7 -0
- package/dist/core/system/state/sqlite/eventIntegrity.js.map +1 -0
- package/dist/core/system/state/sqlite/managedSidecarRepository.d.ts +10 -0
- package/dist/core/system/state/sqlite/managedSidecarRepository.js +62 -0
- package/dist/core/system/state/sqlite/managedSidecarRepository.js.map +1 -0
- package/dist/core/system/state/sqlite/missionRepository.d.ts +24 -0
- package/dist/core/system/state/sqlite/missionRepository.js +252 -0
- package/dist/core/system/state/sqlite/missionRepository.js.map +1 -0
- package/dist/core/system/state/sqlite/orchestrationRepository.d.ts +20 -0
- package/dist/core/system/state/sqlite/orchestrationRepository.js +158 -0
- package/dist/core/system/state/sqlite/orchestrationRepository.js.map +1 -0
- package/dist/core/system/state/sqlite/pendingRequestRepository.d.ts +13 -0
- package/dist/core/system/state/sqlite/pendingRequestRepository.js +76 -0
- package/dist/core/system/state/sqlite/pendingRequestRepository.js.map +1 -0
- package/dist/core/system/state/sqlite/providerBindingRepository.d.ts +10 -0
- package/dist/core/system/state/sqlite/providerBindingRepository.js +58 -0
- package/dist/core/system/state/sqlite/providerBindingRepository.js.map +1 -0
- package/dist/core/system/state/sqlite/providerEventLogRepository.d.ts +10 -0
- package/dist/core/system/state/sqlite/providerEventLogRepository.js +77 -0
- package/dist/core/system/state/sqlite/providerEventLogRepository.js.map +1 -0
- package/dist/core/system/state/sqlite/rowMappers.d.ts +2 -0
- package/dist/core/system/state/sqlite/rowMappers.js +7 -0
- package/dist/core/system/state/sqlite/rowMappers.js.map +1 -0
- package/dist/core/system/state/sqlite/runtimeHistoryPruningRepository.d.ts +23 -0
- package/dist/core/system/state/sqlite/runtimeHistoryPruningRepository.js +82 -0
- package/dist/core/system/state/sqlite/runtimeHistoryPruningRepository.js.map +1 -0
- package/dist/core/system/state/sqlite/runtimeReceiptRepository.d.ts +9 -0
- package/dist/core/system/state/sqlite/runtimeReceiptRepository.js +47 -0
- package/dist/core/system/state/sqlite/runtimeReceiptRepository.js.map +1 -0
- package/dist/core/system/state/sqlite/sessionMetadataRepository.d.ts +7 -0
- package/dist/core/system/state/sqlite/sessionMetadataRepository.js +25 -0
- package/dist/core/system/state/sqlite/sessionMetadataRepository.js.map +1 -0
- package/dist/core/system/state/sqlite/sessionRepository.d.ts +12 -0
- package/dist/core/system/state/sqlite/sessionRepository.js +72 -0
- package/dist/core/system/state/sqlite/sessionRepository.js.map +1 -0
- package/dist/core/system/state/sqlite/types.d.ts +140 -0
- package/dist/core/system/state/sqlite/types.js +113 -0
- package/dist/core/system/state/sqlite/types.js.map +1 -0
- package/dist/core/system/state/sqliteSessionStore.d.ts +86 -0
- package/dist/core/system/state/sqliteSessionStore.js +210 -0
- package/dist/core/system/state/sqliteSessionStore.js.map +1 -0
- package/dist/core/system/state/sqliteSupport.d.ts +4 -0
- package/dist/core/system/state/sqliteSupport.js +32 -0
- package/dist/core/system/state/sqliteSupport.js.map +1 -0
- package/dist/core/system/vcs/gitCheckpointService.d.ts +11 -0
- package/dist/core/system/vcs/gitCheckpointService.js +32 -0
- package/dist/core/system/vcs/gitCheckpointService.js.map +1 -0
- package/dist/core/system/vcs/gitCommitParser.d.ts +3 -0
- package/dist/core/system/vcs/gitCommitParser.js +55 -0
- package/dist/core/system/vcs/gitCommitParser.js.map +1 -0
- package/dist/core/system/vcs/gitDiffFormatter.d.ts +1 -0
- package/dist/core/system/vcs/gitDiffFormatter.js +4 -0
- package/dist/core/system/vcs/gitDiffFormatter.js.map +1 -0
- package/dist/core/system/vcs/gitHistoryService.d.ts +46 -0
- package/dist/core/system/vcs/gitHistoryService.js +277 -0
- package/dist/core/system/vcs/gitHistoryService.js.map +1 -0
- package/dist/core/system/vcs/gitIgnoreTemplate.d.ts +1 -0
- package/dist/core/system/vcs/gitIgnoreTemplate.js +12 -0
- package/dist/core/system/vcs/gitIgnoreTemplate.js.map +1 -0
- package/dist/core/system/vcs/gitRepoStore.d.ts +12 -0
- package/dist/core/system/vcs/gitRepoStore.js +46 -0
- package/dist/core/system/vcs/gitRepoStore.js.map +1 -0
- package/dist/core/system/vcs/gitTrackedPaths.d.ts +6 -0
- package/dist/core/system/vcs/gitTrackedPaths.js +80 -0
- package/dist/core/system/vcs/gitTrackedPaths.js.map +1 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.js +6 -0
- package/dist/index.js.map +1 -0
- package/dist/types/app.d.ts +444 -0
- package/dist/types/app.js +2 -0
- package/dist/types/app.js.map +1 -0
- package/dist/types/config.d.ts +188 -0
- package/dist/types/config.js +422 -0
- package/dist/types/config.js.map +1 -0
- package/dist/types/distro.d.ts +1 -0
- package/dist/types/distro.js +2 -0
- package/dist/types/distro.js.map +1 -0
- package/dist/types/history.d.ts +43 -0
- package/dist/types/history.js +2 -0
- package/dist/types/history.js.map +1 -0
- package/dist/types/package.d.ts +61 -0
- package/dist/types/package.js +2 -0
- package/dist/types/package.js.map +1 -0
- package/dist/types/plugin.d.ts +1 -0
- package/dist/types/plugin.js +2 -0
- package/dist/types/plugin.js.map +1 -0
- package/dist/types/provider.d.ts +2 -0
- package/dist/types/provider.js +2 -0
- package/dist/types/provider.js.map +1 -0
- package/dist/types/release.d.ts +24 -0
- package/dist/types/release.js +2 -0
- package/dist/types/release.js.map +1 -0
- package/dist/types/runtime.d.ts +2 -0
- package/dist/types/runtime.js +2 -0
- package/dist/types/runtime.js.map +1 -0
- package/dist/types/skill.d.ts +1 -0
- package/dist/types/skill.js +2 -0
- package/dist/types/skill.js.map +1 -0
- package/dist/types/transport.d.ts +2 -0
- package/dist/types/transport.js +2 -0
- package/dist/types/transport.js.map +1 -0
- package/package.json +62 -0
- package/resources/migrations/001_sessions.sql +59 -0
- package/resources/migrations/002_pending_request_metadata.sql +2 -0
- package/resources/migrations/003_provider_projections.sql +38 -0
- package/resources/migrations/004_runtime_projection_state.sql +22 -0
- package/resources/migrations/005_runtime_robustness.sql +3 -0
- package/resources/migrations/006_provider_autostart.sql +1 -0
- package/resources/migrations/007_missions.sql +41 -0
- package/resources/migrations/008_mission_schedule_anchor.sql +5 -0
- package/resources/migrations/009_session_orchestration.sql +26 -0
- package/resources/migrations/010_mission_archival.sql +1 -0
- package/resources/migrations/011_managed_sidecars.sql +29 -0
- package/resources/migrations/012_scope_space_terminology.sql +19 -0
- package/resources/migrations/013_orchestration_dedupe.sql +5 -0
- package/resources/migrations/014_orchestration_execution_claims.sql +13 -0
- package/resources/migrations/015_mission_schedule_meta.sql +9 -0
- package/resources/migrations/016_mission_hook_bindings.sql +16 -0
- package/resources/migrations/017_domain_event_provenance.sql +1 -0
- package/resources/migrations/018_provider_event_processing.sql +8 -0
- package/resources/official-catalog.json +444 -0
- package/resources/policies/default-secure.json +160 -0
|
@@ -0,0 +1,230 @@
|
|
|
1
|
+
import { buildDraftMissionSetupPrompt, parseDraftMissionSetupMessage } from '../../domain/missions/missionDraftSetup.js';
|
|
2
|
+
import { PendingRequestActionError } from './runtimePendingRequestService.js';
|
|
3
|
+
const ARCHIVED_SESSION_MESSAGE = 'This session is archived. Create a new session if you want Moorline to continue work.';
|
|
4
|
+
const DRAINING_ACTION_DENIED_MESSAGE = 'Moorline is currently draining work. Only status, control, and pending-request commands are allowed.';
|
|
5
|
+
const BUILT_IN_ACTION_POLICIES = {
|
|
6
|
+
'runtime.pending_request.respond': {
|
|
7
|
+
allowedWhileDraining: true,
|
|
8
|
+
bypassQueue: true
|
|
9
|
+
}
|
|
10
|
+
};
|
|
11
|
+
function stringInput(input, key) {
|
|
12
|
+
const value = input[key];
|
|
13
|
+
return typeof value === 'string' ? value.trim() : '';
|
|
14
|
+
}
|
|
15
|
+
function hasNativeReply(payload) {
|
|
16
|
+
return !!payload && typeof payload === 'object' && typeof payload.reply === 'function';
|
|
17
|
+
}
|
|
18
|
+
export class RuntimeInteractionService {
|
|
19
|
+
deps;
|
|
20
|
+
constructor(deps) {
|
|
21
|
+
this.deps = deps;
|
|
22
|
+
}
|
|
23
|
+
async handleTransportEvent(event) {
|
|
24
|
+
if (event.scopeId !== this.deps.config.transport.scopeId || !this.deps.getNamespaceReady()) {
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
if (event.type === 'message.received') {
|
|
28
|
+
await this.handleMessage(event);
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
if (event.type === 'action.invoked') {
|
|
32
|
+
if (this.shouldBypassActionQueue(event)) {
|
|
33
|
+
await this.handleAction(event);
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
const queueKey = event.spaceId ?? `actor:${event.actor.actorId}`;
|
|
37
|
+
await this.deps.queue(queueKey, async () => {
|
|
38
|
+
await this.handleAction(event);
|
|
39
|
+
});
|
|
40
|
+
return;
|
|
41
|
+
}
|
|
42
|
+
await this.deps.getPluginHost().handleTransportEvent(event, (pluginId) => this.deps.createPluginContext(`plugin:${pluginId}`));
|
|
43
|
+
}
|
|
44
|
+
shouldBypassActionQueue(event) {
|
|
45
|
+
return this.actionPolicy(event.actionId)?.bypassQueue === true;
|
|
46
|
+
}
|
|
47
|
+
async handleMessage(event) {
|
|
48
|
+
await this.deps.queue(event.spaceId, async () => {
|
|
49
|
+
if (!this.deps.getAcceptingNewWork()) {
|
|
50
|
+
await this.deps.postTransportMessage('runtime:status', event.spaceId, {
|
|
51
|
+
text: 'Moorline is currently draining work and is not accepting new messages.'
|
|
52
|
+
});
|
|
53
|
+
return;
|
|
54
|
+
}
|
|
55
|
+
const session = this.deps.sessionRegistry.getBySpaceId(event.spaceId);
|
|
56
|
+
if (session) {
|
|
57
|
+
if (session.lifecycleStatus === 'archived') {
|
|
58
|
+
await this.deps.postTransportMessage('runtime:archived-session', event.spaceId, {
|
|
59
|
+
text: ARCHIVED_SESSION_MESSAGE
|
|
60
|
+
});
|
|
61
|
+
this.deps.appendAuditEvent('session.archived.message_ignored', {
|
|
62
|
+
sessionId: session.sessionId,
|
|
63
|
+
spaceId: session.spaceId,
|
|
64
|
+
actorId: event.actor.actorId
|
|
65
|
+
});
|
|
66
|
+
return;
|
|
67
|
+
}
|
|
68
|
+
this.deps.sessionLifecycle.recordActivity(session.threadId, this.deps.now());
|
|
69
|
+
}
|
|
70
|
+
const mission = this.deps.missionRegistry.getBySpaceId(event.spaceId);
|
|
71
|
+
if (mission) {
|
|
72
|
+
await this.handleMissionMessage(event, mission);
|
|
73
|
+
return;
|
|
74
|
+
}
|
|
75
|
+
const result = await this.deps.getPluginHost().handleTransportEvent(event, (pluginId) => this.deps.createPluginContext(`plugin:${pluginId}`));
|
|
76
|
+
if (result.reply) {
|
|
77
|
+
await this.deps.postTransportMessage('runtime:plugin/action', event.spaceId, result.reply);
|
|
78
|
+
}
|
|
79
|
+
if (result.audit) {
|
|
80
|
+
this.deps.appendAuditEvent(result.audit.event, result.audit.payload ?? {});
|
|
81
|
+
}
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
async handleAction(event) {
|
|
85
|
+
if (!this.deps.getAcceptingNewWork() && !this.isAllowedWhileDraining(event.actionId)) {
|
|
86
|
+
await this.replyToAction(event, DRAINING_ACTION_DENIED_MESSAGE);
|
|
87
|
+
return;
|
|
88
|
+
}
|
|
89
|
+
if (event.actionId === 'runtime.pending_request.respond') {
|
|
90
|
+
if (await this.handlePendingRequestAction(event)) {
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
const result = await this.deps.getPluginHost().handleTransportEvent(event, (pluginId) => this.deps.createPluginContext(`plugin:${pluginId}`));
|
|
95
|
+
if (result.reply && event.spaceId) {
|
|
96
|
+
await this.deps.postTransportMessage('runtime:plugin/action', event.spaceId, result.reply);
|
|
97
|
+
}
|
|
98
|
+
if (result.audit) {
|
|
99
|
+
this.deps.appendAuditEvent(result.audit.event, result.audit.payload ?? {});
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
isAllowedWhileDraining(actionId) {
|
|
103
|
+
return this.actionPolicy(actionId)?.allowedWhileDraining === true;
|
|
104
|
+
}
|
|
105
|
+
actionPolicy(actionId) {
|
|
106
|
+
const builtIn = BUILT_IN_ACTION_POLICIES[actionId];
|
|
107
|
+
if (builtIn) {
|
|
108
|
+
return builtIn;
|
|
109
|
+
}
|
|
110
|
+
const action = this.deps.getPluginHost().listActions((pluginId) => this.deps.createPluginContext(`plugin:${pluginId}`)).find((entry) => entry.id === actionId);
|
|
111
|
+
return action?.policy ?? null;
|
|
112
|
+
}
|
|
113
|
+
async replyToAction(event, message) {
|
|
114
|
+
if (hasNativeReply(event.native?.payload)) {
|
|
115
|
+
await event.native.payload.reply({
|
|
116
|
+
content: message,
|
|
117
|
+
ephemeral: true
|
|
118
|
+
});
|
|
119
|
+
return;
|
|
120
|
+
}
|
|
121
|
+
if (event.spaceId) {
|
|
122
|
+
await this.deps.postTransportMessage('runtime:status', event.spaceId, {
|
|
123
|
+
text: message
|
|
124
|
+
});
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
async handlePendingRequestAction(event) {
|
|
128
|
+
const requestId = stringInput(event.input, 'requestId');
|
|
129
|
+
const decision = stringInput(event.input, 'decision');
|
|
130
|
+
if (!requestId || (decision !== 'accept' && decision !== 'decline' && decision !== 'cancel')) {
|
|
131
|
+
return false;
|
|
132
|
+
}
|
|
133
|
+
try {
|
|
134
|
+
await this.deps.resolvePendingRequest({
|
|
135
|
+
actorId: 'runtime:pending-request-action',
|
|
136
|
+
requestId,
|
|
137
|
+
decision,
|
|
138
|
+
deniedTitle: 'Provider approval response blocked',
|
|
139
|
+
metadata: { source: 'action', actionId: event.actionId },
|
|
140
|
+
requestActor: event.actor
|
|
141
|
+
});
|
|
142
|
+
}
|
|
143
|
+
catch (error) {
|
|
144
|
+
if (error instanceof PendingRequestActionError) {
|
|
145
|
+
await this.replyToAction(event, error.message);
|
|
146
|
+
return true;
|
|
147
|
+
}
|
|
148
|
+
throw error;
|
|
149
|
+
}
|
|
150
|
+
const responseText = decision === 'accept' ? `Approved request ${requestId}.` : decision === 'decline' ? `Declined request ${requestId}.` : `Cancelled request ${requestId}.`;
|
|
151
|
+
await this.replyToAction(event, responseText);
|
|
152
|
+
return true;
|
|
153
|
+
}
|
|
154
|
+
async handleMissionMessage(event, mission) {
|
|
155
|
+
await this.deps.queue(`mission:${mission.missionId}`, async () => {
|
|
156
|
+
const currentMission = this.deps.missionRegistry.getById(mission.missionId);
|
|
157
|
+
if (currentMission?.lifecycleStatus === 'draft') {
|
|
158
|
+
await this.handleDraftMissionMessage(event, currentMission);
|
|
159
|
+
return;
|
|
160
|
+
}
|
|
161
|
+
if (!currentMission ||
|
|
162
|
+
currentMission.archivedAt ||
|
|
163
|
+
currentMission.lifecycleStatus === 'stopped' ||
|
|
164
|
+
currentMission.lifecycleStatus === 'completed') {
|
|
165
|
+
await this.deps.postTransportMessage('runtime:mission/message', event.spaceId, {
|
|
166
|
+
text: `Mission ${mission.missionId} is not accepting new messages because it is ${currentMission?.archivedAt ? 'archived' : currentMission?.lifecycleStatus ?? 'missing'}.`
|
|
167
|
+
});
|
|
168
|
+
return;
|
|
169
|
+
}
|
|
170
|
+
const reply = await this.deps.createMissionReply(event, currentMission);
|
|
171
|
+
await this.deps.postTransportMessage('runtime:mission/message', event.spaceId, reply);
|
|
172
|
+
this.deps.appendAuditEvent('mission.replied', {
|
|
173
|
+
missionId: currentMission.missionId,
|
|
174
|
+
spaceId: currentMission.spaceId,
|
|
175
|
+
actorId: event.actor.actorId
|
|
176
|
+
});
|
|
177
|
+
});
|
|
178
|
+
}
|
|
179
|
+
async handleDraftMissionMessage(event, mission) {
|
|
180
|
+
const draftPrompt = buildDraftMissionSetupPrompt({
|
|
181
|
+
title: mission.title,
|
|
182
|
+
missionId: mission.missionId
|
|
183
|
+
});
|
|
184
|
+
let setup;
|
|
185
|
+
try {
|
|
186
|
+
setup = parseDraftMissionSetupMessage(event.message.text);
|
|
187
|
+
}
|
|
188
|
+
catch (error) {
|
|
189
|
+
await this.deps.postTransportMessage('runtime:mission/setup', event.spaceId, {
|
|
190
|
+
text: `Could not parse draft mission setup: ${error instanceof Error ? error.message : String(error)}\n\n${draftPrompt}`
|
|
191
|
+
});
|
|
192
|
+
return;
|
|
193
|
+
}
|
|
194
|
+
if (!setup) {
|
|
195
|
+
await this.deps.postTransportMessage('runtime:mission/setup', event.spaceId, {
|
|
196
|
+
text: draftPrompt
|
|
197
|
+
});
|
|
198
|
+
return;
|
|
199
|
+
}
|
|
200
|
+
let configured;
|
|
201
|
+
try {
|
|
202
|
+
configured = await this.deps.configureDraftMission({
|
|
203
|
+
actorId: event.actor.actorId,
|
|
204
|
+
spaceId: event.spaceId,
|
|
205
|
+
missionId: mission.missionId,
|
|
206
|
+
goal: setup.goal,
|
|
207
|
+
schedule: setup.schedule,
|
|
208
|
+
...(setup.startTime ? { startTime: setup.startTime } : {}),
|
|
209
|
+
...(setup.runtimeMode ? { runtimeMode: setup.runtimeMode } : {})
|
|
210
|
+
});
|
|
211
|
+
}
|
|
212
|
+
catch (error) {
|
|
213
|
+
await this.deps.postTransportMessage('runtime:mission/setup', event.spaceId, {
|
|
214
|
+
text: `Could not configure draft mission: ${error instanceof Error ? error.message : String(error)}\n\n${draftPrompt}`
|
|
215
|
+
});
|
|
216
|
+
return;
|
|
217
|
+
}
|
|
218
|
+
await this.deps.postTransportMessage('runtime:mission/setup', event.spaceId, {
|
|
219
|
+
text: `Configured mission ${configured.missionId}. ` +
|
|
220
|
+
`It will run on ${configured.scheduleText}` +
|
|
221
|
+
`${configured.nextRunAt ? ` starting at ${configured.nextRunAt}` : ''}.`
|
|
222
|
+
});
|
|
223
|
+
this.deps.appendAuditEvent('mission.configured_from_message', {
|
|
224
|
+
missionId: configured.missionId,
|
|
225
|
+
spaceId: configured.spaceId,
|
|
226
|
+
actorId: event.actor.actorId
|
|
227
|
+
});
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
//# sourceMappingURL=runtimeInteractionService.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runtimeInteractionService.js","sourceRoot":"","sources":["../../../../../../../src/core/runtime/execution/runtimeInteractionService.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import type { RuntimePluginContext } from '../../../types/plugin.js';
|
|
2
|
+
import type { RuntimeAttachmentPayload, RuntimeMessagePayload } from '../../../types/transport.js';
|
|
3
|
+
import type { RuntimeOrchestrationRequestRow, SqliteSessionStore } from '../../system/state/sqliteSessionStore.js';
|
|
4
|
+
import type { RuntimeWorkManagementService } from '../../domain/sessions/runtimeWorkManagementService.js';
|
|
5
|
+
export declare const ORCHESTRATION_STUCK_RUNNING_THRESHOLD_MS: number;
|
|
6
|
+
interface ForcedDrainSignal {
|
|
7
|
+
timeoutMs: number;
|
|
8
|
+
inFlightRequestIds: string[];
|
|
9
|
+
oldestInFlightAgeMs: number;
|
|
10
|
+
at: string;
|
|
11
|
+
}
|
|
12
|
+
export interface RuntimeOrchestrationQueueHealth {
|
|
13
|
+
openRequests: number;
|
|
14
|
+
runningRequests: number;
|
|
15
|
+
pendingRequests: number;
|
|
16
|
+
staleRunningRequests: number;
|
|
17
|
+
oldestOpenAgeMs: number;
|
|
18
|
+
oldestRunningAgeMs: number;
|
|
19
|
+
inFlightRequests: number;
|
|
20
|
+
staleRunningThresholdMs: number;
|
|
21
|
+
}
|
|
22
|
+
export declare function summarizeOrchestrationQueueHealth(requests: RuntimeOrchestrationRequestRow[], input?: {
|
|
23
|
+
nowMs?: number;
|
|
24
|
+
staleRunningThresholdMs?: number;
|
|
25
|
+
inFlightRequests?: number;
|
|
26
|
+
}): RuntimeOrchestrationQueueHealth;
|
|
27
|
+
interface RuntimeOrchestrationRequestServiceDeps {
|
|
28
|
+
store: SqliteSessionStore;
|
|
29
|
+
workManagement: RuntimeWorkManagementService;
|
|
30
|
+
createPluginContext(actorId: string): RuntimePluginContext;
|
|
31
|
+
now(): string;
|
|
32
|
+
validateLocalFiles(files: RuntimeAttachmentPayload[] | undefined, input: {
|
|
33
|
+
requestedByThreadId: string | null;
|
|
34
|
+
}): void;
|
|
35
|
+
postTransportMessage(actor: string, spaceId: string, payload: RuntimeMessagePayload): Promise<{
|
|
36
|
+
id: string;
|
|
37
|
+
}>;
|
|
38
|
+
nowMs?(): number;
|
|
39
|
+
drainWaitTimeoutMs?: number;
|
|
40
|
+
onForcedDrain?(signal: ForcedDrainSignal): void;
|
|
41
|
+
}
|
|
42
|
+
export declare class RuntimeOrchestrationRequestService {
|
|
43
|
+
private readonly deps;
|
|
44
|
+
private poller;
|
|
45
|
+
private draining;
|
|
46
|
+
private readonly inFlight;
|
|
47
|
+
private readonly inFlightStartedAt;
|
|
48
|
+
private readonly executionOwner;
|
|
49
|
+
private abandonedRunningRecovered;
|
|
50
|
+
constructor(deps: RuntimeOrchestrationRequestServiceDeps);
|
|
51
|
+
start(): void;
|
|
52
|
+
stop(): void;
|
|
53
|
+
drain(waitForCompletion?: boolean): Promise<void>;
|
|
54
|
+
getQueueHealth(input?: {
|
|
55
|
+
staleRunningThresholdMs?: number;
|
|
56
|
+
}): RuntimeOrchestrationQueueHealth;
|
|
57
|
+
private process;
|
|
58
|
+
private executeRequest;
|
|
59
|
+
private waitForInFlight;
|
|
60
|
+
private recoverAbandonedRunningRequests;
|
|
61
|
+
private nowMs;
|
|
62
|
+
private signalForcedDrain;
|
|
63
|
+
}
|
|
64
|
+
export {};
|
|
@@ -0,0 +1,366 @@
|
|
|
1
|
+
import { randomUUID } from 'node:crypto';
|
|
2
|
+
import { decodeOrchestrationPayload } from './runtimeOrchestrationRequests.js';
|
|
3
|
+
const ORCHESTRATION_POLL_MS = 250;
|
|
4
|
+
export const ORCHESTRATION_STUCK_RUNNING_THRESHOLD_MS = 5 * 60_000;
|
|
5
|
+
const ORCHESTRATION_DRAIN_WAIT_TIMEOUT_MS = 30_000;
|
|
6
|
+
const ORCHESTRATION_REPLAY_SAFETY_BLOCK_ERROR = '[ORCH_REPLAY_SAFETY_BLOCK] Found an abandoned running orchestration request after restart. ' +
|
|
7
|
+
'The request was marked failed to avoid replaying non-idempotent side effects.';
|
|
8
|
+
const CLI_RUNTIME_CONTROL_REQUESTED_BY = {
|
|
9
|
+
actorId: 'cli:runtime-control',
|
|
10
|
+
accessGroupIds: [],
|
|
11
|
+
isSurfaceAdmin: false
|
|
12
|
+
};
|
|
13
|
+
const CLI_RUNTIME_CONTROL_REASON = 'Moorline CLI runtime control request';
|
|
14
|
+
function ageMs(nowMs, iso) {
|
|
15
|
+
const parsed = Date.parse(iso);
|
|
16
|
+
if (!Number.isFinite(parsed)) {
|
|
17
|
+
return 0;
|
|
18
|
+
}
|
|
19
|
+
return Math.max(0, nowMs - parsed);
|
|
20
|
+
}
|
|
21
|
+
export function summarizeOrchestrationQueueHealth(requests, input = {}) {
|
|
22
|
+
const nowMs = input.nowMs ?? Date.now();
|
|
23
|
+
const staleRunningThresholdMs = input.staleRunningThresholdMs ?? ORCHESTRATION_STUCK_RUNNING_THRESHOLD_MS;
|
|
24
|
+
let oldestOpenAgeMs = 0;
|
|
25
|
+
let oldestRunningAgeMs = 0;
|
|
26
|
+
let runningRequests = 0;
|
|
27
|
+
let pendingRequests = 0;
|
|
28
|
+
let staleRunningRequests = 0;
|
|
29
|
+
for (const request of requests) {
|
|
30
|
+
const age = ageMs(nowMs, request.updatedAt);
|
|
31
|
+
oldestOpenAgeMs = Math.max(oldestOpenAgeMs, age);
|
|
32
|
+
if (request.status === 'running') {
|
|
33
|
+
runningRequests += 1;
|
|
34
|
+
oldestRunningAgeMs = Math.max(oldestRunningAgeMs, age);
|
|
35
|
+
if (age >= staleRunningThresholdMs) {
|
|
36
|
+
staleRunningRequests += 1;
|
|
37
|
+
}
|
|
38
|
+
continue;
|
|
39
|
+
}
|
|
40
|
+
if (request.status === 'pending') {
|
|
41
|
+
pendingRequests += 1;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
return {
|
|
45
|
+
openRequests: requests.length,
|
|
46
|
+
runningRequests,
|
|
47
|
+
pendingRequests,
|
|
48
|
+
staleRunningRequests,
|
|
49
|
+
oldestOpenAgeMs,
|
|
50
|
+
oldestRunningAgeMs,
|
|
51
|
+
inFlightRequests: input.inFlightRequests ?? 0,
|
|
52
|
+
staleRunningThresholdMs
|
|
53
|
+
};
|
|
54
|
+
}
|
|
55
|
+
export class RuntimeOrchestrationRequestService {
|
|
56
|
+
deps;
|
|
57
|
+
poller = null;
|
|
58
|
+
draining = false;
|
|
59
|
+
inFlight = new Map();
|
|
60
|
+
inFlightStartedAt = new Map();
|
|
61
|
+
executionOwner = randomUUID();
|
|
62
|
+
abandonedRunningRecovered = false;
|
|
63
|
+
constructor(deps) {
|
|
64
|
+
this.deps = deps;
|
|
65
|
+
}
|
|
66
|
+
start() {
|
|
67
|
+
this.stop();
|
|
68
|
+
this.poller = setInterval(() => {
|
|
69
|
+
void this.drain(false);
|
|
70
|
+
}, ORCHESTRATION_POLL_MS);
|
|
71
|
+
}
|
|
72
|
+
stop() {
|
|
73
|
+
if (this.poller) {
|
|
74
|
+
clearInterval(this.poller);
|
|
75
|
+
this.poller = null;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
async drain(waitForCompletion = true) {
|
|
79
|
+
if (this.draining) {
|
|
80
|
+
if (waitForCompletion) {
|
|
81
|
+
await this.waitForInFlight();
|
|
82
|
+
}
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
this.draining = true;
|
|
86
|
+
try {
|
|
87
|
+
if (!this.abandonedRunningRecovered) {
|
|
88
|
+
this.recoverAbandonedRunningRequests();
|
|
89
|
+
this.abandonedRunningRecovered = true;
|
|
90
|
+
}
|
|
91
|
+
for (const request of this.deps.store.listOpenOrchestrationRequests()) {
|
|
92
|
+
if (this.inFlight.has(request.requestId)) {
|
|
93
|
+
continue;
|
|
94
|
+
}
|
|
95
|
+
const claimed = this.deps.store.claimPendingOrchestrationRequest({
|
|
96
|
+
requestId: request.requestId,
|
|
97
|
+
executionOwner: this.executionOwner,
|
|
98
|
+
nowIso: this.deps.now()
|
|
99
|
+
});
|
|
100
|
+
if (!claimed) {
|
|
101
|
+
continue;
|
|
102
|
+
}
|
|
103
|
+
const inFlight = this.process(claimed).finally(() => {
|
|
104
|
+
this.inFlight.delete(request.requestId);
|
|
105
|
+
this.inFlightStartedAt.delete(request.requestId);
|
|
106
|
+
});
|
|
107
|
+
this.inFlight.set(request.requestId, inFlight);
|
|
108
|
+
this.inFlightStartedAt.set(request.requestId, this.nowMs());
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
finally {
|
|
112
|
+
this.draining = false;
|
|
113
|
+
}
|
|
114
|
+
if (waitForCompletion) {
|
|
115
|
+
await this.waitForInFlight();
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
getQueueHealth(input = {}) {
|
|
119
|
+
return summarizeOrchestrationQueueHealth(this.deps.store.listOpenOrchestrationRequests(), {
|
|
120
|
+
staleRunningThresholdMs: input.staleRunningThresholdMs,
|
|
121
|
+
inFlightRequests: this.inFlight.size
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
async process(request) {
|
|
125
|
+
const executionToken = `${this.executionOwner}:${request.requestId}:${request.executionAttempt}`;
|
|
126
|
+
try {
|
|
127
|
+
const result = await this.executeRequest(request, executionToken);
|
|
128
|
+
this.deps.store.upsertOrchestrationRequest({
|
|
129
|
+
...request,
|
|
130
|
+
status: 'completed',
|
|
131
|
+
resultJson: JSON.stringify(result),
|
|
132
|
+
error: null,
|
|
133
|
+
completionToken: executionToken,
|
|
134
|
+
completedAt: this.deps.now(),
|
|
135
|
+
updatedAt: this.deps.now()
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
catch (error) {
|
|
139
|
+
this.deps.store.upsertOrchestrationRequest({
|
|
140
|
+
...request,
|
|
141
|
+
status: 'failed',
|
|
142
|
+
resultJson: null,
|
|
143
|
+
error: error instanceof Error ? error.message : String(error),
|
|
144
|
+
completionToken: null,
|
|
145
|
+
completedAt: this.deps.now(),
|
|
146
|
+
updatedAt: this.deps.now()
|
|
147
|
+
});
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
async executeRequest(request, executionToken) {
|
|
151
|
+
let parsedPayload;
|
|
152
|
+
try {
|
|
153
|
+
parsedPayload = JSON.parse(request.payloadJson);
|
|
154
|
+
}
|
|
155
|
+
catch {
|
|
156
|
+
throw new Error(`[ORCH_PAYLOAD_JSON_INVALID] orchestration payload for ${request.type} is not valid JSON.`);
|
|
157
|
+
}
|
|
158
|
+
switch (request.type) {
|
|
159
|
+
case 'create_session':
|
|
160
|
+
return await this.deps.workManagement.createManagedSession({
|
|
161
|
+
actorId: request.actorId,
|
|
162
|
+
...decodeOrchestrationPayload('create_session', parsedPayload)
|
|
163
|
+
});
|
|
164
|
+
case 'direct_session':
|
|
165
|
+
return await this.deps.workManagement.directManagedSession({
|
|
166
|
+
actorId: request.actorId,
|
|
167
|
+
...decodeOrchestrationPayload('direct_session', parsedPayload)
|
|
168
|
+
});
|
|
169
|
+
case 'archive_session':
|
|
170
|
+
return await this.deps.workManagement.archiveManagedSession({
|
|
171
|
+
actorId: request.actorId,
|
|
172
|
+
...decodeOrchestrationPayload('archive_session', parsedPayload)
|
|
173
|
+
});
|
|
174
|
+
case 'delete_session':
|
|
175
|
+
return await this.deps.workManagement.deleteManagedSession({
|
|
176
|
+
actorId: request.actorId,
|
|
177
|
+
...decodeOrchestrationPayload('delete_session', parsedPayload)
|
|
178
|
+
});
|
|
179
|
+
case 'post_message': {
|
|
180
|
+
const payload = decodeOrchestrationPayload('post_message', parsedPayload);
|
|
181
|
+
const attachments = payload.files?.map((file) => ({
|
|
182
|
+
kind: 'file',
|
|
183
|
+
path: file.path,
|
|
184
|
+
...(file.name ? { name: file.name } : {}),
|
|
185
|
+
...(file.description ? { description: file.description } : {})
|
|
186
|
+
}));
|
|
187
|
+
this.deps.validateLocalFiles(attachments, {
|
|
188
|
+
requestedByThreadId: request.requestedByThreadId
|
|
189
|
+
});
|
|
190
|
+
return await this.deps.postTransportMessage(request.actorId, payload.spaceId, {
|
|
191
|
+
...(payload.content ? { text: payload.content } : {}),
|
|
192
|
+
...(attachments ? { attachments } : {}),
|
|
193
|
+
metadata: {
|
|
194
|
+
orchestrationRequestId: request.requestId,
|
|
195
|
+
orchestrationExecutionToken: executionToken
|
|
196
|
+
}
|
|
197
|
+
});
|
|
198
|
+
}
|
|
199
|
+
case 'create_mission':
|
|
200
|
+
return await this.deps.createPluginContext(request.actorId).createMission(decodeOrchestrationPayload('create_mission', parsedPayload));
|
|
201
|
+
case 'pause_mission':
|
|
202
|
+
return await this.deps.workManagement.updateMissionLifecycle(request.actorId, decodeOrchestrationPayload('pause_mission', parsedPayload), 'pause');
|
|
203
|
+
case 'resume_mission':
|
|
204
|
+
return await this.deps.workManagement.updateMissionLifecycle(request.actorId, decodeOrchestrationPayload('resume_mission', parsedPayload), 'resume');
|
|
205
|
+
case 'stop_mission':
|
|
206
|
+
return await this.deps.workManagement.updateMissionLifecycle(request.actorId, decodeOrchestrationPayload('stop_mission', parsedPayload), 'stop');
|
|
207
|
+
case 'run_mission':
|
|
208
|
+
{
|
|
209
|
+
const payload = decodeOrchestrationPayload('run_mission', parsedPayload);
|
|
210
|
+
return await this.deps.createPluginContext(request.actorId).runMissionNow({
|
|
211
|
+
spaceId: payload.spaceId,
|
|
212
|
+
missionId: payload.missionId
|
|
213
|
+
});
|
|
214
|
+
}
|
|
215
|
+
case 'archive_mission':
|
|
216
|
+
return await this.deps.workManagement.archiveMission({
|
|
217
|
+
actorId: request.actorId,
|
|
218
|
+
...decodeOrchestrationPayload('archive_mission', parsedPayload)
|
|
219
|
+
});
|
|
220
|
+
case 'delete_mission':
|
|
221
|
+
return await this.deps.workManagement.deleteArchivedMission({
|
|
222
|
+
actorId: request.actorId,
|
|
223
|
+
...decodeOrchestrationPayload('delete_mission', parsedPayload)
|
|
224
|
+
});
|
|
225
|
+
case 'runtime_set_accepting': {
|
|
226
|
+
const payload = decodeOrchestrationPayload('runtime_set_accepting', parsedPayload);
|
|
227
|
+
await this.deps.createPluginContext(request.actorId).setRuntimeAcceptingNewWork({
|
|
228
|
+
accepting: payload.accepting,
|
|
229
|
+
reason: CLI_RUNTIME_CONTROL_REASON,
|
|
230
|
+
requestedBy: CLI_RUNTIME_CONTROL_REQUESTED_BY
|
|
231
|
+
});
|
|
232
|
+
return {
|
|
233
|
+
accepting: payload.accepting
|
|
234
|
+
};
|
|
235
|
+
}
|
|
236
|
+
case 'runtime_reload': {
|
|
237
|
+
const payload = decodeOrchestrationPayload('runtime_reload', parsedPayload);
|
|
238
|
+
return await this.deps.createPluginContext(request.actorId).requestRuntimeReload({
|
|
239
|
+
mode: payload.mode,
|
|
240
|
+
reason: CLI_RUNTIME_CONTROL_REASON,
|
|
241
|
+
requestedBy: CLI_RUNTIME_CONTROL_REQUESTED_BY
|
|
242
|
+
});
|
|
243
|
+
}
|
|
244
|
+
case 'provider_test': {
|
|
245
|
+
const payload = decodeOrchestrationPayload('provider_test', parsedPayload);
|
|
246
|
+
return await this.deps.createPluginContext(request.actorId).testProvider({
|
|
247
|
+
...(payload.sendTurn === true ? { sendTurn: true } : {}),
|
|
248
|
+
...(payload.prompt ? { prompt: payload.prompt } : {}),
|
|
249
|
+
reason: CLI_RUNTIME_CONTROL_REASON,
|
|
250
|
+
requestedBy: CLI_RUNTIME_CONTROL_REQUESTED_BY
|
|
251
|
+
});
|
|
252
|
+
}
|
|
253
|
+
case 'provider_stop': {
|
|
254
|
+
const payload = decodeOrchestrationPayload('provider_stop', parsedPayload);
|
|
255
|
+
return await this.deps.createPluginContext(request.actorId).stopProvider({
|
|
256
|
+
...(payload.threadId ? { threadId: payload.threadId } : {}),
|
|
257
|
+
reason: CLI_RUNTIME_CONTROL_REASON,
|
|
258
|
+
requestedBy: CLI_RUNTIME_CONTROL_REQUESTED_BY
|
|
259
|
+
});
|
|
260
|
+
}
|
|
261
|
+
case 'provider_start': {
|
|
262
|
+
const payload = decodeOrchestrationPayload('provider_start', parsedPayload);
|
|
263
|
+
return await this.deps.createPluginContext(request.actorId).startProvider({
|
|
264
|
+
...(payload.threadId ? { threadId: payload.threadId } : {}),
|
|
265
|
+
reason: CLI_RUNTIME_CONTROL_REASON,
|
|
266
|
+
requestedBy: CLI_RUNTIME_CONTROL_REQUESTED_BY
|
|
267
|
+
});
|
|
268
|
+
}
|
|
269
|
+
case 'resolve_pending_request': {
|
|
270
|
+
const payload = decodeOrchestrationPayload('resolve_pending_request', parsedPayload);
|
|
271
|
+
const context = this.deps.createPluginContext(request.actorId);
|
|
272
|
+
const pending = context.getRuntimeOverview().openRequests.find((entry) => entry.requestId === payload.requestId);
|
|
273
|
+
if (!pending || pending.status !== 'open') {
|
|
274
|
+
throw new Error(`Open pending request not found: ${payload.requestId}`);
|
|
275
|
+
}
|
|
276
|
+
if (payload.decision === 'cancel') {
|
|
277
|
+
await context.cancelRuntimeRequest({
|
|
278
|
+
threadId: pending.threadId,
|
|
279
|
+
requestId: pending.requestId,
|
|
280
|
+
requestType: pending.requestType
|
|
281
|
+
});
|
|
282
|
+
return {
|
|
283
|
+
requestId: pending.requestId,
|
|
284
|
+
decision: payload.decision
|
|
285
|
+
};
|
|
286
|
+
}
|
|
287
|
+
await context.respondToRuntimeRequest({
|
|
288
|
+
threadId: pending.threadId,
|
|
289
|
+
requestId: pending.requestId,
|
|
290
|
+
decision: payload.decision
|
|
291
|
+
});
|
|
292
|
+
return {
|
|
293
|
+
requestId: pending.requestId,
|
|
294
|
+
decision: payload.decision
|
|
295
|
+
};
|
|
296
|
+
}
|
|
297
|
+
case 'answer_pending_request': {
|
|
298
|
+
const payload = decodeOrchestrationPayload('answer_pending_request', parsedPayload);
|
|
299
|
+
const context = this.deps.createPluginContext(request.actorId);
|
|
300
|
+
const pending = context.getRuntimeOverview().openRequests.find((entry) => entry.requestId === payload.requestId);
|
|
301
|
+
if (!pending || pending.status !== 'open') {
|
|
302
|
+
throw new Error(`Open pending request not found: ${payload.requestId}`);
|
|
303
|
+
}
|
|
304
|
+
await context.respondToRuntimeUserInput({
|
|
305
|
+
threadId: pending.threadId,
|
|
306
|
+
requestId: pending.requestId,
|
|
307
|
+
answers: payload.answers
|
|
308
|
+
});
|
|
309
|
+
return {
|
|
310
|
+
requestId: pending.requestId
|
|
311
|
+
};
|
|
312
|
+
}
|
|
313
|
+
default:
|
|
314
|
+
throw new Error(`Unknown orchestration request type: ${String(request.type)}`);
|
|
315
|
+
}
|
|
316
|
+
}
|
|
317
|
+
async waitForInFlight() {
|
|
318
|
+
const startedAt = this.nowMs();
|
|
319
|
+
const timeoutMs = this.deps.drainWaitTimeoutMs ?? ORCHESTRATION_DRAIN_WAIT_TIMEOUT_MS;
|
|
320
|
+
while (this.inFlight.size > 0) {
|
|
321
|
+
const elapsedMs = this.nowMs() - startedAt;
|
|
322
|
+
const remainingMs = timeoutMs - elapsedMs;
|
|
323
|
+
if (remainingMs <= 0) {
|
|
324
|
+
this.signalForcedDrain(timeoutMs);
|
|
325
|
+
return;
|
|
326
|
+
}
|
|
327
|
+
await Promise.race([
|
|
328
|
+
Promise.race(this.inFlight.values()),
|
|
329
|
+
new Promise((resolve) => {
|
|
330
|
+
globalThis.setTimeout(resolve, Math.min(ORCHESTRATION_POLL_MS, remainingMs));
|
|
331
|
+
})
|
|
332
|
+
]);
|
|
333
|
+
}
|
|
334
|
+
}
|
|
335
|
+
recoverAbandonedRunningRequests() {
|
|
336
|
+
const nowIso = this.deps.now();
|
|
337
|
+
const recovered = this.deps.store.failAbandonedRunningOrchestrationRequests({
|
|
338
|
+
executionOwner: this.executionOwner,
|
|
339
|
+
nowIso,
|
|
340
|
+
error: ORCHESTRATION_REPLAY_SAFETY_BLOCK_ERROR
|
|
341
|
+
});
|
|
342
|
+
if (recovered > 0) {
|
|
343
|
+
this.deps.store.putMetadata('runtime.orchestration.last_replay_safety_block', {
|
|
344
|
+
recovered,
|
|
345
|
+
executionOwner: this.executionOwner,
|
|
346
|
+
at: nowIso
|
|
347
|
+
}, nowIso);
|
|
348
|
+
}
|
|
349
|
+
}
|
|
350
|
+
nowMs() {
|
|
351
|
+
return this.deps.nowMs ? this.deps.nowMs() : Date.now();
|
|
352
|
+
}
|
|
353
|
+
signalForcedDrain(timeoutMs) {
|
|
354
|
+
const nowIso = this.deps.now();
|
|
355
|
+
const ages = [...this.inFlightStartedAt.values()].map((startedAt) => Math.max(0, this.nowMs() - startedAt));
|
|
356
|
+
const signal = {
|
|
357
|
+
timeoutMs,
|
|
358
|
+
inFlightRequestIds: [...this.inFlight.keys()],
|
|
359
|
+
oldestInFlightAgeMs: ages.length > 0 ? Math.max(...ages) : 0,
|
|
360
|
+
at: nowIso
|
|
361
|
+
};
|
|
362
|
+
this.deps.store.putMetadata('runtime.orchestration.last_forced_drain', signal, nowIso);
|
|
363
|
+
this.deps.onForcedDrain?.(signal);
|
|
364
|
+
}
|
|
365
|
+
}
|
|
366
|
+
//# sourceMappingURL=runtimeOrchestrationRequestService.js.map
|