@moorline/core 0.0.1 → 0.0.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/dist/app/bootstrap/apiAdapterPackageLoader.d.ts +0 -10
- package/dist/app/bootstrap/apiAdapterPackageLoader.js +1 -1
- package/dist/app/bootstrap/apiAdapterPackageLoader.js.map +1 -1
- package/dist/app/bootstrap/operatorPackageService.d.ts +11 -4
- package/dist/app/bootstrap/operatorPackageService.js +231 -59
- package/dist/app/bootstrap/operatorPackageService.js.map +1 -1
- package/dist/app/bootstrap/runtimeBootstrap.d.ts +2 -1
- package/dist/app/bootstrap/runtimeBootstrap.js +14 -3
- package/dist/app/bootstrap/runtimeBootstrap.js.map +1 -1
- package/dist/app/control-api/services/actions.d.ts +12 -16
- package/dist/app/control-api/services/actions.js +89 -68
- package/dist/app/control-api/services/actions.js.map +1 -1
- package/dist/app/control-api/services/controlPlane.d.ts +17 -21
- package/dist/app/control-api/services/controlPlane.js +69 -74
- package/dist/app/control-api/services/controlPlane.js.map +1 -1
- package/dist/app/control-api/services/state.js +5 -9
- package/dist/app/control-api/services/state.js.map +1 -1
- package/dist/core/domain/memory/retrieval/indexTargets.js +6 -6
- package/dist/core/domain/memory/retrieval/indexTargets.js.map +1 -1
- package/dist/core/domain/memory/retrieval/schema.js +10 -6
- package/dist/core/domain/memory/retrieval/schema.js.map +1 -1
- package/dist/core/domain/memory/retrieval/scope.d.ts +2 -2
- package/dist/core/domain/memory/retrieval/scope.js +7 -7
- package/dist/core/domain/memory/retrieval/scope.js.map +1 -1
- package/dist/core/domain/memory/retrieval/types.d.ts +2 -7
- package/dist/core/domain/memory/retrieval/types.js.map +1 -1
- package/dist/core/domain/memory/retrieval.d.ts +1 -2
- package/dist/core/domain/memory/retrieval.js +9 -16
- package/dist/core/domain/memory/retrieval.js.map +1 -1
- package/dist/core/domain/memory/store.d.ts +1 -1
- package/dist/core/domain/memory/store.js +2 -2
- package/dist/core/domain/memory/store.js.map +1 -1
- package/dist/core/domain/sessions/managedWorkerSessions.d.ts +0 -1
- package/dist/core/domain/sessions/managedWorkerSessions.js.map +1 -1
- package/dist/core/domain/sessions/runtimeWorkManagementService.d.ts +41 -60
- package/dist/core/domain/sessions/runtimeWorkManagementService.js +169 -351
- package/dist/core/domain/sessions/runtimeWorkManagementService.js.map +1 -1
- package/dist/core/domain/sessions/sessionLifecycleService.d.ts +1 -1
- package/dist/core/domain/sessions/sessionLifecycleService.js +4 -4
- package/dist/core/domain/sessions/sessionLifecycleService.js.map +1 -1
- package/dist/core/domain/sessions/sessionState.d.ts +14 -8
- package/dist/core/domain/sessions/sessionState.js +74 -28
- package/dist/core/domain/sessions/sessionState.js.map +1 -1
- package/dist/core/domain/sessions/workManagement/transportResourceNames.d.ts +2 -0
- package/dist/core/domain/sessions/workManagement/{spaceNames.js → transportResourceNames.js} +2 -2
- package/dist/core/domain/sessions/workManagement/transportResourceNames.js.map +1 -0
- package/dist/core/extension/capabilities/capabilities.d.ts +1 -1
- package/dist/core/extension/capabilities/capabilities.js +11 -8
- package/dist/core/extension/capabilities/capabilities.js.map +1 -1
- package/dist/core/extension/packages/bundledArchiveResolver.d.ts +2 -0
- package/dist/core/extension/packages/{officialArchiveResolver.js → bundledArchiveResolver.js} +4 -4
- package/dist/core/extension/packages/bundledArchiveResolver.js.map +1 -0
- package/dist/core/extension/packages/npmRegistryClient.d.ts +3 -2
- package/dist/core/extension/packages/npmRegistryClient.js +12 -37
- package/dist/core/extension/packages/npmRegistryClient.js.map +1 -1
- package/dist/core/extension/packages/packageActivation.d.ts +0 -4
- package/dist/core/extension/packages/packageActivation.js +2 -12
- package/dist/core/extension/packages/packageActivation.js.map +1 -1
- package/dist/core/extension/packages/packageApplyPlanner.js +1 -4
- package/dist/core/extension/packages/packageApplyPlanner.js.map +1 -1
- package/dist/core/extension/packages/packageConfigSchema.js +0 -33
- package/dist/core/extension/packages/packageConfigSchema.js.map +1 -1
- package/dist/core/extension/packages/packageDependencyResolver.js +2 -20
- package/dist/core/extension/packages/packageDependencyResolver.js.map +1 -1
- package/dist/core/extension/packages/packageInstaller.js +3 -0
- package/dist/core/extension/packages/packageInstaller.js.map +1 -1
- package/dist/core/extension/packages/packageInventoryStore.js +20 -4
- package/dist/core/extension/packages/packageInventoryStore.js.map +1 -1
- package/dist/core/extension/packages/packageRegistryBlocklist.d.ts +2 -2
- package/dist/core/extension/packages/packageRegistryBlocklist.js +1 -1
- package/dist/core/extension/packages/packageRegistryBlocklist.js.map +1 -1
- package/dist/core/extension/packages/packageRegistryService.d.ts +8 -3
- package/dist/core/extension/packages/packageRegistryService.js +109 -49
- package/dist/core/extension/packages/packageRegistryService.js.map +1 -1
- package/dist/core/extension/packages/packageRegistryTypes.d.ts +14 -6
- package/dist/core/extension/packages/packageSource.js +120 -5
- package/dist/core/extension/packages/packageSource.js.map +1 -1
- package/dist/core/extension/packages/packageValidation.js +1 -1
- package/dist/core/extension/packages/packageValidation.js.map +1 -1
- package/dist/core/extension/packages/packageVersionResolver.d.ts +6 -11
- package/dist/core/extension/packages/packageVersionResolver.js +5 -5
- package/dist/core/extension/packages/packageVersionResolver.js.map +1 -1
- package/dist/core/extension/packages/runtimeStartability.d.ts +2 -2
- package/dist/core/extension/packages/runtimeStartability.js +26 -23
- package/dist/core/extension/packages/runtimeStartability.js.map +1 -1
- package/dist/core/extension/plugins/pluginHost.d.ts +13 -8
- package/dist/core/extension/plugins/pluginHost.js +41 -13
- package/dist/core/extension/plugins/pluginHost.js.map +1 -1
- package/dist/core/extension/plugins/pluginId.d.ts +0 -1
- package/dist/core/extension/plugins/pluginId.js +0 -3
- package/dist/core/extension/plugins/pluginId.js.map +1 -1
- package/dist/core/extension/plugins/runtimePluginLoader.d.ts +0 -1
- package/dist/core/extension/plugins/runtimePluginLoader.js +0 -7
- package/dist/core/extension/plugins/runtimePluginLoader.js.map +1 -1
- package/dist/core/extension/skills/skillRegistry.d.ts +3 -2
- package/dist/core/extension/skills/skillWriter.d.ts +1 -1
- package/dist/core/extension/skills/skillWriter.js +2 -2
- package/dist/core/runtime/execution/commandReactor.d.ts +5 -5
- package/dist/core/runtime/execution/commandReactor.js +10 -7
- package/dist/core/runtime/execution/commandReactor.js.map +1 -1
- package/dist/core/runtime/execution/defaultModelSelection.js +1 -1
- package/dist/core/runtime/execution/orchestrationEngine.js +10 -10
- package/dist/core/runtime/execution/orchestrationEngine.js.map +1 -1
- package/dist/core/runtime/execution/orchestrationHealth.d.ts +0 -7
- package/dist/core/runtime/execution/orchestrationHealth.js +1 -1
- package/dist/core/runtime/execution/orchestrationHealth.js.map +1 -1
- package/dist/core/runtime/execution/pluginContext/defaultSessionOwner.js +3 -5
- package/dist/core/runtime/execution/pluginContext/defaultSessionOwner.js.map +1 -1
- package/dist/core/runtime/execution/pluginContext/pluginCapabilities.d.ts +0 -2
- package/dist/core/runtime/execution/pluginContext/pluginCapabilities.js +0 -2
- package/dist/core/runtime/execution/pluginContext/pluginCapabilities.js.map +1 -1
- package/dist/core/runtime/execution/pluginContext/pluginContextFactory.d.ts +1 -2
- package/dist/core/runtime/execution/pluginContext/pluginContextFactory.js +1 -2
- package/dist/core/runtime/execution/pluginContext/pluginContextFactory.js.map +1 -1
- package/dist/core/runtime/execution/providerCoordination/providerSessionCoordinator.js +3 -3
- package/dist/core/runtime/execution/providerCoordination/providerSessionCoordinator.js.map +1 -1
- package/dist/core/runtime/execution/providerOrchestration/ports.d.ts +3 -13
- package/dist/core/runtime/execution/providerOrchestration/providerAttachmentResolver.d.ts +3 -3
- package/dist/core/runtime/execution/providerOrchestration/providerAttachmentResolver.js +4 -5
- package/dist/core/runtime/execution/providerOrchestration/providerAttachmentResolver.js.map +1 -1
- package/dist/core/runtime/execution/providerOrchestration/providerCompactionPolicy.d.ts +2 -1
- package/dist/core/runtime/execution/providerOrchestration/providerCompactionPolicy.js +5 -5
- package/dist/core/runtime/execution/providerOrchestration/providerCompactionPolicy.js.map +1 -1
- package/dist/core/runtime/execution/providerOrchestration/providerEventPipeline.d.ts +3 -5
- package/dist/core/runtime/execution/providerOrchestration/providerEventPipeline.js +10 -8
- package/dist/core/runtime/execution/providerOrchestration/providerEventPipeline.js.map +1 -1
- package/dist/core/runtime/execution/providerOrchestration/providerOrchestrator.d.ts +3 -3
- package/dist/core/runtime/execution/providerOrchestration/providerOrchestrator.js +0 -3
- package/dist/core/runtime/execution/providerOrchestration/providerOrchestrator.js.map +1 -1
- package/dist/core/runtime/execution/providerOrchestration/providerRequestProjector.d.ts +3 -2
- package/dist/core/runtime/execution/providerOrchestration/providerRequestProjector.js +6 -6
- package/dist/core/runtime/execution/providerOrchestration/providerRequestProjector.js.map +1 -1
- package/dist/core/runtime/execution/providerOrchestration/providerSessionOrchestrator.d.ts +9 -6
- package/dist/core/runtime/execution/providerOrchestration/providerSessionOrchestrator.js +36 -15
- package/dist/core/runtime/execution/providerOrchestration/providerSessionOrchestrator.js.map +1 -1
- package/dist/core/runtime/execution/providerOrchestration/providerTurnBroker.d.ts +9 -3
- package/dist/core/runtime/execution/providerOrchestration/providerTurnBroker.js +19 -7
- package/dist/core/runtime/execution/providerOrchestration/providerTurnBroker.js.map +1 -1
- package/dist/core/runtime/execution/providerProjectionTypes.d.ts +4 -2
- package/dist/core/runtime/execution/providerProjectionTypes.js +2 -0
- package/dist/core/runtime/execution/providerProjectionTypes.js.map +1 -1
- package/dist/core/runtime/execution/providerSessionDirectory.js +12 -4
- package/dist/core/runtime/execution/providerSessionDirectory.js.map +1 -1
- package/dist/core/runtime/execution/runtimeDomain.d.ts +11 -9
- package/dist/core/runtime/execution/runtimeDomain.js +10 -3
- package/dist/core/runtime/execution/runtimeDomain.js.map +1 -1
- package/dist/core/runtime/execution/runtimeIngestion.js +15 -13
- package/dist/core/runtime/execution/runtimeIngestion.js.map +1 -1
- package/dist/core/runtime/execution/runtimeInteractionService.d.ts +12 -26
- package/dist/core/runtime/execution/runtimeInteractionService.js +23 -113
- package/dist/core/runtime/execution/runtimeInteractionService.js.map +1 -1
- package/dist/core/runtime/execution/runtimeOrchestrationRequestService.d.ts +1 -1
- package/dist/core/runtime/execution/runtimeOrchestrationRequestService.js +8 -28
- package/dist/core/runtime/execution/runtimeOrchestrationRequestService.js.map +1 -1
- package/dist/core/runtime/execution/runtimeOrchestrationRequests.d.ts +7 -29
- package/dist/core/runtime/execution/runtimeOrchestrationRequests.js +21 -67
- package/dist/core/runtime/execution/runtimeOrchestrationRequests.js.map +1 -1
- package/dist/core/runtime/execution/runtimeOrchestrationResult.js +5 -0
- package/dist/core/runtime/execution/runtimeOrchestrationResult.js.map +1 -1
- package/dist/core/runtime/execution/runtimePendingRequestService.d.ts +2 -2
- package/dist/core/runtime/execution/runtimePendingRequestService.js +10 -10
- package/dist/core/runtime/execution/runtimePendingRequestService.js.map +1 -1
- package/dist/core/runtime/execution/runtimePluginContextService.d.ts +28 -15
- package/dist/core/runtime/execution/runtimePluginContextService.js +994 -165
- package/dist/core/runtime/execution/runtimePluginContextService.js.map +1 -1
- package/dist/core/runtime/execution/runtimeWorkerQueues.js +1 -1
- package/dist/core/runtime/execution/runtimeWorkerQueues.js.map +1 -1
- package/dist/core/runtime/hosting/managedTransportResourceMetadata.d.ts +6 -0
- package/dist/core/runtime/hosting/managedTransportResourceMetadata.js +8 -0
- package/dist/core/runtime/hosting/managedTransportResourceMetadata.js.map +1 -0
- package/dist/core/runtime/hosting/runtimeHostingService.d.ts +6 -4
- package/dist/core/runtime/hosting/runtimeHostingService.js +23 -46
- package/dist/core/runtime/hosting/runtimeHostingService.js.map +1 -1
- package/dist/core/runtime/hosting/runtimeLayout.js +1 -1
- package/dist/core/runtime/hosting/runtimeLayout.js.map +1 -1
- package/dist/core/runtime/hosting/runtimeTransportEffectService.d.ts +22 -0
- package/dist/core/runtime/hosting/runtimeTransportEffectService.js +86 -0
- package/dist/core/runtime/hosting/runtimeTransportEffectService.js.map +1 -0
- package/dist/core/runtime/hosting/runtimeTransportIntentService.d.ts +23 -0
- package/dist/core/runtime/hosting/runtimeTransportIntentService.js +144 -0
- package/dist/core/runtime/hosting/runtimeTransportIntentService.js.map +1 -0
- package/dist/core/runtime/hosting/runtimeTransportSurfaceService.d.ts +6 -7
- package/dist/core/runtime/hosting/runtimeTransportSurfaceService.js +15 -63
- package/dist/core/runtime/hosting/runtimeTransportSurfaceService.js.map +1 -1
- package/dist/core/runtime/hosting/systemEmbeds.d.ts +0 -1
- package/dist/core/runtime/hosting/systemEmbeds.js +0 -9
- package/dist/core/runtime/hosting/systemEmbeds.js.map +1 -1
- package/dist/core/runtime/lifecycle/packageJobSchedulerService.d.ts +21 -0
- package/dist/core/runtime/lifecycle/packageJobSchedulerService.js +84 -0
- package/dist/core/runtime/lifecycle/packageJobSchedulerService.js.map +1 -0
- package/dist/core/runtime/lifecycle/runtimeLifecycleService.d.ts +2 -13
- package/dist/core/runtime/lifecycle/runtimeLifecycleService.js +12 -256
- package/dist/core/runtime/lifecycle/runtimeLifecycleService.js.map +1 -1
- package/dist/core/runtime/moorlineRuntime.d.ts +7 -8
- package/dist/core/runtime/moorlineRuntime.js +73 -57
- package/dist/core/runtime/moorlineRuntime.js.map +1 -1
- package/dist/core/runtime/moorlineRuntimeBuilder.d.ts +19 -18
- package/dist/core/runtime/moorlineRuntimeBuilder.js +69 -109
- package/dist/core/runtime/moorlineRuntimeBuilder.js.map +1 -1
- package/dist/core/runtime/runtimeBootstrapRegistry.d.ts +0 -2
- package/dist/core/runtime/runtimeBootstrapRegistry.js +0 -6
- package/dist/core/runtime/runtimeBootstrapRegistry.js.map +1 -1
- package/dist/core/runtime/runtimeStatus.js +2 -2
- package/dist/core/runtime/runtimeStatus.js.map +1 -1
- package/dist/core/runtime/supervision/runtimeControlService.js +4 -1
- package/dist/core/runtime/supervision/runtimeControlService.js.map +1 -1
- package/dist/core/shared/errors/statusError.d.ts +5 -0
- package/dist/core/shared/errors/statusError.js +18 -0
- package/dist/core/shared/errors/statusError.js.map +1 -0
- package/dist/core/shared/fs/canonicalPathContainment.d.ts +0 -2
- package/dist/core/shared/fs/canonicalPathContainment.js +1 -6
- package/dist/core/shared/fs/canonicalPathContainment.js.map +1 -1
- package/dist/core/shared/fs/runtimeOwnedPath.d.ts +1 -1
- package/dist/core/shared/fs/runtimeOwnedPath.js +3 -3
- package/dist/core/shared/fs/runtimeOwnedPath.js.map +1 -1
- package/dist/core/shared/scheduling/packageSchedule.d.ts +22 -0
- package/dist/core/{domain/missions/missionSchedule.js → shared/scheduling/packageSchedule.js} +15 -18
- package/dist/core/shared/scheduling/packageSchedule.js.map +1 -0
- package/dist/core/shared/utils/childProcessEnv.js +1 -1
- package/dist/core/shared/utils/childProcessEnv.js.map +1 -1
- package/dist/core/shared/utils/payloadRedaction.d.ts +0 -12
- package/dist/core/shared/utils/payloadRedaction.js +0 -77
- package/dist/core/shared/utils/payloadRedaction.js.map +1 -1
- package/dist/core/shared/utils/remoteNetworkPolicy.d.ts +0 -4
- package/dist/core/shared/utils/remoteNetworkPolicy.js +1 -7
- package/dist/core/shared/utils/remoteNetworkPolicy.js.map +1 -1
- package/dist/core/shared/utils/runtimeMessageUtils.d.ts +0 -1
- package/dist/core/shared/utils/runtimeMessageUtils.js +0 -19
- package/dist/core/shared/utils/runtimeMessageUtils.js.map +1 -1
- package/dist/core/system/backup/runtimeBackupService.d.ts +0 -2
- package/dist/core/system/backup/runtimeBackupService.js +71 -2
- package/dist/core/system/backup/runtimeBackupService.js.map +1 -1
- package/dist/core/system/config/configStore.d.ts +3 -3
- package/dist/core/system/config/configStore.js +19 -20
- package/dist/core/system/config/configStore.js.map +1 -1
- package/dist/core/system/projection/managementReadModel/deps.d.ts +4 -5
- package/dist/core/system/projection/managementReadModel/objects/serviceObjects.d.ts +2 -1
- package/dist/core/system/projection/managementReadModel/objects/serviceObjects.js +13 -7
- package/dist/core/system/projection/managementReadModel/objects/serviceObjects.js.map +1 -1
- package/dist/core/system/projection/managementReadModel/packageTrust.d.ts +5 -0
- package/dist/core/system/projection/managementReadModel/packageTrust.js +40 -0
- package/dist/core/system/projection/managementReadModel/packageTrust.js.map +1 -0
- package/dist/core/system/projection/managementReadModel/pluginDiskRecords.d.ts +0 -1
- package/dist/core/system/projection/managementReadModel/pluginDiskRecords.js +1 -10
- package/dist/core/system/projection/managementReadModel/pluginDiskRecords.js.map +1 -1
- package/dist/core/system/projection/managementReadModelService.d.ts +3 -1
- package/dist/core/system/projection/managementReadModelService.js +133 -117
- package/dist/core/system/projection/managementReadModelService.js.map +1 -1
- package/dist/core/system/projection/pendingRequestProjectionStore.d.ts +1 -1
- package/dist/core/system/projection/pendingRequestProjectionStore.js +9 -9
- package/dist/core/system/projection/pendingRequestProjectionStore.js.map +1 -1
- package/dist/core/system/projection/runtimeActivityStore.d.ts +1 -1
- package/dist/core/system/projection/runtimeActivityStore.js +7 -7
- package/dist/core/system/projection/runtimeActivityStore.js.map +1 -1
- package/dist/core/system/projection/runtimeProjectionService.d.ts +1 -1
- package/dist/core/system/projection/runtimeProjectionService.js +3 -3
- package/dist/core/system/projection/runtimeProjectionService.js.map +1 -1
- package/dist/core/system/projection/runtimeReceiptStore.js +5 -5
- package/dist/core/system/projection/runtimeReceiptStore.js.map +1 -1
- package/dist/core/system/projection/runtimeReconciler.js +2 -2
- package/dist/core/system/projection/runtimeReconciler.js.map +1 -1
- package/dist/core/system/projection/runtimeSnapshotQuery.d.ts +6 -5
- package/dist/core/system/projection/runtimeSnapshotQuery.js +6 -6
- package/dist/core/system/projection/runtimeSnapshotQuery.js.map +1 -1
- package/dist/core/system/release/releaseArtifacts.d.ts +0 -2
- package/dist/core/system/release/releaseArtifacts.js +1 -12
- package/dist/core/system/release/releaseArtifacts.js.map +1 -1
- package/dist/core/system/release/runtimePackageLoadReport.d.ts +0 -1
- package/dist/core/system/release/runtimePackageLoadReport.js +0 -7
- package/dist/core/system/release/runtimePackageLoadReport.js.map +1 -1
- package/dist/core/system/state/canonicalEventLogStore.d.ts +1 -1
- package/dist/core/system/state/canonicalEventLogStore.js +7 -7
- package/dist/core/system/state/canonicalEventLogStore.js.map +1 -1
- package/dist/core/system/state/safeJson.d.ts +2 -1
- package/dist/core/system/state/sqlite/domainEventLogRepository.js +5 -5
- package/dist/core/system/state/sqlite/domainEventLogRepository.js.map +1 -1
- package/dist/core/system/state/sqlite/externalResourceRepository.d.ts +25 -0
- package/dist/core/system/state/sqlite/externalResourceRepository.js +105 -0
- package/dist/core/system/state/sqlite/externalResourceRepository.js.map +1 -0
- package/dist/core/system/state/sqlite/gateRunRepository.d.ts +13 -0
- package/dist/core/system/state/sqlite/gateRunRepository.js +66 -0
- package/dist/core/system/state/sqlite/gateRunRepository.js.map +1 -0
- package/dist/core/system/state/sqlite/orchestrationRepository.js +6 -6
- package/dist/core/system/state/sqlite/orchestrationRepository.js.map +1 -1
- package/dist/core/system/state/sqlite/packageJobRepository.d.ts +11 -0
- package/dist/core/system/state/sqlite/packageJobRepository.js +60 -0
- package/dist/core/system/state/sqlite/packageJobRepository.js.map +1 -0
- package/dist/core/system/state/sqlite/packageStateRepository.d.ts +10 -0
- package/dist/core/system/state/sqlite/packageStateRepository.js +45 -0
- package/dist/core/system/state/sqlite/packageStateRepository.js.map +1 -0
- package/dist/core/system/state/sqlite/pendingRequestRepository.d.ts +2 -2
- package/dist/core/system/state/sqlite/pendingRequestRepository.js +10 -10
- package/dist/core/system/state/sqlite/pendingRequestRepository.js.map +1 -1
- package/dist/core/system/state/sqlite/providerEventLogRepository.d.ts +1 -1
- package/dist/core/system/state/sqlite/providerEventLogRepository.js +6 -6
- package/dist/core/system/state/sqlite/providerEventLogRepository.js.map +1 -1
- package/dist/core/system/state/sqlite/rowMappers.d.ts +0 -1
- package/dist/core/system/state/sqlite/rowMappers.js +0 -3
- package/dist/core/system/state/sqlite/rowMappers.js.map +1 -1
- package/dist/core/system/state/sqlite/runtimeReceiptRepository.js +4 -4
- package/dist/core/system/state/sqlite/runtimeReceiptRepository.js.map +1 -1
- package/dist/core/system/state/sqlite/sessionRepository.d.ts +1 -1
- package/dist/core/system/state/sqlite/sessionRepository.js +13 -10
- package/dist/core/system/state/sqlite/sessionRepository.js.map +1 -1
- package/dist/core/system/state/sqlite/transportIntentRepository.d.ts +12 -0
- package/dist/core/system/state/sqlite/transportIntentRepository.js +106 -0
- package/dist/core/system/state/sqlite/transportIntentRepository.js.map +1 -0
- package/dist/core/system/state/sqlite/types.d.ts +91 -48
- package/dist/core/system/state/sqlite/types.js +86 -31
- package/dist/core/system/state/sqlite/types.js.map +1 -1
- package/dist/core/system/state/sqlite/workItemRepository.d.ts +25 -0
- package/dist/core/system/state/sqlite/workItemRepository.js +200 -0
- package/dist/core/system/state/sqlite/workItemRepository.js.map +1 -0
- package/dist/core/system/state/sqliteSessionStore.d.ts +68 -24
- package/dist/core/system/state/sqliteSessionStore.js +92 -41
- package/dist/core/system/state/sqliteSessionStore.js.map +1 -1
- package/dist/core/system/vcs/gitIgnoreTemplate.js +1 -1
- package/dist/core/system/vcs/gitIgnoreTemplate.js.map +1 -1
- package/dist/core/system/vcs/gitTrackedPaths.js +1 -1
- package/dist/core/system/vcs/gitTrackedPaths.js.map +1 -1
- package/dist/types/app.d.ts +35 -36
- package/dist/types/config.d.ts +14 -26
- package/dist/types/config.js +16 -22
- package/dist/types/config.js.map +1 -1
- package/dist/types/distro.d.ts +1 -1
- package/dist/types/distro.js.map +1 -1
- package/dist/types/external.d.ts +1 -0
- package/dist/types/external.js +2 -0
- package/dist/types/external.js.map +1 -0
- package/dist/types/package.d.ts +4 -4
- package/dist/types/provider.d.ts +2 -2
- package/dist/types/provider.js +1 -1
- package/dist/types/provider.js.map +1 -1
- package/dist/types/runtime.d.ts +2 -2
- package/dist/types/runtime.js +1 -1
- package/dist/types/runtime.js.map +1 -1
- package/dist/types/transport.d.ts +1 -1
- package/dist/types/transport.js.map +1 -1
- package/package.json +6 -3
- package/resources/migrations/001_sessions.sql +8 -9
- package/resources/migrations/003_provider_projections.sql +2 -2
- package/resources/migrations/004_runtime_projection_state.sql +1 -1
- package/resources/migrations/007_package_state_jobs.sql +28 -0
- package/resources/migrations/{009_session_orchestration.sql → 008_session_orchestration.sql} +1 -1
- package/resources/migrations/010_scope_space_terminology.sql +2 -0
- package/resources/migrations/015_external_work_spine.sql +92 -0
- package/resources/migrations/016_provider_profiles.sql +4 -0
- package/resources/migrations/017_nullable_session_workspace.sql +49 -0
- package/resources/migrations/018_transport_intents.sql +18 -0
- package/resources/policies/default-secure.json +13 -95
- package/dist/app/bootstrap/officialCatalog.d.ts +0 -1
- package/dist/app/bootstrap/officialCatalog.js +0 -2
- package/dist/app/bootstrap/officialCatalog.js.map +0 -1
- package/dist/core/domain/memory/operatorMemoryService.d.ts +0 -36
- package/dist/core/domain/memory/operatorMemoryService.js +0 -81
- package/dist/core/domain/memory/operatorMemoryService.js.map +0 -1
- package/dist/core/domain/missions/missionDraftSetup.d.ts +0 -12
- package/dist/core/domain/missions/missionDraftSetup.js +0 -92
- package/dist/core/domain/missions/missionDraftSetup.js.map +0 -1
- package/dist/core/domain/missions/missionHookService.d.ts +0 -41
- package/dist/core/domain/missions/missionHookService.js +0 -161
- package/dist/core/domain/missions/missionHookService.js.map +0 -1
- package/dist/core/domain/missions/missionHookValidation.d.ts +0 -8
- package/dist/core/domain/missions/missionHookValidation.js +0 -59
- package/dist/core/domain/missions/missionHookValidation.js.map +0 -1
- package/dist/core/domain/missions/missionRegistry.d.ts +0 -55
- package/dist/core/domain/missions/missionRegistry.js +0 -204
- package/dist/core/domain/missions/missionRegistry.js.map +0 -1
- package/dist/core/domain/missions/missionSchedule.d.ts +0 -24
- package/dist/core/domain/missions/missionSchedule.js.map +0 -1
- package/dist/core/domain/sessions/workManagement/spaceNames.d.ts +0 -2
- package/dist/core/domain/sessions/workManagement/spaceNames.js.map +0 -1
- package/dist/core/extension/packages/officialArchiveResolver.d.ts +0 -2
- package/dist/core/extension/packages/officialArchiveResolver.js.map +0 -1
- package/dist/core/extension/packages/officialCatalog.d.ts +0 -9
- package/dist/core/extension/packages/officialCatalog.js +0 -198
- package/dist/core/extension/packages/officialCatalog.js.map +0 -1
- package/dist/core/extension/packages/packageDistroMetadata.d.ts +0 -14
- package/dist/core/extension/packages/packageDistroMetadata.js +0 -153
- package/dist/core/extension/packages/packageDistroMetadata.js.map +0 -1
- package/dist/core/runtime/execution/providerCoordination/providerCompactionCoordinator.d.ts +0 -7
- package/dist/core/runtime/execution/providerCoordination/providerCompactionCoordinator.js +0 -25
- package/dist/core/runtime/execution/providerCoordination/providerCompactionCoordinator.js.map +0 -1
- package/dist/core/runtime/execution/providerCoordination/providerRecoveryService.d.ts +0 -7
- package/dist/core/runtime/execution/providerCoordination/providerRecoveryService.js +0 -6
- package/dist/core/runtime/execution/providerCoordination/providerRecoveryService.js.map +0 -1
- package/dist/core/runtime/execution/providerCoordination/providerTurnCoordinator.d.ts +0 -3
- package/dist/core/runtime/execution/providerCoordination/providerTurnCoordinator.js +0 -6
- package/dist/core/runtime/execution/providerCoordination/providerTurnCoordinator.js.map +0 -1
- package/dist/core/runtime/execution/providerOrchestration/providerMissionEventProjector.d.ts +0 -12
- package/dist/core/runtime/execution/providerOrchestration/providerMissionEventProjector.js +0 -71
- package/dist/core/runtime/execution/providerOrchestration/providerMissionEventProjector.js.map +0 -1
- package/dist/core/runtime/hosting/managedSpaceMetadata.d.ts +0 -7
- package/dist/core/runtime/hosting/managedSpaceMetadata.js +0 -14
- package/dist/core/runtime/hosting/managedSpaceMetadata.js.map +0 -1
- package/dist/core/runtime/lifecycle/managedChannelLifecycleService.d.ts +0 -37
- package/dist/core/runtime/lifecycle/managedChannelLifecycleService.js +0 -256
- package/dist/core/runtime/lifecycle/managedChannelLifecycleService.js.map +0 -1
- package/dist/core/system/state/sqlite/missionRepository.d.ts +0 -24
- package/dist/core/system/state/sqlite/missionRepository.js +0 -252
- package/dist/core/system/state/sqlite/missionRepository.js.map +0 -1
- package/resources/migrations/007_missions.sql +0 -41
- package/resources/migrations/008_mission_schedule_anchor.sql +0 -5
- package/resources/migrations/010_mission_archival.sql +0 -1
- package/resources/migrations/012_scope_space_terminology.sql +0 -19
- package/resources/migrations/015_mission_schedule_meta.sql +0 -9
- package/resources/migrations/016_mission_hook_bindings.sql +0 -16
- package/resources/official-catalog.json +0 -444
- /package/resources/migrations/{011_managed_sidecars.sql → 009_managed_sidecars.sql} +0 -0
- /package/resources/migrations/{013_orchestration_dedupe.sql → 011_orchestration_dedupe.sql} +0 -0
- /package/resources/migrations/{014_orchestration_execution_claims.sql → 012_orchestration_execution_claims.sql} +0 -0
- /package/resources/migrations/{017_domain_event_provenance.sql → 013_domain_event_provenance.sql} +0 -0
- /package/resources/migrations/{018_provider_event_processing.sql → 014_provider_event_processing.sql} +0 -0
|
@@ -1,5 +1,8 @@
|
|
|
1
|
+
import { randomUUID } from 'node:crypto';
|
|
2
|
+
import { join } from 'node:path';
|
|
1
3
|
import { usesProviderDefaultModel } from '../../../types/config.js';
|
|
2
4
|
import { saveMoorlineConfig } from '../../system/config/configStore.js';
|
|
5
|
+
import { writeSkill } from '../../extension/skills/skillWriter.js';
|
|
3
6
|
import { parseRuntimeModeName } from '../../../types/runtime.js';
|
|
4
7
|
import { refreshMemoryIndex, retrieveFromMemoryWithSQLite } from '../../domain/memory/retrieval.js';
|
|
5
8
|
import { recordHistoryCheckpoint } from '../../system/vcs/gitCheckpointService.js';
|
|
@@ -7,6 +10,7 @@ import { createPluginContextCapabilities } from './pluginContext/pluginContextFa
|
|
|
7
10
|
import { describeTransportAuthor } from './pluginContext/transportAuthor.js';
|
|
8
11
|
import { toPluginPackageId } from '../../extension/plugins/pluginId.js';
|
|
9
12
|
import { normalizeAndValidateDefaultModel } from './defaultModelSelection.js';
|
|
13
|
+
import { computePackageJobRunAtOrAfterWithMeta, packageScheduleMetaToJson, parsePackageSchedule, parsePackageScheduleStartTime } from '../../shared/scheduling/packageSchedule.js';
|
|
10
14
|
export { defaultSessionOwner } from './pluginContext/defaultSessionOwner.js';
|
|
11
15
|
export class RuntimePluginContextService {
|
|
12
16
|
deps;
|
|
@@ -43,6 +47,103 @@ export class RuntimePluginContextService {
|
|
|
43
47
|
const providerId = this.deps.config.provider.packageId ?? this.deps.config.provider.kind;
|
|
44
48
|
return `provider:${providerId}:${threadId}:${suffix}`;
|
|
45
49
|
}
|
|
50
|
+
contextPackageId(actorId) {
|
|
51
|
+
return actorId.startsWith('plugin:') ? actorId.slice('plugin:'.length) : actorId;
|
|
52
|
+
}
|
|
53
|
+
packageState(valueJson) {
|
|
54
|
+
try {
|
|
55
|
+
return JSON.parse(valueJson);
|
|
56
|
+
}
|
|
57
|
+
catch {
|
|
58
|
+
return null;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
validateStructuredOutput(value, schema) {
|
|
62
|
+
if (!schema || typeof schema !== 'object' || Array.isArray(schema)) {
|
|
63
|
+
return;
|
|
64
|
+
}
|
|
65
|
+
const record = schema;
|
|
66
|
+
if (record.type === 'object' && (!value || typeof value !== 'object' || Array.isArray(value))) {
|
|
67
|
+
throw new Error('Headless run output must be a JSON object.');
|
|
68
|
+
}
|
|
69
|
+
const objectValue = value && typeof value === 'object' && !Array.isArray(value) ? value : {};
|
|
70
|
+
if (Array.isArray(record.required)) {
|
|
71
|
+
for (const key of record.required) {
|
|
72
|
+
if (typeof key === 'string' && objectValue[key] === undefined) {
|
|
73
|
+
throw new Error(`Headless run output is missing required field: ${key}.`);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
const properties = record.properties && typeof record.properties === 'object' && !Array.isArray(record.properties)
|
|
78
|
+
? record.properties
|
|
79
|
+
: {};
|
|
80
|
+
for (const [key, property] of Object.entries(properties)) {
|
|
81
|
+
const expected = property.type;
|
|
82
|
+
const actual = objectValue[key];
|
|
83
|
+
if (actual === undefined || typeof expected !== 'string') {
|
|
84
|
+
continue;
|
|
85
|
+
}
|
|
86
|
+
const ok = expected === 'array'
|
|
87
|
+
? Array.isArray(actual)
|
|
88
|
+
: expected === 'object'
|
|
89
|
+
? actual !== null && typeof actual === 'object' && !Array.isArray(actual)
|
|
90
|
+
: typeof actual === expected;
|
|
91
|
+
if (!ok) {
|
|
92
|
+
throw new Error(`Headless run output field ${key} must be ${expected}.`);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
transitionWorkItem(actorId, workItemId, update) {
|
|
97
|
+
const current = this.requireOwnedWorkItem(actorId, workItemId);
|
|
98
|
+
const nowIso = this.deps.now();
|
|
99
|
+
const updated = this.deps.store.updateWorkItem(update(current, nowIso));
|
|
100
|
+
this.deps.appendAuditEvent('work_item.updated', {
|
|
101
|
+
actorId,
|
|
102
|
+
packageId: updated.packageId,
|
|
103
|
+
workItemId: updated.workItemId,
|
|
104
|
+
queue: updated.queue,
|
|
105
|
+
status: updated.status
|
|
106
|
+
});
|
|
107
|
+
this.deps.recordRuntimeActivity({
|
|
108
|
+
...this.activityTargetForSession(updated.sessionId, 'runtime:work'),
|
|
109
|
+
sourceEventId: randomUUID(),
|
|
110
|
+
kind: `work_item.${updated.status}`,
|
|
111
|
+
severity: updated.status === 'failed' || updated.status === 'dead_lettered' ? 'error' : 'info',
|
|
112
|
+
title: `Work item ${updated.status}`,
|
|
113
|
+
detail: `${updated.packageId}/${updated.queue}/${updated.workItemId}`,
|
|
114
|
+
createdAt: nowIso
|
|
115
|
+
});
|
|
116
|
+
return updated;
|
|
117
|
+
}
|
|
118
|
+
requireOwnedWorkItem(actorId, workItemId) {
|
|
119
|
+
const record = this.deps.store.getWorkItem(workItemId);
|
|
120
|
+
if (!record) {
|
|
121
|
+
throw new Error(`Unknown work item: ${workItemId}`);
|
|
122
|
+
}
|
|
123
|
+
const packageId = this.contextPackageId(actorId);
|
|
124
|
+
if (record.packageId !== packageId) {
|
|
125
|
+
throw new Error(`Work item ${workItemId} is owned by ${record.packageId}, not ${packageId}.`);
|
|
126
|
+
}
|
|
127
|
+
return record;
|
|
128
|
+
}
|
|
129
|
+
requireSession(sessionId) {
|
|
130
|
+
const session = this.deps.store.getSession(sessionId);
|
|
131
|
+
if (!session) {
|
|
132
|
+
throw new Error(`Unknown session: ${sessionId}`);
|
|
133
|
+
}
|
|
134
|
+
return session;
|
|
135
|
+
}
|
|
136
|
+
activityTargetForSession(sessionId, fallbackThreadId) {
|
|
137
|
+
if (!sessionId) {
|
|
138
|
+
return { threadId: fallbackThreadId, sessionId: null, transportResourceId: null };
|
|
139
|
+
}
|
|
140
|
+
const session = this.deps.store.getSession(sessionId);
|
|
141
|
+
return {
|
|
142
|
+
threadId: session?.threadId ?? fallbackThreadId,
|
|
143
|
+
sessionId,
|
|
144
|
+
transportResourceId: session?.transportResourceId ?? null
|
|
145
|
+
};
|
|
146
|
+
}
|
|
46
147
|
createContext(actorId) {
|
|
47
148
|
const capabilities = createPluginContextCapabilities({
|
|
48
149
|
actorId,
|
|
@@ -63,66 +164,329 @@ export class RuntimePluginContextService {
|
|
|
63
164
|
config: this.deps.config,
|
|
64
165
|
getAdminConfig: () => capabilities.admin.getAdminConfig(),
|
|
65
166
|
isAdminActor: (input) => this.deps.isAdminActor(input),
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
getCurrentThreadId: () => `
|
|
69
|
-
getCurrentWorkspacePath: () => this.deps.
|
|
70
|
-
|
|
167
|
+
getSurfaceState: () => this.deps.requireSurfaceState(),
|
|
168
|
+
getCurrentTransportResourceId: () => this.deps.getSurfaceState()?.coordinationResourceId ?? this.deps.config.transport.scopeId,
|
|
169
|
+
getCurrentThreadId: () => `coordination:${this.deps.getSurfaceState()?.coordinationResourceId ?? this.deps.config.transport.scopeId}`,
|
|
170
|
+
getCurrentWorkspacePath: () => this.deps.coordinationWorkspacePath,
|
|
171
|
+
getCoordinationWorkspacePath: () => this.deps.coordinationWorkspacePath,
|
|
172
|
+
getRuntimeRootPath: () => this.deps.runtimeRoot,
|
|
71
173
|
listSkills: () => capabilities.memory.listSkills(),
|
|
72
174
|
loadSkill: async (name) => await capabilities.memory.loadSkill(name),
|
|
73
175
|
writeSkill: async (input) => await capabilities.memory.writeSkill(input),
|
|
74
176
|
listSessions: () => this.deps.snapshots.listSessions().map((entry) => entry.session),
|
|
75
|
-
|
|
177
|
+
getSessionByTransportResourceId: (transportResourceId) => this.deps.snapshots.getSessionByTransportResourceId(transportResourceId)?.session ?? null,
|
|
76
178
|
getSessionById: (sessionId) => this.deps.snapshots.getSessionById(sessionId)?.session ?? null,
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
179
|
+
getPackageState: (key) => {
|
|
180
|
+
const row = this.deps.store.getPackageState(this.contextPackageId(actorId), key);
|
|
181
|
+
return row ? this.packageState(row.valueJson) : null;
|
|
182
|
+
},
|
|
183
|
+
putPackageState: async (key, value) => await this.deps.runGuardedAction({
|
|
184
|
+
action: 'package.state.write',
|
|
185
|
+
actor: actorId,
|
|
186
|
+
target: `${this.contextPackageId(actorId)}:${key}`,
|
|
187
|
+
title: 'Package state write blocked',
|
|
188
|
+
execute: async () => {
|
|
189
|
+
this.deps.store.putPackageState({
|
|
190
|
+
packageId: this.contextPackageId(actorId),
|
|
191
|
+
key,
|
|
192
|
+
valueJson: JSON.stringify(value),
|
|
193
|
+
updatedAt: this.deps.now()
|
|
194
|
+
});
|
|
195
|
+
}
|
|
84
196
|
}),
|
|
85
|
-
|
|
86
|
-
action: '
|
|
197
|
+
deletePackageState: async (key) => await this.deps.runGuardedAction({
|
|
198
|
+
action: 'package.state.write',
|
|
87
199
|
actor: actorId,
|
|
88
|
-
target:
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
missionId,
|
|
94
|
-
hookKey,
|
|
95
|
-
...(condition ? { condition } : {})
|
|
96
|
-
})
|
|
200
|
+
target: `${this.contextPackageId(actorId)}:${key}`,
|
|
201
|
+
title: 'Package state delete blocked',
|
|
202
|
+
execute: async () => {
|
|
203
|
+
this.deps.store.deletePackageState(this.contextPackageId(actorId), key);
|
|
204
|
+
}
|
|
97
205
|
}),
|
|
98
|
-
|
|
99
|
-
|
|
206
|
+
listPackageState: (prefix) => this.deps.store.listPackageState(this.contextPackageId(actorId), prefix).map((row) => ({
|
|
207
|
+
packageId: row.packageId,
|
|
208
|
+
key: row.key,
|
|
209
|
+
value: this.packageState(row.valueJson),
|
|
210
|
+
updatedAt: row.updatedAt
|
|
211
|
+
})),
|
|
212
|
+
schedulePackageJob: async ({ jobId, actionId, schedule, startTime, payload }) => await this.deps.runGuardedAction({
|
|
213
|
+
action: 'package.job.manage',
|
|
100
214
|
actor: actorId,
|
|
101
|
-
target:
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
215
|
+
target: `${this.contextPackageId(actorId)}:${jobId}`,
|
|
216
|
+
payload: { actionId, schedule },
|
|
217
|
+
title: 'Package job schedule blocked',
|
|
218
|
+
execute: async () => {
|
|
219
|
+
const nowIso = this.deps.now();
|
|
220
|
+
const parsed = parsePackageSchedule(schedule);
|
|
221
|
+
const anchor = parsePackageScheduleStartTime(startTime, nowIso);
|
|
222
|
+
const nextRunAt = computePackageJobRunAtOrAfterWithMeta(anchor, parsed.cadenceMinutes, nowIso, parsed.meta);
|
|
223
|
+
const row = {
|
|
224
|
+
packageId: this.contextPackageId(actorId),
|
|
225
|
+
jobId,
|
|
226
|
+
actionId,
|
|
227
|
+
schedule: parsed.normalized,
|
|
228
|
+
scheduleAnchorAt: anchor,
|
|
229
|
+
cadenceMinutes: parsed.cadenceMinutes,
|
|
230
|
+
scheduleMetaJson: packageScheduleMetaToJson(parsed.meta),
|
|
231
|
+
payloadJson: JSON.stringify(payload ?? {}),
|
|
232
|
+
nextRunAt,
|
|
233
|
+
createdAt: this.deps.store.getPackageJob(this.contextPackageId(actorId), jobId)?.createdAt ?? nowIso,
|
|
234
|
+
updatedAt: nowIso
|
|
235
|
+
};
|
|
236
|
+
this.deps.store.upsertPackageJob(row);
|
|
237
|
+
return {
|
|
238
|
+
packageId: row.packageId,
|
|
239
|
+
jobId: row.jobId,
|
|
240
|
+
actionId: row.actionId,
|
|
241
|
+
schedule: row.schedule,
|
|
242
|
+
scheduleAnchorAt: row.scheduleAnchorAt,
|
|
243
|
+
nextRunAt: row.nextRunAt,
|
|
244
|
+
payload: payload ?? {},
|
|
245
|
+
createdAt: row.createdAt,
|
|
246
|
+
updatedAt: row.updatedAt
|
|
247
|
+
};
|
|
248
|
+
}
|
|
107
249
|
}),
|
|
108
|
-
|
|
109
|
-
action: '
|
|
250
|
+
cancelPackageJob: async (jobId) => await this.deps.runGuardedAction({
|
|
251
|
+
action: 'package.job.manage',
|
|
110
252
|
actor: actorId,
|
|
111
|
-
target:
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
253
|
+
target: `${this.contextPackageId(actorId)}:${jobId}`,
|
|
254
|
+
title: 'Package job cancel blocked',
|
|
255
|
+
execute: async () => {
|
|
256
|
+
const row = this.deps.store.deletePackageJob(this.contextPackageId(actorId), jobId);
|
|
257
|
+
return row
|
|
258
|
+
? {
|
|
259
|
+
packageId: row.packageId,
|
|
260
|
+
jobId: row.jobId,
|
|
261
|
+
actionId: row.actionId,
|
|
262
|
+
schedule: row.schedule,
|
|
263
|
+
scheduleAnchorAt: row.scheduleAnchorAt,
|
|
264
|
+
nextRunAt: row.nextRunAt,
|
|
265
|
+
payload: this.packageState(row.payloadJson) ?? {},
|
|
266
|
+
createdAt: row.createdAt,
|
|
267
|
+
updatedAt: row.updatedAt
|
|
268
|
+
}
|
|
269
|
+
: null;
|
|
270
|
+
}
|
|
271
|
+
}),
|
|
272
|
+
listPackageJobs: () => this.deps.store.listPackageJobs(this.contextPackageId(actorId)).map((row) => ({
|
|
273
|
+
packageId: row.packageId,
|
|
274
|
+
jobId: row.jobId,
|
|
275
|
+
actionId: row.actionId,
|
|
276
|
+
schedule: row.schedule,
|
|
277
|
+
scheduleAnchorAt: row.scheduleAnchorAt,
|
|
278
|
+
nextRunAt: row.nextRunAt,
|
|
279
|
+
payload: this.packageState(row.payloadJson) ?? {},
|
|
280
|
+
createdAt: row.createdAt,
|
|
281
|
+
updatedAt: row.updatedAt
|
|
282
|
+
})),
|
|
283
|
+
enqueueWorkItem: async ({ queue, workItemId, idempotencyKey, externalResource, payload, priority, runAfter, maxAttempts }) => await this.deps.runGuardedAction({
|
|
284
|
+
action: 'package.work.manage',
|
|
285
|
+
actor: actorId,
|
|
286
|
+
target: `${this.contextPackageId(actorId)}:${queue}`,
|
|
287
|
+
payload: { idempotencyKey, externalResource },
|
|
288
|
+
title: 'Package work enqueue blocked',
|
|
289
|
+
execute: async () => {
|
|
290
|
+
const packageId = this.contextPackageId(actorId);
|
|
291
|
+
const normalizedQueue = queue.trim();
|
|
292
|
+
if (!normalizedQueue) {
|
|
293
|
+
throw new Error('Work item queue is required.');
|
|
294
|
+
}
|
|
295
|
+
const nowIso = this.deps.now();
|
|
296
|
+
if (externalResource) {
|
|
297
|
+
this.deps.store.upsertExternalResource({ ...externalResource, nowIso });
|
|
298
|
+
}
|
|
299
|
+
const record = this.deps.store.enqueueWorkItem({
|
|
300
|
+
workItemId: workItemId?.trim() || randomUUID(),
|
|
301
|
+
packageId,
|
|
302
|
+
queue: normalizedQueue,
|
|
303
|
+
status: 'queued',
|
|
304
|
+
priority: Number.isFinite(priority) ? Math.trunc(priority ?? 0) : 0,
|
|
305
|
+
...(idempotencyKey ? { idempotencyKey } : {}),
|
|
306
|
+
...(externalResource ? { externalResource } : {}),
|
|
307
|
+
payload: payload ?? {},
|
|
308
|
+
attempts: 0,
|
|
309
|
+
maxAttempts: Math.max(1, Math.trunc(maxAttempts ?? 3)),
|
|
310
|
+
runAfter: runAfter ?? null,
|
|
311
|
+
leaseOwner: null,
|
|
312
|
+
leaseExpiresAt: null,
|
|
313
|
+
lastError: null,
|
|
314
|
+
createdAt: nowIso,
|
|
315
|
+
updatedAt: nowIso,
|
|
316
|
+
completedAt: null
|
|
317
|
+
});
|
|
318
|
+
this.deps.appendAuditEvent('work_item.enqueued', {
|
|
319
|
+
actorId,
|
|
320
|
+
packageId,
|
|
321
|
+
workItemId: record.workItemId,
|
|
322
|
+
queue: record.queue,
|
|
323
|
+
idempotencyKey: record.idempotencyKey
|
|
324
|
+
});
|
|
325
|
+
this.deps.recordRuntimeActivity({
|
|
326
|
+
threadId: 'runtime:work',
|
|
327
|
+
sessionId: null,
|
|
328
|
+
transportResourceId: null,
|
|
329
|
+
sourceEventId: randomUUID(),
|
|
330
|
+
kind: 'work_item.queued',
|
|
331
|
+
severity: 'info',
|
|
332
|
+
title: 'Work item queued',
|
|
333
|
+
detail: `${record.packageId}/${record.queue}/${record.workItemId}`,
|
|
334
|
+
createdAt: nowIso
|
|
335
|
+
});
|
|
336
|
+
return record;
|
|
337
|
+
}
|
|
338
|
+
}),
|
|
339
|
+
claimWorkItem: async ({ queue, leaseSeconds, leaseOwner }) => await this.deps.runGuardedAction({
|
|
340
|
+
action: 'package.work.manage',
|
|
341
|
+
actor: actorId,
|
|
342
|
+
target: `${this.contextPackageId(actorId)}:${queue}`,
|
|
343
|
+
title: 'Package work claim blocked',
|
|
344
|
+
execute: async () => {
|
|
345
|
+
const now = new Date(this.deps.now());
|
|
346
|
+
const leaseMs = Math.max(1, leaseSeconds ?? 300) * 1000;
|
|
347
|
+
const claimed = this.deps.store.claimWorkItem({
|
|
348
|
+
packageId: this.contextPackageId(actorId),
|
|
349
|
+
queue,
|
|
350
|
+
leaseOwner: leaseOwner?.trim() || actorId,
|
|
351
|
+
leaseExpiresAt: new Date(now.getTime() + leaseMs).toISOString(),
|
|
352
|
+
nowIso: now.toISOString()
|
|
353
|
+
});
|
|
354
|
+
if (claimed) {
|
|
355
|
+
this.deps.appendAuditEvent('work_item.claimed', {
|
|
356
|
+
actorId,
|
|
357
|
+
packageId: claimed.packageId,
|
|
358
|
+
workItemId: claimed.workItemId,
|
|
359
|
+
queue: claimed.queue,
|
|
360
|
+
attempts: claimed.attempts
|
|
361
|
+
});
|
|
362
|
+
this.deps.recordRuntimeActivity({
|
|
363
|
+
...this.activityTargetForSession(claimed.sessionId, 'runtime:work'),
|
|
364
|
+
sourceEventId: randomUUID(),
|
|
365
|
+
kind: 'work_item.claimed',
|
|
366
|
+
severity: 'info',
|
|
367
|
+
title: 'Work item claimed',
|
|
368
|
+
detail: `${claimed.packageId}/${claimed.queue}/${claimed.workItemId}`,
|
|
369
|
+
createdAt: now.toISOString()
|
|
370
|
+
});
|
|
371
|
+
}
|
|
372
|
+
return claimed;
|
|
373
|
+
}
|
|
374
|
+
}),
|
|
375
|
+
completeWorkItem: async ({ workItemId, phase }) => await this.deps.runGuardedAction({
|
|
376
|
+
action: 'package.work.manage',
|
|
377
|
+
actor: actorId,
|
|
378
|
+
target: workItemId,
|
|
379
|
+
title: 'Package work complete blocked',
|
|
380
|
+
execute: async () => this.transitionWorkItem(actorId, workItemId, (current, nowIso) => ({
|
|
381
|
+
...current,
|
|
382
|
+
status: 'completed',
|
|
383
|
+
...(phase ? { phase } : {}),
|
|
384
|
+
leaseOwner: null,
|
|
385
|
+
leaseExpiresAt: null,
|
|
386
|
+
lastError: null,
|
|
387
|
+
updatedAt: nowIso,
|
|
388
|
+
completedAt: nowIso
|
|
389
|
+
}))
|
|
390
|
+
}),
|
|
391
|
+
failWorkItem: async ({ workItemId, error, retryAfter, phase }) => await this.deps.runGuardedAction({
|
|
392
|
+
action: 'package.work.manage',
|
|
393
|
+
actor: actorId,
|
|
394
|
+
target: workItemId,
|
|
395
|
+
title: 'Package work fail blocked',
|
|
396
|
+
execute: async () => this.transitionWorkItem(actorId, workItemId, (current, nowIso) => {
|
|
397
|
+
const shouldRetry = retryAfter !== undefined && current.attempts < current.maxAttempts;
|
|
398
|
+
return {
|
|
399
|
+
...current,
|
|
400
|
+
status: shouldRetry ? 'queued' : 'failed',
|
|
401
|
+
...(phase ? { phase } : {}),
|
|
402
|
+
runAfter: shouldRetry ? retryAfter : current.runAfter,
|
|
403
|
+
leaseOwner: null,
|
|
404
|
+
leaseExpiresAt: null,
|
|
405
|
+
lastError: error,
|
|
406
|
+
updatedAt: nowIso,
|
|
407
|
+
completedAt: shouldRetry ? null : nowIso
|
|
408
|
+
};
|
|
119
409
|
})
|
|
120
410
|
}),
|
|
121
|
-
|
|
411
|
+
deadLetterWorkItem: async ({ workItemId, reason, phase }) => await this.deps.runGuardedAction({
|
|
412
|
+
action: 'package.work.manage',
|
|
413
|
+
actor: actorId,
|
|
414
|
+
target: workItemId,
|
|
415
|
+
title: 'Package work dead-letter blocked',
|
|
416
|
+
execute: async () => this.transitionWorkItem(actorId, workItemId, (current, nowIso) => ({
|
|
417
|
+
...current,
|
|
418
|
+
status: 'dead_lettered',
|
|
419
|
+
...(phase ? { phase } : {}),
|
|
420
|
+
leaseOwner: null,
|
|
421
|
+
leaseExpiresAt: null,
|
|
422
|
+
lastError: reason,
|
|
423
|
+
updatedAt: nowIso,
|
|
424
|
+
completedAt: nowIso
|
|
425
|
+
}))
|
|
426
|
+
}),
|
|
427
|
+
updateWorkItem: async ({ workItemId, payload, phase, externalResource, sessionId }) => await this.deps.runGuardedAction({
|
|
428
|
+
action: 'package.work.manage',
|
|
429
|
+
actor: actorId,
|
|
430
|
+
target: workItemId,
|
|
431
|
+
title: 'Package work update blocked',
|
|
432
|
+
execute: async () => {
|
|
433
|
+
if (sessionId) {
|
|
434
|
+
this.requireSession(sessionId);
|
|
435
|
+
}
|
|
436
|
+
return this.transitionWorkItem(actorId, workItemId, (current, nowIso) => ({
|
|
437
|
+
...current,
|
|
438
|
+
...(payload ? { payload } : {}),
|
|
439
|
+
...(phase ? { phase } : {}),
|
|
440
|
+
...(externalResource ? { externalResource } : {}),
|
|
441
|
+
...(sessionId ? { sessionId } : {}),
|
|
442
|
+
updatedAt: nowIso
|
|
443
|
+
}));
|
|
444
|
+
}
|
|
445
|
+
}),
|
|
446
|
+
getWorkItem: (workItemId) => {
|
|
447
|
+
const record = this.deps.store.getWorkItem(workItemId);
|
|
448
|
+
return record?.packageId === this.contextPackageId(actorId) ? record : null;
|
|
449
|
+
},
|
|
450
|
+
listWorkItems: (filter) => this.deps.store.listWorkItems({
|
|
451
|
+
packageId: this.contextPackageId(actorId),
|
|
452
|
+
queue: filter?.queue,
|
|
453
|
+
status: filter?.status,
|
|
454
|
+
externalResource: filter?.externalResource,
|
|
455
|
+
limit: filter?.limit
|
|
456
|
+
}),
|
|
457
|
+
upsertExternalResource: async (input) => await this.deps.runGuardedAction({
|
|
458
|
+
action: 'package.work.manage',
|
|
459
|
+
actor: actorId,
|
|
460
|
+
target: `${input.provider}:${input.kind}:${input.id}`,
|
|
461
|
+
title: 'External resource update blocked',
|
|
462
|
+
execute: async () => this.deps.store.upsertExternalResource({ ...input, nowIso: this.deps.now() })
|
|
463
|
+
}),
|
|
464
|
+
listExternalResources: (filter) => this.deps.store.listExternalResources(filter),
|
|
465
|
+
bindSessionToExternalResource: async ({ sessionId, externalResource, relationship }) => await this.deps.runGuardedAction({
|
|
466
|
+
action: 'package.work.manage',
|
|
467
|
+
actor: actorId,
|
|
468
|
+
target: `${sessionId}:${externalResource.provider}:${externalResource.kind}:${externalResource.id}`,
|
|
469
|
+
title: 'Session resource binding blocked',
|
|
470
|
+
execute: async () => {
|
|
471
|
+
this.requireSession(sessionId);
|
|
472
|
+
this.deps.store.upsertExternalResource({ ...externalResource, nowIso: this.deps.now() });
|
|
473
|
+
this.deps.store.bindSessionToExternalResource({
|
|
474
|
+
sessionId,
|
|
475
|
+
resource: externalResource,
|
|
476
|
+
relationship: relationship?.trim() || 'source',
|
|
477
|
+
nowIso: this.deps.now()
|
|
478
|
+
});
|
|
479
|
+
}
|
|
480
|
+
}),
|
|
481
|
+
listSessionsForExternalResource: (resource) => {
|
|
482
|
+
const ids = new Set(this.deps.store.listSessionIdsForExternalResource(resource));
|
|
483
|
+
return this.deps.snapshots.listSessions().filter((snapshot) => ids.has(snapshot.session.sessionId));
|
|
484
|
+
},
|
|
485
|
+
listPendingRequests: (transportResourceId) => this.deps.store.listPendingRequestsByTransportResource(transportResourceId).filter((request) => request.status === 'open'),
|
|
122
486
|
listRuntimeReceipts: () => this.deps.snapshots.overview().receipts,
|
|
123
487
|
listProviderConnections: () => this.deps.snapshots.overview().providers,
|
|
124
488
|
listRuntimeActivities: (threadId) => threadId ? this.deps.snapshots.getSessionByThreadId(threadId)?.recentActivities ?? [] : this.deps.activities.listRecent(25),
|
|
125
|
-
|
|
489
|
+
getSessionSnapshotByTransportResourceId: (transportResourceId) => this.deps.snapshots.getSessionByTransportResourceId(transportResourceId),
|
|
126
490
|
getSessionSnapshotById: (sessionId) => this.deps.snapshots.getSessionById(sessionId),
|
|
127
491
|
getRuntimeOverview: () => this.deps.snapshots.overview(),
|
|
128
492
|
querySessions: (filter) => this.deps.snapshots.querySessions(filter),
|
|
@@ -167,40 +531,40 @@ export class RuntimePluginContextService {
|
|
|
167
531
|
listDomainEvents: (threadId) => this.deps.store.listDomainEvents(threadId).map((row) => ({
|
|
168
532
|
eventId: row.eventId,
|
|
169
533
|
threadId: row.threadId,
|
|
170
|
-
|
|
534
|
+
transportResourceId: row.transportResourceId,
|
|
171
535
|
sessionId: row.sessionId,
|
|
172
536
|
sourceProviderEventId: row.sourceProviderEventId,
|
|
173
537
|
createdAt: row.createdAt,
|
|
174
538
|
type: row.type,
|
|
175
539
|
payload: JSON.parse(row.payloadJson)
|
|
176
540
|
})),
|
|
177
|
-
updateSessionSummary: async (
|
|
178
|
-
this.deps.sessionRegistry.updateSummary(
|
|
541
|
+
updateSessionSummary: async (transportResourceId, summary, nowIso) => {
|
|
542
|
+
this.deps.sessionRegistry.updateSummary(transportResourceId, summary, nowIso);
|
|
179
543
|
},
|
|
180
|
-
retrieveMemory: async ({ query, scopeId,
|
|
544
|
+
retrieveMemory: async ({ query, scopeId, transportResourceId, threadId, maxResults, enableRerank }) => this.deps.runGuardedAction({
|
|
181
545
|
action: 'memory.read',
|
|
182
546
|
actor: actorId,
|
|
183
|
-
target:
|
|
547
|
+
target: transportResourceId ? `${scopeId}:${transportResourceId}:${threadId ?? 'root'}` : scopeId,
|
|
184
548
|
payload: { query, maxResults, enableRerank },
|
|
185
549
|
title: 'Memory read blocked',
|
|
186
|
-
execute: async () => await retrieveFromMemoryWithSQLite(query, this.deps.runtimeRoot, { scopeId: scopeId,
|
|
550
|
+
execute: async () => await retrieveFromMemoryWithSQLite(query, this.deps.runtimeRoot, { scopeId: scopeId, transportResourceId: transportResourceId, threadId: threadId ?? null, projectKey: 'default' }, this.deps.sqlitePath, { maxResults, enableRerank })
|
|
187
551
|
}),
|
|
188
|
-
writeSessionMemory: async ({ scopeId,
|
|
552
|
+
writeSessionMemory: async ({ scopeId, transportResourceId, threadId, kind, content, sourceRefs }) => {
|
|
189
553
|
await this.deps.runGuardedAction({
|
|
190
554
|
action: kind === 'summary' ? 'memory.write' : 'fs.write',
|
|
191
555
|
actor: actorId,
|
|
192
|
-
target: `${scopeId}:${
|
|
556
|
+
target: `${scopeId}:${transportResourceId}:${threadId ?? 'root'}:${kind}`,
|
|
193
557
|
payload: { sourceRefs },
|
|
194
558
|
title: 'Session memory write blocked',
|
|
195
559
|
execute: async () => this.deps.memoryStore.writeSessionRecord({
|
|
196
560
|
scopeId: scopeId,
|
|
197
|
-
|
|
561
|
+
transportResourceId: transportResourceId,
|
|
198
562
|
threadId: threadId ?? null,
|
|
199
563
|
kind,
|
|
200
564
|
content,
|
|
201
565
|
sourceRefs
|
|
202
566
|
}).then(() => {
|
|
203
|
-
void refreshMemoryIndex(this.deps.runtimeRoot, { scopeId: scopeId,
|
|
567
|
+
void refreshMemoryIndex(this.deps.runtimeRoot, { scopeId: scopeId, transportResourceId: transportResourceId, threadId: threadId ?? null, projectKey: 'default' }, this.deps.sqlitePath);
|
|
204
568
|
})
|
|
205
569
|
});
|
|
206
570
|
},
|
|
@@ -228,7 +592,7 @@ export class RuntimePluginContextService {
|
|
|
228
592
|
})
|
|
229
593
|
});
|
|
230
594
|
},
|
|
231
|
-
createSession: async ({ requestedName, runtimeMode, initialInstruction, objective, owner, tags }) => {
|
|
595
|
+
createSession: async ({ requestedName, runtimeMode, initialInstruction, objective, owner, tags, externalResource, workItemId }) => {
|
|
232
596
|
const safeRuntimeMode = parseRuntimeModeName(runtimeMode, 'runtime_mode');
|
|
233
597
|
const created = await this.deps.workManagement.createManagedSession({
|
|
234
598
|
actorId,
|
|
@@ -239,84 +603,195 @@ export class RuntimePluginContextService {
|
|
|
239
603
|
owner,
|
|
240
604
|
tags
|
|
241
605
|
});
|
|
242
|
-
|
|
606
|
+
if (externalResource) {
|
|
607
|
+
this.deps.store.upsertExternalResource({ ...externalResource, nowIso: this.deps.now() });
|
|
608
|
+
this.deps.store.bindSessionToExternalResource({
|
|
609
|
+
sessionId: created.session.sessionId,
|
|
610
|
+
resource: externalResource,
|
|
611
|
+
relationship: 'source',
|
|
612
|
+
nowIso: this.deps.now()
|
|
613
|
+
});
|
|
614
|
+
}
|
|
615
|
+
if (workItemId) {
|
|
616
|
+
this.transitionWorkItem(actorId, workItemId, (current, nowIso) => ({
|
|
617
|
+
...current,
|
|
618
|
+
sessionId: created.session.sessionId,
|
|
619
|
+
...(externalResource ? { externalResource } : {}),
|
|
620
|
+
updatedAt: nowIso
|
|
621
|
+
}));
|
|
622
|
+
}
|
|
623
|
+
return { session: created.session, transportResourceId: created.transportResourceId };
|
|
243
624
|
},
|
|
244
|
-
|
|
625
|
+
runGate: async ({ gateId, command, args, cwd, required, workItemId, sessionId }) => await this.deps.runGuardedAction({
|
|
626
|
+
action: 'command.exec',
|
|
627
|
+
actor: actorId,
|
|
628
|
+
target: `${gateId}:${command}`,
|
|
629
|
+
payload: { args, cwd, required, workItemId, sessionId },
|
|
630
|
+
threadId: sessionId ? this.deps.store.getSession(sessionId)?.threadId : undefined,
|
|
631
|
+
title: 'Runtime gate blocked',
|
|
632
|
+
execute: async () => {
|
|
633
|
+
if (!this.deps.commandRunner) {
|
|
634
|
+
throw new Error('Runtime gates require a command runner.');
|
|
635
|
+
}
|
|
636
|
+
if (sessionId) {
|
|
637
|
+
this.requireSession(sessionId);
|
|
638
|
+
}
|
|
639
|
+
if (workItemId) {
|
|
640
|
+
this.requireOwnedWorkItem(actorId, workItemId);
|
|
641
|
+
}
|
|
642
|
+
const packageId = this.contextPackageId(actorId);
|
|
643
|
+
const startedAt = this.deps.now();
|
|
644
|
+
let gate = this.deps.store.upsertGateRun({
|
|
645
|
+
gateRunId: randomUUID(),
|
|
646
|
+
gateId,
|
|
647
|
+
packageId,
|
|
648
|
+
...(workItemId ? { workItemId } : {}),
|
|
649
|
+
...(sessionId ? { sessionId } : {}),
|
|
650
|
+
command,
|
|
651
|
+
args: args ?? [],
|
|
652
|
+
...(cwd ? { cwd } : {}),
|
|
653
|
+
required: required === true,
|
|
654
|
+
status: 'running',
|
|
655
|
+
exitCode: null,
|
|
656
|
+
stdout: '',
|
|
657
|
+
stderr: '',
|
|
658
|
+
startedAt,
|
|
659
|
+
completedAt: null
|
|
660
|
+
});
|
|
661
|
+
try {
|
|
662
|
+
const result = await this.deps.commandRunner.run(command, args ?? [], cwd);
|
|
663
|
+
gate = this.deps.store.upsertGateRun({
|
|
664
|
+
...gate,
|
|
665
|
+
status: result.exitCode === 0 ? 'passed' : 'failed',
|
|
666
|
+
exitCode: result.exitCode,
|
|
667
|
+
stdout: result.stdout,
|
|
668
|
+
stderr: result.stderr,
|
|
669
|
+
completedAt: this.deps.now()
|
|
670
|
+
});
|
|
671
|
+
this.deps.appendAuditEvent(result.exitCode === 0 ? 'runtime.gate.passed' : 'runtime.gate.failed', {
|
|
672
|
+
actorId,
|
|
673
|
+
packageId,
|
|
674
|
+
gateRunId: gate.gateRunId,
|
|
675
|
+
gateId,
|
|
676
|
+
workItemId,
|
|
677
|
+
sessionId,
|
|
678
|
+
exitCode: result.exitCode
|
|
679
|
+
});
|
|
680
|
+
this.deps.recordRuntimeActivity({
|
|
681
|
+
...this.activityTargetForSession(sessionId, 'runtime:gates'),
|
|
682
|
+
sourceEventId: gate.gateRunId,
|
|
683
|
+
kind: result.exitCode === 0 ? 'runtime.gate.passed' : 'runtime.gate.failed',
|
|
684
|
+
severity: result.exitCode === 0 ? 'info' : 'error',
|
|
685
|
+
title: result.exitCode === 0 ? 'Runtime gate passed' : 'Runtime gate failed',
|
|
686
|
+
detail: `${gate.gateId}: ${gate.command} ${(gate.args ?? []).join(' ')}`.trim(),
|
|
687
|
+
createdAt: gate.completedAt ?? this.deps.now()
|
|
688
|
+
});
|
|
689
|
+
return gate;
|
|
690
|
+
}
|
|
691
|
+
catch (error) {
|
|
692
|
+
this.deps.store.upsertGateRun({
|
|
693
|
+
...gate,
|
|
694
|
+
status: 'error',
|
|
695
|
+
exitCode: null,
|
|
696
|
+
stderr: error instanceof Error ? error.message : String(error),
|
|
697
|
+
completedAt: this.deps.now()
|
|
698
|
+
});
|
|
699
|
+
this.deps.recordRuntimeActivity({
|
|
700
|
+
...this.activityTargetForSession(sessionId, 'runtime:gates'),
|
|
701
|
+
sourceEventId: gate.gateRunId,
|
|
702
|
+
kind: 'runtime.gate.error',
|
|
703
|
+
severity: 'error',
|
|
704
|
+
title: 'Runtime gate errored',
|
|
705
|
+
detail: error instanceof Error ? error.message : String(error),
|
|
706
|
+
createdAt: this.deps.now()
|
|
707
|
+
});
|
|
708
|
+
throw error;
|
|
709
|
+
}
|
|
710
|
+
}
|
|
711
|
+
}),
|
|
712
|
+
runHeadless: async ({ requestedName, runtimeMode, prompt, objective, owner, tags, externalResource, workItemId, outputSchema, requireStructuredOutput }) => await this.deps.runGuardedAction({
|
|
713
|
+
action: 'provider.headless.run',
|
|
714
|
+
actor: actorId,
|
|
715
|
+
target: `${this.contextPackageId(actorId)}:${requestedName}`,
|
|
716
|
+
payload: { requestedName, runtimeMode, objective, owner, tags, externalResource, workItemId },
|
|
717
|
+
title: 'Headless provider run blocked',
|
|
718
|
+
execute: async () => {
|
|
719
|
+
const context = this.createContext(actorId);
|
|
720
|
+
// First-pass headless runs are session-backed, so provider execution uses the managed session workspace.
|
|
721
|
+
const created = await context.createSession({
|
|
722
|
+
requestedName,
|
|
723
|
+
runtimeMode,
|
|
724
|
+
objective,
|
|
725
|
+
owner,
|
|
726
|
+
tags,
|
|
727
|
+
externalResource,
|
|
728
|
+
workItemId
|
|
729
|
+
});
|
|
730
|
+
const reply = await context.runAgent({
|
|
731
|
+
surface: 'session',
|
|
732
|
+
transportResourceId: created.transportResourceId,
|
|
733
|
+
actorId,
|
|
734
|
+
actorLabel: this.contextPackageId(actorId),
|
|
735
|
+
message: prompt,
|
|
736
|
+
session: created.session,
|
|
737
|
+
cwd: created.session.workspacePath,
|
|
738
|
+
runtimeMode,
|
|
739
|
+
context: {
|
|
740
|
+
systemPromptSections: await this.loadSessionPromptSections(this.toInternalSessionRow(created.session))
|
|
741
|
+
},
|
|
742
|
+
promptSource: 'headless'
|
|
743
|
+
});
|
|
744
|
+
const text = reply.text ?? '';
|
|
745
|
+
let parsedOutput;
|
|
746
|
+
if (outputSchema || requireStructuredOutput) {
|
|
747
|
+
try {
|
|
748
|
+
parsedOutput = JSON.parse(text);
|
|
749
|
+
this.validateStructuredOutput(parsedOutput, outputSchema);
|
|
750
|
+
}
|
|
751
|
+
catch (error) {
|
|
752
|
+
if (requireStructuredOutput) {
|
|
753
|
+
throw error;
|
|
754
|
+
}
|
|
755
|
+
}
|
|
756
|
+
}
|
|
757
|
+
return {
|
|
758
|
+
session: created.session,
|
|
759
|
+
reply,
|
|
760
|
+
...(parsedOutput !== undefined ? { parsedOutput } : {})
|
|
761
|
+
};
|
|
762
|
+
}
|
|
763
|
+
}),
|
|
764
|
+
directSession: async ({ sessionId, transportResourceId, instruction, reason }) => await this.deps.workManagement.directManagedSession({
|
|
245
765
|
actorId,
|
|
246
766
|
sessionId,
|
|
247
|
-
|
|
767
|
+
transportResourceId: transportResourceId,
|
|
248
768
|
instruction,
|
|
249
769
|
reason
|
|
250
770
|
}),
|
|
251
|
-
|
|
771
|
+
resumeSession: async ({ transportResourceId, sessionId, reason }) => await this.deps.workManagement.resumeManagedSession({
|
|
252
772
|
actorId,
|
|
253
|
-
|
|
254
|
-
sessionId
|
|
773
|
+
transportResourceId,
|
|
774
|
+
sessionId,
|
|
775
|
+
reason
|
|
255
776
|
}),
|
|
256
|
-
|
|
777
|
+
archiveSession: async ({ transportResourceId, sessionId }) => await this.deps.workManagement.archiveManagedSession({
|
|
257
778
|
actorId,
|
|
258
|
-
|
|
779
|
+
transportResourceId: transportResourceId,
|
|
259
780
|
sessionId
|
|
260
781
|
}),
|
|
261
|
-
|
|
782
|
+
deleteArchivedSession: async ({ transportResourceId, sessionId }) => await this.deps.workManagement.deleteManagedSession({
|
|
262
783
|
actorId,
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
}),
|
|
266
|
-
deleteArchivedMission: async ({ spaceId, missionId }) => await this.deps.workManagement.deleteArchivedMission({
|
|
267
|
-
actorId,
|
|
268
|
-
spaceId: spaceId,
|
|
269
|
-
missionId
|
|
784
|
+
transportResourceId: transportResourceId,
|
|
785
|
+
sessionId
|
|
270
786
|
}),
|
|
271
|
-
|
|
787
|
+
archiveTransportResourceTarget: async ({ transportResourceId }) => await this.deps.workManagement.archiveResourceTarget({
|
|
272
788
|
actorId,
|
|
273
|
-
|
|
789
|
+
transportResourceId: transportResourceId
|
|
274
790
|
}),
|
|
275
|
-
|
|
791
|
+
deleteArchivedTransportResourceTarget: async ({ transportResourceId }) => await this.deps.workManagement.deleteArchivedResourceTarget({
|
|
276
792
|
actorId,
|
|
277
|
-
|
|
793
|
+
transportResourceId: transportResourceId
|
|
278
794
|
}),
|
|
279
|
-
createMission: async ({ title, goal, schedule, startTime, runtimeMode }) => {
|
|
280
|
-
const safeRuntimeMode = parseRuntimeModeName(runtimeMode, 'runtime_mode');
|
|
281
|
-
const created = await this.deps.workManagement.createMission({
|
|
282
|
-
actorId,
|
|
283
|
-
title,
|
|
284
|
-
goal,
|
|
285
|
-
schedule,
|
|
286
|
-
startTime,
|
|
287
|
-
runtimeMode: safeRuntimeMode
|
|
288
|
-
});
|
|
289
|
-
return { mission: created.mission, spaceId: created.spaceId };
|
|
290
|
-
},
|
|
291
|
-
pauseMission: async ({ spaceId, missionId }) => this.deps.workManagement.updateMissionLifecycle(actorId, { spaceId: spaceId, missionId }, 'pause'),
|
|
292
|
-
resumeMission: async ({ spaceId, missionId }) => this.deps.workManagement.updateMissionLifecycle(actorId, { spaceId: spaceId, missionId }, 'resume'),
|
|
293
|
-
stopMission: async ({ spaceId, missionId }) => this.deps.workManagement.updateMissionLifecycle(actorId, { spaceId: spaceId, missionId }, 'stop'),
|
|
294
|
-
runMissionNow: async ({ spaceId, missionId, requesterActorId }) => {
|
|
295
|
-
const mission = this.deps.workManagement.resolveMission({ spaceId, missionId });
|
|
296
|
-
if (!mission) {
|
|
297
|
-
return null;
|
|
298
|
-
}
|
|
299
|
-
await this.deps.runGuardedAction({
|
|
300
|
-
action: 'mission.control',
|
|
301
|
-
actor: actorId,
|
|
302
|
-
target: mission.missionId,
|
|
303
|
-
title: 'Mission control blocked',
|
|
304
|
-
execute: async () => undefined
|
|
305
|
-
});
|
|
306
|
-
if (mission.lifecycleStatus === 'draft' || mission.lifecycleStatus === 'stopped' || mission.completedAt || mission.archivedAt) {
|
|
307
|
-
throw new Error(`Mission ${mission.missionId} cannot be run because it is not fully configured or is stopped.`);
|
|
308
|
-
}
|
|
309
|
-
void this.deps.lifecycleService
|
|
310
|
-
.runMissionTurn(mission.missionId, 'manual', 'runtime:mission/manual', requesterActorId ?? null)
|
|
311
|
-
.catch((error) => {
|
|
312
|
-
this.deps.appendAuditEvent('mission.trigger.failed', {
|
|
313
|
-
missionId: mission.missionId,
|
|
314
|
-
actorId,
|
|
315
|
-
error: error instanceof Error ? error.message : String(error)
|
|
316
|
-
});
|
|
317
|
-
});
|
|
318
|
-
return this.deps.missionRegistry.getById(mission.missionId) ?? mission;
|
|
319
|
-
},
|
|
320
795
|
respondToRuntimeRequest: async ({ threadId, requestId, decision, requesterActor }) => {
|
|
321
796
|
await this.deps.resolvePendingRequest({
|
|
322
797
|
actorId,
|
|
@@ -444,69 +919,99 @@ export class RuntimePluginContextService {
|
|
|
444
919
|
}
|
|
445
920
|
return true;
|
|
446
921
|
}),
|
|
447
|
-
sendMessage: async (
|
|
448
|
-
await this.deps.postTransportMessage(actorId,
|
|
922
|
+
sendMessage: async (transportResourceId, payload) => {
|
|
923
|
+
await this.deps.postTransportMessage(actorId, transportResourceId, payload);
|
|
449
924
|
},
|
|
450
925
|
sendStatusUpdate: async (payload) => {
|
|
451
|
-
const
|
|
452
|
-
if (
|
|
453
|
-
await this.deps.postTransportMessage(actorId,
|
|
926
|
+
const surfaceState = this.deps.getSurfaceState();
|
|
927
|
+
if (surfaceState) {
|
|
928
|
+
await this.deps.postTransportMessage(actorId, surfaceState.statusResourceId ?? this.deps.config.transport.scopeId, payload);
|
|
454
929
|
}
|
|
455
930
|
},
|
|
456
931
|
appendAuditEvent: (event, payload) => {
|
|
457
932
|
this.deps.appendAuditEvent(event, payload);
|
|
458
933
|
},
|
|
459
934
|
nowIso: () => this.deps.now(),
|
|
460
|
-
runAgent: async ({ surface,
|
|
461
|
-
const
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
935
|
+
runAgent: async ({ surface, transportResourceId, actorId: promptActorId, actorLabel, message, attachments, session, cwd, runtimeMode, toolGrantIds, context: agentContext, agentKind, promptSource }) => {
|
|
936
|
+
const activeSession = session
|
|
937
|
+
? this.toInternalSessionRow(session)
|
|
938
|
+
: await this.deps.ensureCoordinationSession(transportResourceId, cwd ?? this.deps.coordinationWorkspacePath);
|
|
939
|
+
const effectiveAgentKind = agentKind ?? activeSession.agentKind ?? (session ? 'workspace' : 'ephemeral');
|
|
940
|
+
const contributions = await this.deps.getPluginHost().contributeAgentContext({
|
|
941
|
+
surface,
|
|
942
|
+
transportResourceId,
|
|
943
|
+
actorId: promptActorId,
|
|
944
|
+
actorLabel,
|
|
945
|
+
text: message,
|
|
946
|
+
attachments,
|
|
947
|
+
session
|
|
948
|
+
}, (pluginId) => this.createContext(`plugin:${pluginId}`));
|
|
949
|
+
const contributionSystemSections = contributions.flatMap((entry) => entry.systemPromptSections ?? []);
|
|
950
|
+
const contributionContext = contributions.flatMap((entry) => entry.perTurnContext ?? []);
|
|
951
|
+
const contributionGrantIds = contributions.flatMap((entry) => entry.toolGrantIds ?? []);
|
|
952
|
+
const policyGrants = this.deps.providerToolPolicy[effectiveAgentKind].grants ?? [];
|
|
953
|
+
const resources = this.buildProviderResourceBundle([
|
|
954
|
+
...(agentContext?.systemPromptSections ?? []),
|
|
955
|
+
...contributionSystemSections
|
|
956
|
+
]);
|
|
957
|
+
const providerContext = [
|
|
958
|
+
{
|
|
959
|
+
title: promptSource === 'orchestration' ? 'Orchestration instruction source' : 'Transport message source',
|
|
960
|
+
content: promptSource === 'orchestration'
|
|
961
|
+
? `${actorLabel} (${promptActorId})`
|
|
962
|
+
: describeTransportAuthor({
|
|
963
|
+
authorId: promptActorId,
|
|
964
|
+
authorUsername: actorLabel,
|
|
965
|
+
authorGlobalName: null,
|
|
966
|
+
authorDisplayName: actorLabel,
|
|
967
|
+
authorLabel: actorLabel
|
|
968
|
+
}),
|
|
969
|
+
source: 'moorline/runtime'
|
|
970
|
+
},
|
|
971
|
+
...((attachments ?? []).length > 0
|
|
972
|
+
? [{
|
|
973
|
+
title: 'Attachment summary',
|
|
974
|
+
content: `Attached image count: ${(attachments ?? []).length}`,
|
|
975
|
+
source: 'moorline/runtime'
|
|
976
|
+
}]
|
|
977
|
+
: []),
|
|
978
|
+
...(agentContext?.perTurnContext ?? []),
|
|
979
|
+
...contributionContext
|
|
980
|
+
];
|
|
981
|
+
const resolvedGrantIds = [
|
|
982
|
+
...(activeSession.toolGrantIds ?? []),
|
|
983
|
+
...policyGrants,
|
|
984
|
+
...(toolGrantIds ?? []),
|
|
985
|
+
...contributionGrantIds,
|
|
986
|
+
...(effectiveAgentKind === 'ephemeral' ? ['core.moorline_session'] : [])
|
|
472
987
|
];
|
|
473
|
-
const
|
|
474
|
-
const prompt = [
|
|
475
|
-
...promptSections,
|
|
476
|
-
'',
|
|
477
|
-
promptSource === 'orchestration'
|
|
478
|
-
? `Orchestration instruction from ${actorLabel} (${promptActorId}): ${text || '(no text content)'}`
|
|
479
|
-
: `Transport message from ${describeTransportAuthor({
|
|
480
|
-
authorId: promptActorId,
|
|
481
|
-
authorUsername: actorLabel,
|
|
482
|
-
authorGlobalName: null,
|
|
483
|
-
authorDisplayName: actorLabel,
|
|
484
|
-
authorLabel: actorLabel
|
|
485
|
-
})}: ${text || '(no text content)'}`,
|
|
486
|
-
...((attachments ?? []).length > 0 ? [`Attached image count: ${(attachments ?? []).length}`] : [])
|
|
487
|
-
].join('\n');
|
|
988
|
+
const providerTools = this.resolveProviderTools(effectiveAgentKind, resolvedGrantIds);
|
|
488
989
|
const providerImages = await this.deps.prepareProviderImages(activeSession.threadId, attachments);
|
|
489
990
|
const result = await this.deps.providerOrchestrator.runTurn({
|
|
490
991
|
actorId,
|
|
491
992
|
session: activeSession,
|
|
492
|
-
|
|
993
|
+
transportResourceId: transportResourceId,
|
|
493
994
|
surface,
|
|
494
|
-
promptContent:
|
|
995
|
+
promptContent: message,
|
|
495
996
|
promptSource,
|
|
496
997
|
authorId: promptActorId,
|
|
497
998
|
authorLabel: actorLabel,
|
|
498
999
|
providerInput: {
|
|
499
|
-
text:
|
|
500
|
-
...(providerImages && providerImages.length > 0 ? { images: providerImages } : {})
|
|
501
|
-
|
|
1000
|
+
text: message,
|
|
1001
|
+
...(providerImages && providerImages.length > 0 ? { images: providerImages } : {}),
|
|
1002
|
+
...(providerContext.length > 0 ? { context: providerContext } : {})
|
|
1003
|
+
},
|
|
1004
|
+
providerResources: resources,
|
|
1005
|
+
providerTools,
|
|
1006
|
+
providerToolExecutor: this.createProviderToolExecutor(providerTools)
|
|
502
1007
|
});
|
|
503
1008
|
const formattedResult = this.deps.normalizeReply(result.text || (result.attachments?.length ? '' : 'I could not finish that cleanly.'));
|
|
504
1009
|
await this.deps.getPluginHost().afterAgentResponse({
|
|
505
1010
|
surface,
|
|
506
|
-
|
|
1011
|
+
transportResourceId,
|
|
507
1012
|
actorId: promptActorId,
|
|
508
1013
|
actorLabel,
|
|
509
|
-
text,
|
|
1014
|
+
text: message,
|
|
510
1015
|
attachments,
|
|
511
1016
|
session,
|
|
512
1017
|
replyMessage: formattedResult
|
|
@@ -539,18 +1044,342 @@ export class RuntimePluginContextService {
|
|
|
539
1044
|
}
|
|
540
1045
|
return dynamicSections;
|
|
541
1046
|
}
|
|
542
|
-
|
|
1047
|
+
toInternalSessionRow(session) {
|
|
1048
|
+
return session;
|
|
1049
|
+
}
|
|
1050
|
+
buildProviderResourceBundle(systemPromptSections) {
|
|
1051
|
+
const skills = this.deps.skillRegistry.list().map((skill) => ({
|
|
1052
|
+
name: skill.name,
|
|
1053
|
+
description: skill.description,
|
|
1054
|
+
filePath: skill.path,
|
|
1055
|
+
baseDir: skill.path.replace(/[\\/]SKILL\.md$/, ''),
|
|
1056
|
+
metadata: skill.metadata
|
|
1057
|
+
}));
|
|
1058
|
+
return {
|
|
1059
|
+
systemPromptSections: systemPromptSections.map((section) => section.trim()).filter(Boolean),
|
|
1060
|
+
contextFiles: [],
|
|
1061
|
+
skills,
|
|
1062
|
+
promptTemplates: []
|
|
1063
|
+
};
|
|
1064
|
+
}
|
|
1065
|
+
coreSessionTool() {
|
|
1066
|
+
return {
|
|
1067
|
+
name: 'moorline_session',
|
|
1068
|
+
description: 'Inspect, query, create, direct, archive, or delete Moorline managed sessions.',
|
|
1069
|
+
inputSchema: {
|
|
1070
|
+
type: 'object',
|
|
1071
|
+
properties: {
|
|
1072
|
+
action: {
|
|
1073
|
+
type: 'string',
|
|
1074
|
+
enum: ['query', 'inspect', 'create', 'direct', 'archive', 'delete_archived']
|
|
1075
|
+
},
|
|
1076
|
+
session_id: { type: 'string' },
|
|
1077
|
+
transport_resource_id: { type: 'string' },
|
|
1078
|
+
requested_name: { type: 'string' },
|
|
1079
|
+
runtime_mode: { type: 'string' },
|
|
1080
|
+
instruction: { type: 'string' },
|
|
1081
|
+
objective: { type: 'string' },
|
|
1082
|
+
reason: { type: 'string' },
|
|
1083
|
+
include_archived: { type: 'boolean' },
|
|
1084
|
+
limit: { type: 'number' }
|
|
1085
|
+
},
|
|
1086
|
+
required: ['action'],
|
|
1087
|
+
additionalProperties: false
|
|
1088
|
+
},
|
|
1089
|
+
execute: async (input, context) => {
|
|
1090
|
+
const action = typeof input.action === 'string' ? input.action : '';
|
|
1091
|
+
const sessionId = typeof input.session_id === 'string' ? input.session_id.trim() : '';
|
|
1092
|
+
const transportResourceId = typeof input.transport_resource_id === 'string' ? input.transport_resource_id.trim() : '';
|
|
1093
|
+
switch (action) {
|
|
1094
|
+
case 'query': {
|
|
1095
|
+
return await this.deps.runGuardedAction({
|
|
1096
|
+
action: 'session.inspect',
|
|
1097
|
+
actor: context.actorId,
|
|
1098
|
+
target: 'sessions',
|
|
1099
|
+
title: 'Session query blocked',
|
|
1100
|
+
execute: async () => {
|
|
1101
|
+
const sessions = this.deps.snapshots.querySessions({
|
|
1102
|
+
includeArchived: input.include_archived === true,
|
|
1103
|
+
limit: typeof input.limit === 'number' ? input.limit : undefined
|
|
1104
|
+
});
|
|
1105
|
+
return {
|
|
1106
|
+
content: sessions.length === 0
|
|
1107
|
+
? 'No sessions matched.'
|
|
1108
|
+
: [
|
|
1109
|
+
'Sessions:',
|
|
1110
|
+
...sessions.map(({ session }) => [
|
|
1111
|
+
`- ${session.sessionId}`,
|
|
1112
|
+
`kind=${session.agentKind ?? 'workspace'}`,
|
|
1113
|
+
`lifecycle=${session.lifecycleStatus}`,
|
|
1114
|
+
`mode=${session.runtimeMode}`,
|
|
1115
|
+
`provider=${session.providerStatus}`,
|
|
1116
|
+
session.objective ? `objective=${session.objective}` : null
|
|
1117
|
+
].filter(Boolean).join(' | '))
|
|
1118
|
+
].join('\n')
|
|
1119
|
+
};
|
|
1120
|
+
}
|
|
1121
|
+
});
|
|
1122
|
+
}
|
|
1123
|
+
case 'inspect': {
|
|
1124
|
+
return await this.deps.runGuardedAction({
|
|
1125
|
+
action: 'session.inspect',
|
|
1126
|
+
actor: context.actorId,
|
|
1127
|
+
target: sessionId || transportResourceId || 'session',
|
|
1128
|
+
title: 'Session inspect blocked',
|
|
1129
|
+
execute: async () => {
|
|
1130
|
+
const snapshot = sessionId
|
|
1131
|
+
? this.deps.snapshots.getSessionById(sessionId)
|
|
1132
|
+
: transportResourceId
|
|
1133
|
+
? this.deps.snapshots.getSessionByTransportResourceId(transportResourceId)
|
|
1134
|
+
: null;
|
|
1135
|
+
return { content: snapshot ? JSON.stringify(snapshot, null, 2) : 'No matching session found.' };
|
|
1136
|
+
}
|
|
1137
|
+
});
|
|
1138
|
+
}
|
|
1139
|
+
case 'create': {
|
|
1140
|
+
const requestedName = typeof input.requested_name === 'string' ? input.requested_name.trim() : '';
|
|
1141
|
+
if (!requestedName)
|
|
1142
|
+
return { content: 'create error: requested_name is required.' };
|
|
1143
|
+
const runtimeMode = parseRuntimeModeName(input.runtime_mode, 'runtime_mode');
|
|
1144
|
+
return await this.deps.runGuardedAction({
|
|
1145
|
+
action: 'session.create',
|
|
1146
|
+
actor: context.actorId,
|
|
1147
|
+
target: requestedName,
|
|
1148
|
+
title: 'Session create blocked',
|
|
1149
|
+
execute: async () => {
|
|
1150
|
+
const created = await this.deps.workManagement.createManagedSession({
|
|
1151
|
+
actorId: 'runtime:provider/tool',
|
|
1152
|
+
requestedName,
|
|
1153
|
+
runtimeMode,
|
|
1154
|
+
objective: typeof input.objective === 'string' ? input.objective : undefined
|
|
1155
|
+
});
|
|
1156
|
+
return { content: `Created session ${created.session.sessionId} (${created.transportResourceId}).` };
|
|
1157
|
+
}
|
|
1158
|
+
});
|
|
1159
|
+
}
|
|
1160
|
+
case 'direct': {
|
|
1161
|
+
const instruction = typeof input.instruction === 'string' ? input.instruction.trim() : '';
|
|
1162
|
+
if (!instruction)
|
|
1163
|
+
return { content: 'direct error: instruction is required.' };
|
|
1164
|
+
return await this.deps.runGuardedAction({
|
|
1165
|
+
action: 'session.direct',
|
|
1166
|
+
actor: context.actorId,
|
|
1167
|
+
target: sessionId || transportResourceId || 'session',
|
|
1168
|
+
title: 'Session direct blocked',
|
|
1169
|
+
execute: async () => {
|
|
1170
|
+
const result = await this.deps.workManagement.directManagedSession({
|
|
1171
|
+
actorId: 'runtime:provider/tool',
|
|
1172
|
+
sessionId: sessionId || undefined,
|
|
1173
|
+
transportResourceId: transportResourceId || undefined,
|
|
1174
|
+
instruction,
|
|
1175
|
+
reason: typeof input.reason === 'string' ? input.reason : undefined
|
|
1176
|
+
});
|
|
1177
|
+
return { content: `Directed session ${result.session.sessionId}.\n${result.reply.text ?? ''}`.trim() };
|
|
1178
|
+
}
|
|
1179
|
+
});
|
|
1180
|
+
}
|
|
1181
|
+
case 'archive': {
|
|
1182
|
+
return await this.deps.runGuardedAction({
|
|
1183
|
+
action: 'session.archive',
|
|
1184
|
+
actor: context.actorId,
|
|
1185
|
+
target: sessionId || transportResourceId || 'session',
|
|
1186
|
+
title: 'Session archive blocked',
|
|
1187
|
+
execute: async () => {
|
|
1188
|
+
const archived = await this.deps.workManagement.archiveManagedSession({
|
|
1189
|
+
actorId: 'runtime:provider/tool',
|
|
1190
|
+
sessionId: sessionId || undefined,
|
|
1191
|
+
transportResourceId: transportResourceId || undefined
|
|
1192
|
+
});
|
|
1193
|
+
return { content: archived ? `Archived session ${archived.sessionId}.` : 'No matching session found.' };
|
|
1194
|
+
}
|
|
1195
|
+
});
|
|
1196
|
+
}
|
|
1197
|
+
case 'delete_archived': {
|
|
1198
|
+
return await this.deps.runGuardedAction({
|
|
1199
|
+
action: 'session.delete',
|
|
1200
|
+
actor: context.actorId,
|
|
1201
|
+
target: sessionId || transportResourceId || 'session',
|
|
1202
|
+
title: 'Session delete blocked',
|
|
1203
|
+
execute: async () => {
|
|
1204
|
+
const deleted = await this.deps.workManagement.deleteManagedSession({
|
|
1205
|
+
actorId: 'runtime:provider/tool',
|
|
1206
|
+
sessionId: sessionId || undefined,
|
|
1207
|
+
transportResourceId: transportResourceId || undefined
|
|
1208
|
+
});
|
|
1209
|
+
return { content: deleted ? `Deleted archived session ${deleted.sessionId}.` : 'No matching archived session found.' };
|
|
1210
|
+
}
|
|
1211
|
+
});
|
|
1212
|
+
}
|
|
1213
|
+
default:
|
|
1214
|
+
return { content: 'moorline_session error: unknown action.' };
|
|
1215
|
+
}
|
|
1216
|
+
}
|
|
1217
|
+
};
|
|
1218
|
+
}
|
|
1219
|
+
coreSkillLoadTool() {
|
|
1220
|
+
return {
|
|
1221
|
+
name: 'moorline_skill.load',
|
|
1222
|
+
description: 'Load a Moorline-managed skill by name.',
|
|
1223
|
+
requiredCapability: 'fs.read',
|
|
1224
|
+
inputSchema: {
|
|
1225
|
+
type: 'object',
|
|
1226
|
+
properties: {
|
|
1227
|
+
name: { type: 'string' }
|
|
1228
|
+
},
|
|
1229
|
+
required: ['name'],
|
|
1230
|
+
additionalProperties: false
|
|
1231
|
+
},
|
|
1232
|
+
execute: async (input) => {
|
|
1233
|
+
const name = typeof input.name === 'string' ? input.name.trim() : '';
|
|
1234
|
+
if (!name) {
|
|
1235
|
+
return { content: 'moorline_skill.load error: name is required.' };
|
|
1236
|
+
}
|
|
1237
|
+
const skill = await this.deps.skillRegistry.load(name);
|
|
1238
|
+
return {
|
|
1239
|
+
content: skill ? JSON.stringify(skill, null, 2) : `No matching skill found: ${name}`
|
|
1240
|
+
};
|
|
1241
|
+
}
|
|
1242
|
+
};
|
|
1243
|
+
}
|
|
1244
|
+
coreSkillSaveTool() {
|
|
1245
|
+
return {
|
|
1246
|
+
name: 'moorline_skill.save',
|
|
1247
|
+
description: 'Create or update a Moorline-managed runtime skill.',
|
|
1248
|
+
requiredCapability: 'fs.write',
|
|
1249
|
+
inputSchema: {
|
|
1250
|
+
type: 'object',
|
|
1251
|
+
properties: {
|
|
1252
|
+
name: { type: 'string' },
|
|
1253
|
+
description: { type: 'string' },
|
|
1254
|
+
tags: { type: 'array', items: { type: 'string' } },
|
|
1255
|
+
body: { type: 'string' },
|
|
1256
|
+
directory_name: { type: 'string' },
|
|
1257
|
+
resource_files: {
|
|
1258
|
+
type: 'array',
|
|
1259
|
+
items: {
|
|
1260
|
+
type: 'object',
|
|
1261
|
+
properties: {
|
|
1262
|
+
path: { type: 'string' },
|
|
1263
|
+
content: { type: 'string' }
|
|
1264
|
+
},
|
|
1265
|
+
required: ['path', 'content'],
|
|
1266
|
+
additionalProperties: false
|
|
1267
|
+
}
|
|
1268
|
+
}
|
|
1269
|
+
},
|
|
1270
|
+
required: ['name', 'body'],
|
|
1271
|
+
additionalProperties: false
|
|
1272
|
+
},
|
|
1273
|
+
execute: async (input, context) => {
|
|
1274
|
+
const name = typeof input.name === 'string' ? input.name.trim() : '';
|
|
1275
|
+
const body = typeof input.body === 'string' ? input.body : '';
|
|
1276
|
+
if (!name) {
|
|
1277
|
+
return { content: 'moorline_skill.save error: name is required.' };
|
|
1278
|
+
}
|
|
1279
|
+
if (!body.trim()) {
|
|
1280
|
+
return { content: 'moorline_skill.save error: body is required.' };
|
|
1281
|
+
}
|
|
1282
|
+
const resourceFiles = Array.isArray(input.resource_files)
|
|
1283
|
+
? input.resource_files
|
|
1284
|
+
.filter((entry) => !!entry && typeof entry === 'object' && !Array.isArray(entry))
|
|
1285
|
+
.map((entry) => ({
|
|
1286
|
+
path: typeof entry.path === 'string' ? entry.path : '',
|
|
1287
|
+
content: typeof entry.content === 'string' ? entry.content : ''
|
|
1288
|
+
}))
|
|
1289
|
+
: [];
|
|
1290
|
+
const written = writeSkill({
|
|
1291
|
+
rootDir: join(this.deps.runtimeRoot, 'packages', 'skills'),
|
|
1292
|
+
name,
|
|
1293
|
+
description: typeof input.description === 'string' ? input.description : undefined,
|
|
1294
|
+
tags: Array.isArray(input.tags) ? input.tags.filter((tag) => typeof tag === 'string') : undefined,
|
|
1295
|
+
body,
|
|
1296
|
+
directoryName: typeof input.directory_name === 'string' ? input.directory_name : undefined,
|
|
1297
|
+
resourceFiles
|
|
1298
|
+
});
|
|
1299
|
+
this.deps.skillRegistry.invalidateCache();
|
|
1300
|
+
recordHistoryCheckpoint({
|
|
1301
|
+
homeRoot: this.deps.homeRoot,
|
|
1302
|
+
actor: context.actorId,
|
|
1303
|
+
reason: `Updated skill ${name}.`,
|
|
1304
|
+
operation: `provider tool write skill ${typeof input.directory_name === 'string' ? input.directory_name : name}`,
|
|
1305
|
+
absoluteTargets: [written.skillDir]
|
|
1306
|
+
});
|
|
1307
|
+
return { content: JSON.stringify(written, null, 2) };
|
|
1308
|
+
}
|
|
1309
|
+
};
|
|
1310
|
+
}
|
|
1311
|
+
allProviderRuntimeTools() {
|
|
543
1312
|
return [
|
|
544
|
-
|
|
545
|
-
|
|
546
|
-
|
|
547
|
-
|
|
548
|
-
`Mission workspace: ${mission.workspacePath}`,
|
|
549
|
-
`Runtime mode: ${mission.runtimeMode}`,
|
|
550
|
-
'Mission interactions are independent operator messages. Respond directly to the current message while using the persistent mission thread context when helpful.',
|
|
551
|
-
'Manual mission messages must not change or cancel the recurring mission schedule.'
|
|
1313
|
+
{ ...this.coreSessionTool(), pluginId: 'core' },
|
|
1314
|
+
{ ...this.coreSkillLoadTool(), pluginId: 'core' },
|
|
1315
|
+
{ ...this.coreSkillSaveTool(), pluginId: 'core' },
|
|
1316
|
+
...this.deps.getPluginHost().listTools((pluginId) => this.createContext(`plugin:${pluginId}`))
|
|
552
1317
|
];
|
|
553
1318
|
}
|
|
1319
|
+
toolId(tool) {
|
|
1320
|
+
return tool.pluginId === 'core' ? `core.${tool.name}` : `plugin:${tool.pluginId ?? 'unknown'}.${tool.name}`;
|
|
1321
|
+
}
|
|
1322
|
+
resolveProviderTools(agentKind, grantIds) {
|
|
1323
|
+
const grants = new Set(grantIds);
|
|
1324
|
+
if (agentKind === 'ephemeral') {
|
|
1325
|
+
grants.add('core.moorline_session');
|
|
1326
|
+
}
|
|
1327
|
+
return this.allProviderRuntimeTools()
|
|
1328
|
+
.filter((tool) => grants.has(this.toolId(tool)))
|
|
1329
|
+
.map((tool) => ({
|
|
1330
|
+
id: this.toolId(tool),
|
|
1331
|
+
name: tool.name,
|
|
1332
|
+
description: tool.description ?? tool.name,
|
|
1333
|
+
inputSchema: tool.inputSchema ?? { type: 'object', additionalProperties: true },
|
|
1334
|
+
...(tool.requiredCapability ? { requiredCapability: tool.requiredCapability } : {}),
|
|
1335
|
+
source: tool.pluginId === 'core' ? 'core' : 'plugin',
|
|
1336
|
+
...(tool.pluginId && tool.pluginId !== 'core' ? { ownerPackageId: tool.pluginId } : {})
|
|
1337
|
+
}));
|
|
1338
|
+
}
|
|
1339
|
+
createProviderToolExecutor(tools) {
|
|
1340
|
+
const allowed = new Set(tools.map((tool) => tool.id));
|
|
1341
|
+
return {
|
|
1342
|
+
executeProviderTool: async ({ toolId, arguments: args, actor }) => {
|
|
1343
|
+
if (!allowed.has(toolId)) {
|
|
1344
|
+
throw new Error(`Provider tool is not granted for this session: ${toolId}`);
|
|
1345
|
+
}
|
|
1346
|
+
const runtimeTool = this.allProviderRuntimeTools().find((tool) => this.toolId(tool) === toolId);
|
|
1347
|
+
if (!runtimeTool) {
|
|
1348
|
+
throw new Error(`Unknown provider tool: ${toolId}`);
|
|
1349
|
+
}
|
|
1350
|
+
const context = this.createContext(runtimeTool.pluginId && runtimeTool.pluginId !== 'core' ? `plugin:${runtimeTool.pluginId}` : actor);
|
|
1351
|
+
const run = async () => await runtimeTool.execute(args, context);
|
|
1352
|
+
try {
|
|
1353
|
+
const result = runtimeTool.requiredCapability
|
|
1354
|
+
? await this.deps.runGuardedAction({
|
|
1355
|
+
action: runtimeTool.requiredCapability,
|
|
1356
|
+
actor,
|
|
1357
|
+
target: toolId,
|
|
1358
|
+
title: 'Provider tool blocked',
|
|
1359
|
+
execute: run
|
|
1360
|
+
})
|
|
1361
|
+
: await run();
|
|
1362
|
+
this.deps.appendAuditEvent('provider.tool.executed', {
|
|
1363
|
+
actor,
|
|
1364
|
+
toolId,
|
|
1365
|
+
ownerPackageId: runtimeTool.pluginId ?? 'core',
|
|
1366
|
+
ok: true
|
|
1367
|
+
});
|
|
1368
|
+
return { content: result.content };
|
|
1369
|
+
}
|
|
1370
|
+
catch (error) {
|
|
1371
|
+
this.deps.appendAuditEvent('provider.tool.executed', {
|
|
1372
|
+
actor,
|
|
1373
|
+
toolId,
|
|
1374
|
+
ownerPackageId: runtimeTool.pluginId ?? 'core',
|
|
1375
|
+
ok: false,
|
|
1376
|
+
error: error instanceof Error ? error.message : String(error)
|
|
1377
|
+
});
|
|
1378
|
+
throw error;
|
|
1379
|
+
}
|
|
1380
|
+
}
|
|
1381
|
+
};
|
|
1382
|
+
}
|
|
554
1383
|
normalizePluginSidecarScope(scope) {
|
|
555
1384
|
if (scope.kind === 'session') {
|
|
556
1385
|
return {
|
|
@@ -564,7 +1393,7 @@ export class RuntimePluginContextService {
|
|
|
564
1393
|
const normalized = candidate.trim();
|
|
565
1394
|
const sessions = this.deps.sessionRegistry.list();
|
|
566
1395
|
const session = sessions.find((entry) => entry.sessionId === normalized) ??
|
|
567
|
-
sessions.find((entry) => entry.
|
|
1396
|
+
sessions.find((entry) => entry.transportResourceId === normalized) ??
|
|
568
1397
|
sessions.find((entry) => entry.threadId === normalized) ??
|
|
569
1398
|
null;
|
|
570
1399
|
if (!session) {
|