@panorama-ai/gateway 2.30.211 → 2.31.9

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (120) hide show
  1. package/README.md +59 -63
  2. package/dist/cli-args.d.ts +0 -2
  3. package/dist/cli-args.d.ts.map +1 -1
  4. package/dist/cli-args.js +0 -8
  5. package/dist/cli-args.js.map +1 -1
  6. package/dist/cli-providers/types.d.ts +1 -1
  7. package/dist/cli-providers/types.d.ts.map +1 -1
  8. package/dist/database.types.d.ts +1974 -1024
  9. package/dist/database.types.d.ts.map +1 -1
  10. package/dist/database.types.js.map +1 -1
  11. package/dist/drive-sync/config.d.ts +14 -0
  12. package/dist/drive-sync/config.d.ts.map +1 -0
  13. package/dist/drive-sync/config.js +45 -0
  14. package/dist/drive-sync/config.js.map +1 -0
  15. package/dist/drive-sync/drive-sync-filesystem.d.ts +39 -0
  16. package/dist/drive-sync/drive-sync-filesystem.d.ts.map +1 -0
  17. package/dist/drive-sync/drive-sync-filesystem.js +434 -0
  18. package/dist/drive-sync/drive-sync-filesystem.js.map +1 -0
  19. package/dist/drive-sync/drive-sync-planner.d.ts +76 -0
  20. package/dist/drive-sync/drive-sync-planner.d.ts.map +1 -0
  21. package/dist/drive-sync/drive-sync-planner.js +363 -0
  22. package/dist/drive-sync/drive-sync-planner.js.map +1 -0
  23. package/dist/drive-sync/drive-sync-remote-planner.d.ts +52 -0
  24. package/dist/drive-sync/drive-sync-remote-planner.d.ts.map +1 -0
  25. package/dist/drive-sync/drive-sync-remote-planner.js +77 -0
  26. package/dist/drive-sync/drive-sync-remote-planner.js.map +1 -0
  27. package/dist/drive-sync/drive-sync-scheduler.d.ts +51 -0
  28. package/dist/drive-sync/drive-sync-scheduler.d.ts.map +1 -0
  29. package/dist/drive-sync/drive-sync-scheduler.js +304 -0
  30. package/dist/drive-sync/drive-sync-scheduler.js.map +1 -0
  31. package/dist/drive-sync/drive-sync-state-applier.d.ts +84 -0
  32. package/dist/drive-sync/drive-sync-state-applier.d.ts.map +1 -0
  33. package/dist/drive-sync/drive-sync-state-applier.js +153 -0
  34. package/dist/drive-sync/drive-sync-state-applier.js.map +1 -0
  35. package/dist/drive-sync/drive-sync-transfer.d.ts +86 -0
  36. package/dist/drive-sync/drive-sync-transfer.d.ts.map +1 -0
  37. package/dist/drive-sync/drive-sync-transfer.js +245 -0
  38. package/dist/drive-sync/drive-sync-transfer.js.map +1 -0
  39. package/dist/drive-sync/drive-sync.d.ts +433 -0
  40. package/dist/drive-sync/drive-sync.d.ts.map +1 -0
  41. package/dist/drive-sync/drive-sync.js +1677 -0
  42. package/dist/drive-sync/drive-sync.js.map +1 -0
  43. package/dist/{managed-runtime → drive-sync}/runtime-utils.d.ts +2 -2
  44. package/dist/drive-sync/runtime-utils.d.ts.map +1 -0
  45. package/dist/{managed-runtime → drive-sync}/runtime-utils.js +1 -1
  46. package/dist/drive-sync/runtime-utils.js.map +1 -0
  47. package/dist/finalize-subagent-run.d.ts +2 -1
  48. package/dist/finalize-subagent-run.d.ts.map +1 -1
  49. package/dist/finalize-subagent-run.js.map +1 -1
  50. package/dist/gateway-local-runtime.d.ts +7 -1
  51. package/dist/gateway-local-runtime.d.ts.map +1 -1
  52. package/dist/gateway-local-runtime.js +26 -5
  53. package/dist/gateway-local-runtime.js.map +1 -1
  54. package/dist/gateway-state.d.ts +4 -0
  55. package/dist/gateway-state.d.ts.map +1 -1
  56. package/dist/gateway-state.js +6 -2
  57. package/dist/gateway-state.js.map +1 -1
  58. package/dist/index.js +4102 -2409
  59. package/dist/index.js.map +4 -4
  60. package/dist/local-runtime/drive-sync-supervisor.d.ts +14 -0
  61. package/dist/local-runtime/drive-sync-supervisor.d.ts.map +1 -0
  62. package/dist/local-runtime/drive-sync-supervisor.js +79 -0
  63. package/dist/local-runtime/drive-sync-supervisor.js.map +1 -0
  64. package/dist/local-runtime/shutdown-supervisor.d.ts +1 -0
  65. package/dist/local-runtime/shutdown-supervisor.d.ts.map +1 -1
  66. package/dist/local-runtime/shutdown-supervisor.js +5 -2
  67. package/dist/local-runtime/shutdown-supervisor.js.map +1 -1
  68. package/dist/subagent-adapters/types.d.ts +1 -1
  69. package/dist/subagent-adapters/types.d.ts.map +1 -1
  70. package/dist/subagent-output-persistence.d.ts +1 -1
  71. package/dist/subagent-output-persistence.d.ts.map +1 -1
  72. package/dist/subagent-output-persistence.js +1 -1
  73. package/dist/subagent-output-persistence.js.map +1 -1
  74. package/package.json +6 -6
  75. package/dist/managed-runtime/config.d.ts +0 -20
  76. package/dist/managed-runtime/config.d.ts.map +0 -1
  77. package/dist/managed-runtime/config.js +0 -80
  78. package/dist/managed-runtime/config.js.map +0 -1
  79. package/dist/managed-runtime/control-client.d.ts +0 -66
  80. package/dist/managed-runtime/control-client.d.ts.map +0 -1
  81. package/dist/managed-runtime/control-client.js +0 -142
  82. package/dist/managed-runtime/control-client.js.map +0 -1
  83. package/dist/managed-runtime/dependencies.d.ts +0 -17
  84. package/dist/managed-runtime/dependencies.d.ts.map +0 -1
  85. package/dist/managed-runtime/dependencies.js +0 -28
  86. package/dist/managed-runtime/dependencies.js.map +0 -1
  87. package/dist/managed-runtime/execution-dispatcher.d.ts +0 -25
  88. package/dist/managed-runtime/execution-dispatcher.d.ts.map +0 -1
  89. package/dist/managed-runtime/execution-dispatcher.js +0 -155
  90. package/dist/managed-runtime/execution-dispatcher.js.map +0 -1
  91. package/dist/managed-runtime/heartbeat.d.ts +0 -7
  92. package/dist/managed-runtime/heartbeat.d.ts.map +0 -1
  93. package/dist/managed-runtime/heartbeat.js +0 -44
  94. package/dist/managed-runtime/heartbeat.js.map +0 -1
  95. package/dist/managed-runtime/host-state.d.ts +0 -15
  96. package/dist/managed-runtime/host-state.d.ts.map +0 -1
  97. package/dist/managed-runtime/host-state.js +0 -50
  98. package/dist/managed-runtime/host-state.js.map +0 -1
  99. package/dist/managed-runtime/realtime.d.ts +0 -25
  100. package/dist/managed-runtime/realtime.d.ts.map +0 -1
  101. package/dist/managed-runtime/realtime.js +0 -189
  102. package/dist/managed-runtime/realtime.js.map +0 -1
  103. package/dist/managed-runtime/runtime-utils.d.ts.map +0 -1
  104. package/dist/managed-runtime/runtime-utils.js.map +0 -1
  105. package/dist/managed-runtime/shell-execution.d.ts +0 -33
  106. package/dist/managed-runtime/shell-execution.d.ts.map +0 -1
  107. package/dist/managed-runtime/shell-execution.js +0 -186
  108. package/dist/managed-runtime/shell-execution.js.map +0 -1
  109. package/dist/managed-runtime/step-result.d.ts +0 -22
  110. package/dist/managed-runtime/step-result.d.ts.map +0 -1
  111. package/dist/managed-runtime/step-result.js +0 -252
  112. package/dist/managed-runtime/step-result.js.map +0 -1
  113. package/dist/managed-runtime/wake-signal.d.ts +0 -5
  114. package/dist/managed-runtime/wake-signal.d.ts.map +0 -1
  115. package/dist/managed-runtime/wake-signal.js +0 -29
  116. package/dist/managed-runtime/wake-signal.js.map +0 -1
  117. package/dist/managed-runtime.d.ts +0 -8
  118. package/dist/managed-runtime.d.ts.map +0 -1
  119. package/dist/managed-runtime.js +0 -224
  120. package/dist/managed-runtime.js.map +0 -1
@@ -1,28 +0,0 @@
1
- import { completeLinuxExecution, dispatchLinuxExecution, heartbeatLinuxHost, reconcileExecutionLifecycle, startLinuxExecution, } from './control-client.js';
2
- import { createManagedRealtimeClient, startManagedRealtimeWakeLoop } from './realtime.js';
3
- import { executeCommand } from './shell-execution.js';
4
- const defaultManagedGatewayRuntimeDependencies = {
5
- heartbeatLinuxHost,
6
- dispatchLinuxExecution,
7
- startLinuxExecution,
8
- completeLinuxExecution,
9
- reconcileExecutionLifecycle,
10
- executeCommand,
11
- createRealtimeClient: createManagedRealtimeClient,
12
- startRealtimeWakeLoop: startManagedRealtimeWakeLoop,
13
- registerSignalHandlers(onSignal) {
14
- process.once('SIGINT', onSignal);
15
- process.once('SIGTERM', onSignal);
16
- return () => {
17
- process.off('SIGINT', onSignal);
18
- process.off('SIGTERM', onSignal);
19
- };
20
- },
21
- };
22
- export function resolveManagedGatewayRuntimeDependencies(dependencies = {}) {
23
- return {
24
- ...defaultManagedGatewayRuntimeDependencies,
25
- ...dependencies,
26
- };
27
- }
28
- //# sourceMappingURL=dependencies.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"dependencies.js","sourceRoot":"","sources":["../../src/managed-runtime/dependencies.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,sBAAsB,EACtB,sBAAsB,EACtB,kBAAkB,EAClB,2BAA2B,EAC3B,mBAAmB,GACpB,MAAM,qBAAqB,CAAA;AAC5B,OAAO,EAAE,2BAA2B,EAAE,4BAA4B,EAAE,MAAM,eAAe,CAAA;AACzF,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAA;AAgBrD,MAAM,wCAAwC,GAA8C;IAC1F,kBAAkB;IAClB,sBAAsB;IACtB,mBAAmB;IACnB,sBAAsB;IACtB,2BAA2B;IAC3B,cAAc;IACd,oBAAoB,EAAE,2BAA2B;IACjD,qBAAqB,EAAE,4BAA4B;IACnD,sBAAsB,CAAC,QAAQ;QAC7B,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAA;QAChC,OAAO,CAAC,IAAI,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAA;QACjC,OAAO,GAAG,EAAE;YACV,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAA;YAC/B,OAAO,CAAC,GAAG,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAA;QAClC,CAAC,CAAA;IACH,CAAC;CACF,CAAA;AAED,MAAM,UAAU,wCAAwC,CACtD,eAAkD,EAAE;IAEpD,OAAO;QACL,GAAG,wCAAwC;QAC3C,GAAG,YAAY;KAChB,CAAA;AACH,CAAC"}
@@ -1,25 +0,0 @@
1
- import type { ControlSignal } from '@panorama/shared/control-signals';
2
- import type { LinuxHostClaimedExecution } from '@panorama/shared/linux-host-control/contract';
3
- import type { ManagedGatewayRuntimeConfig } from './config.js';
4
- import type { completeLinuxExecution, startLinuxExecution } from './control-client.js';
5
- import { executeCommand, type CommandExecutionResult } from './shell-execution.js';
6
- import { type LinuxExecutionCompletion } from './step-result.js';
7
- export type ManagedExecutionOutcome = {
8
- reconciliationRequired: boolean;
9
- wakeReason?: string;
10
- };
11
- export interface ExecuteManagedLinuxExecutionDependencies {
12
- startLinuxExecution: typeof startLinuxExecution;
13
- completeLinuxExecution: typeof completeLinuxExecution;
14
- executeCommand: typeof executeCommand;
15
- }
16
- export declare function resolveLinuxExecutionCompletion(result: CommandExecutionResult, controlSignal: ControlSignal | null): LinuxExecutionCompletion;
17
- export declare function executeManagedLinuxExecution(params: {
18
- config: ManagedGatewayRuntimeConfig;
19
- execution: LinuxHostClaimedExecution;
20
- registerCancellation: (cancel: (() => void) | null) => void;
21
- onExecutionStarted?: (executionId: string) => void;
22
- onExecutionFinished?: () => void;
23
- dependencies: ExecuteManagedLinuxExecutionDependencies;
24
- }): Promise<ManagedExecutionOutcome>;
25
- //# sourceMappingURL=execution-dispatcher.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"execution-dispatcher.d.ts","sourceRoot":"","sources":["../../src/managed-runtime/execution-dispatcher.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,kCAAkC,CAAA;AACrE,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,8CAA8C,CAAA;AAE7F,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,aAAa,CAAA;AAC9D,OAAO,KAAK,EAAE,sBAAsB,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAA;AACtF,OAAO,EAGL,cAAc,EAEd,KAAK,sBAAsB,EAC5B,MAAM,sBAAsB,CAAA;AAC7B,OAAO,EAIL,KAAK,wBAAwB,EAC9B,MAAM,kBAAkB,CAAA;AAGzB,MAAM,MAAM,uBAAuB,GAAG;IACpC,sBAAsB,EAAE,OAAO,CAAA;IAC/B,UAAU,CAAC,EAAE,MAAM,CAAA;CACpB,CAAA;AAED,MAAM,WAAW,wCAAwC;IACvD,mBAAmB,EAAE,OAAO,mBAAmB,CAAA;IAC/C,sBAAsB,EAAE,OAAO,sBAAsB,CAAA;IACrD,cAAc,EAAE,OAAO,cAAc,CAAA;CACtC;AAED,wBAAgB,+BAA+B,CAC7C,MAAM,EAAE,sBAAsB,EAC9B,aAAa,EAAE,aAAa,GAAG,IAAI,GAClC,wBAAwB,CAiC1B;AAED,wBAAsB,4BAA4B,CAAC,MAAM,EAAE;IACzD,MAAM,EAAE,2BAA2B,CAAA;IACnC,SAAS,EAAE,yBAAyB,CAAA;IACpC,oBAAoB,EAAE,CAAC,MAAM,EAAE,CAAC,MAAM,IAAI,CAAC,GAAG,IAAI,KAAK,IAAI,CAAA;IAC3D,kBAAkB,CAAC,EAAE,CAAC,WAAW,EAAE,MAAM,KAAK,IAAI,CAAA;IAClD,mBAAmB,CAAC,EAAE,MAAM,IAAI,CAAA;IAChC,YAAY,EAAE,wCAAwC,CAAA;CACvD,GAAG,OAAO,CAAC,uBAAuB,CAAC,CAqInC"}
@@ -1,155 +0,0 @@
1
- import process from 'node:process';
2
- import { buildControlSignalPath, buildManagedShellExecutionEnv, readCommandControlSignal, } from './shell-execution.js';
3
- import { buildLinuxStepResultPayload, buildOutputCaptureMetadata, buildPreview, } from './step-result.js';
4
- import { normalizeRecord, MANAGED_GATEWAY_LOG_PREFIX } from './runtime-utils.js';
5
- export function resolveLinuxExecutionCompletion(result, controlSignal) {
6
- if (result.status === 'succeeded') {
7
- return {
8
- stepStatus: 'completed',
9
- toolCallStatus: 'completed',
10
- controlSignal: controlSignal?.nextAction ?? 'continue',
11
- pauseDuration: controlSignal?.nextAction === 'pause' ? controlSignal.pauseDuration : undefined,
12
- };
13
- }
14
- if (result.status === 'failed') {
15
- return {
16
- stepStatus: 'failed',
17
- toolCallStatus: 'failed',
18
- controlSignal: 'continue',
19
- };
20
- }
21
- if (result.status === 'cancelled') {
22
- return {
23
- stepStatus: 'uncertain',
24
- toolCallStatus: 'failed',
25
- controlSignal: 'stop',
26
- uncertaintyReason: 'linux_execution_cancelled_after_start',
27
- };
28
- }
29
- return {
30
- stepStatus: 'uncertain',
31
- toolCallStatus: 'failed',
32
- controlSignal: 'stop',
33
- uncertaintyReason: 'linux_execution_timed_out_after_start',
34
- };
35
- }
36
- export async function executeManagedLinuxExecution(params) {
37
- const { config } = params;
38
- const { dependencies } = params;
39
- const claimToken = params.execution.claim_token;
40
- if (!claimToken) {
41
- throw new Error(`Managed execution ${params.execution.id} is missing claim token`);
42
- }
43
- const startedExecution = await dependencies.startLinuxExecution({
44
- controlUrl: config.hostControlUrl,
45
- controlToken: config.hostControlToken,
46
- runtimeId: config.runtimeId,
47
- executionId: params.execution.id,
48
- claimToken,
49
- controlTimeoutMs: config.controlTimeoutMs,
50
- });
51
- if (!startedExecution?.id) {
52
- console.warn(`${MANAGED_GATEWAY_LOG_PREFIX} managed execution disappeared before start acknowledgement`, {
53
- executionId: params.execution.id,
54
- });
55
- return {
56
- reconciliationRequired: true,
57
- wakeReason: 'start_ack_missing',
58
- };
59
- }
60
- const command = startedExecution.command;
61
- const controlSignalPath = buildControlSignalPath(startedExecution.id);
62
- params.onExecutionStarted?.(startedExecution.id);
63
- let result;
64
- try {
65
- result = await dependencies.executeCommand(command, config.execTimeoutMs, {
66
- env: buildManagedShellExecutionEnv({
67
- baseEnv: process.env,
68
- agentId: config.agentId,
69
- cycleId: startedExecution.cycle_id,
70
- toolExecutionUrl: config.toolExecutionUrl,
71
- toolExecutionToken: config.toolExecutionToken,
72
- controlSignalPath,
73
- }),
74
- outputCaptureBytes: config.outputCaptureBytes,
75
- registerCancellation: (cancel) => {
76
- params.registerCancellation(cancel);
77
- },
78
- });
79
- }
80
- finally {
81
- params.registerCancellation(null);
82
- params.onExecutionFinished?.();
83
- }
84
- const controlSignal = await readCommandControlSignal(controlSignalPath);
85
- const stdoutPreview = buildPreview(result.stdout);
86
- const stderrPreview = buildPreview(result.stderr);
87
- const stdoutCaptureMetadata = buildOutputCaptureMetadata('stdout', result);
88
- const stderrCaptureMetadata = buildOutputCaptureMetadata('stderr', result);
89
- const executionCompletion = resolveLinuxExecutionCompletion(result, controlSignal);
90
- const stepResult = buildLinuxStepResultPayload({
91
- executionId: startedExecution.id,
92
- command,
93
- result,
94
- completion: executionCompletion,
95
- executionMetadata: startedExecution.metadata,
96
- });
97
- const completion = await dependencies.completeLinuxExecution({
98
- controlUrl: config.hostControlUrl,
99
- controlToken: config.hostControlToken,
100
- runtimeId: config.runtimeId,
101
- executionId: startedExecution.id,
102
- claimToken,
103
- executionStatus: result.status,
104
- exitCode: result.exitCode,
105
- durationMs: result.durationMs,
106
- stdout: result.stdout,
107
- stderr: result.stderr,
108
- error: result.error,
109
- executionMetadata: {
110
- ...normalizeRecord(startedExecution.metadata),
111
- runtime_id: config.runtimeId,
112
- claim_token: claimToken,
113
- started_by_gateway_mode: 'managed',
114
- stdout_preview_truncated: stdoutPreview.truncated,
115
- stderr_preview_truncated: stderrPreview.truncated,
116
- ...stdoutCaptureMetadata,
117
- ...stderrCaptureMetadata,
118
- },
119
- stepStatus: executionCompletion.stepStatus,
120
- stepResult,
121
- stepError: result.error,
122
- stepUncertaintyReason: executionCompletion.uncertaintyReason ?? null,
123
- controlSignal: executionCompletion.controlSignal,
124
- controlTimeoutMs: config.controlTimeoutMs,
125
- });
126
- if (!completion?.run_id) {
127
- console.warn(`${MANAGED_GATEWAY_LOG_PREFIX} execution was no longer active for this gateway when finalizing step; skipping follow-up`, {
128
- executionId: startedExecution.id,
129
- runId: completion?.run_id ?? null,
130
- stepUpdated: completion?.step_updated ?? null,
131
- });
132
- return {
133
- reconciliationRequired: true,
134
- wakeReason: 'completion_followup_reconcile',
135
- };
136
- }
137
- if (completion.step_updated === false) {
138
- console.warn(`${MANAGED_GATEWAY_LOG_PREFIX} execution completed but the linked step was not updated; control plane recovery was queued`, {
139
- executionId: startedExecution.id,
140
- runId: completion.run_id,
141
- stepUpdated: completion.step_updated,
142
- });
143
- return {
144
- reconciliationRequired: true,
145
- wakeReason: 'completion_step_reconcile',
146
- };
147
- }
148
- console.log(`${MANAGED_GATEWAY_LOG_PREFIX} completed managed command`, {
149
- executionId: startedExecution.id,
150
- status: result.status,
151
- runId: completion.run_id,
152
- });
153
- return { reconciliationRequired: false };
154
- }
155
- //# sourceMappingURL=execution-dispatcher.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"execution-dispatcher.js","sourceRoot":"","sources":["../../src/managed-runtime/execution-dispatcher.ts"],"names":[],"mappings":"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"}
@@ -1,7 +0,0 @@
1
- export declare function startHostHeartbeatLoop(params: {
2
- intervalMs: number;
3
- maxConsecutiveFailures: number;
4
- heartbeatHost: () => Promise<void>;
5
- onFatalFailure: (error: Error) => void;
6
- }): () => void;
7
- //# sourceMappingURL=heartbeat.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"heartbeat.d.ts","sourceRoot":"","sources":["../../src/managed-runtime/heartbeat.ts"],"names":[],"mappings":"AAGA,wBAAgB,sBAAsB,CAAC,MAAM,EAAE;IAC7C,UAAU,EAAE,MAAM,CAAA;IAClB,sBAAsB,EAAE,MAAM,CAAA;IAC9B,aAAa,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAA;IAClC,cAAc,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAA;CACvC,GAAG,MAAM,IAAI,CA2Cb"}
@@ -1,44 +0,0 @@
1
- import { setTimeout as sleep } from 'node:timers/promises';
2
- import { asError, MANAGED_GATEWAY_LOG_PREFIX } from './runtime-utils.js';
3
- export function startHostHeartbeatLoop(params) {
4
- let stopped = false;
5
- let consecutiveFailures = 0;
6
- const abortController = new AbortController();
7
- const loop = async () => {
8
- while (!stopped) {
9
- try {
10
- await sleep(params.intervalMs, undefined, { signal: abortController.signal });
11
- }
12
- catch (error) {
13
- if (abortController.signal.aborted) {
14
- break;
15
- }
16
- throw error;
17
- }
18
- if (stopped) {
19
- break;
20
- }
21
- try {
22
- await params.heartbeatHost();
23
- consecutiveFailures = 0;
24
- }
25
- catch (error) {
26
- consecutiveFailures += 1;
27
- console.error(`${MANAGED_GATEWAY_LOG_PREFIX} failed to heartbeat managed host`, {
28
- consecutiveFailures,
29
- error,
30
- });
31
- if (consecutiveFailures >= params.maxConsecutiveFailures) {
32
- params.onFatalFailure(asError(error));
33
- return;
34
- }
35
- }
36
- }
37
- };
38
- void loop();
39
- return () => {
40
- stopped = true;
41
- abortController.abort();
42
- };
43
- }
44
- //# sourceMappingURL=heartbeat.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"heartbeat.js","sourceRoot":"","sources":["../../src/managed-runtime/heartbeat.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,IAAI,KAAK,EAAE,MAAM,sBAAsB,CAAA;AAC1D,OAAO,EAAE,OAAO,EAAE,0BAA0B,EAAE,MAAM,oBAAoB,CAAA;AAExE,MAAM,UAAU,sBAAsB,CAAC,MAKtC;IACC,IAAI,OAAO,GAAG,KAAK,CAAA;IACnB,IAAI,mBAAmB,GAAG,CAAC,CAAA;IAC3B,MAAM,eAAe,GAAG,IAAI,eAAe,EAAE,CAAA;IAE7C,MAAM,IAAI,GAAG,KAAK,IAAI,EAAE;QACtB,OAAO,CAAC,OAAO,EAAE,CAAC;YAChB,IAAI,CAAC;gBACH,MAAM,KAAK,CAAC,MAAM,CAAC,UAAU,EAAE,SAAS,EAAE,EAAE,MAAM,EAAE,eAAe,CAAC,MAAM,EAAE,CAAC,CAAA;YAC/E,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,IAAI,eAAe,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;oBACnC,MAAK;gBACP,CAAC;gBACD,MAAM,KAAK,CAAA;YACb,CAAC;YACD,IAAI,OAAO,EAAE,CAAC;gBACZ,MAAK;YACP,CAAC;YAED,IAAI,CAAC;gBACH,MAAM,MAAM,CAAC,aAAa,EAAE,CAAA;gBAC5B,mBAAmB,GAAG,CAAC,CAAA;YACzB,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,mBAAmB,IAAI,CAAC,CAAA;gBACxB,OAAO,CAAC,KAAK,CAAC,GAAG,0BAA0B,mCAAmC,EAAE;oBAC9E,mBAAmB;oBACnB,KAAK;iBACN,CAAC,CAAA;gBAEF,IAAI,mBAAmB,IAAI,MAAM,CAAC,sBAAsB,EAAE,CAAC;oBACzD,MAAM,CAAC,cAAc,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAA;oBACrC,OAAM;gBACR,CAAC;YACH,CAAC;QACH,CAAC;IACH,CAAC,CAAA;IAED,KAAK,IAAI,EAAE,CAAA;IAEX,OAAO,GAAG,EAAE;QACV,OAAO,GAAG,IAAI,CAAA;QACd,eAAe,CAAC,KAAK,EAAE,CAAA;IACzB,CAAC,CAAA;AACH,CAAC"}
@@ -1,15 +0,0 @@
1
- import type { LinuxHostControlHostEnvelope } from '@panorama/shared/linux-host-control/contract';
2
- export type LinuxHostObservedState = {
3
- attemptGeneration: number | null;
4
- allocationState: string | null;
5
- desiredPowerState: string | null;
6
- status: string | null;
7
- runtimeState: string | null;
8
- error: string | null;
9
- };
10
- export declare function readLinuxHostWakeState(row: Record<string, unknown>): string;
11
- export declare function readLinuxHostObservedState(value: Record<string, unknown> | (LinuxHostControlHostEnvelope & {
12
- error?: string | null;
13
- })): LinuxHostObservedState;
14
- export declare function describeLinuxHostStopReason(state: LinuxHostObservedState, expectedAttemptGeneration: number): string | null;
15
- //# sourceMappingURL=host-state.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"host-state.d.ts","sourceRoot":"","sources":["../../src/managed-runtime/host-state.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,4BAA4B,EAAE,MAAM,8CAA8C,CAAA;AAEhG,MAAM,MAAM,sBAAsB,GAAG;IACnC,iBAAiB,EAAE,MAAM,GAAG,IAAI,CAAA;IAChC,eAAe,EAAE,MAAM,GAAG,IAAI,CAAA;IAC9B,iBAAiB,EAAE,MAAM,GAAG,IAAI,CAAA;IAChC,MAAM,EAAE,MAAM,GAAG,IAAI,CAAA;IACrB,YAAY,EAAE,MAAM,GAAG,IAAI,CAAA;IAC3B,KAAK,EAAE,MAAM,GAAG,IAAI,CAAA;CACrB,CAAA;AAMD,wBAAgB,sBAAsB,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,CAe3E;AAED,wBAAgB,0BAA0B,CACxC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,CAAC,4BAA4B,GAAG;IAAE,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;CAAE,CAAC,GAC1F,sBAAsB,CAgBxB;AAED,wBAAgB,2BAA2B,CACzC,KAAK,EAAE,sBAAsB,EAC7B,yBAAyB,EAAE,MAAM,GAChC,MAAM,GAAG,IAAI,CAsBf"}
@@ -1,50 +0,0 @@
1
- function readNullableString(value) {
2
- return typeof value === 'string' ? value : null;
3
- }
4
- export function readLinuxHostWakeState(row) {
5
- return JSON.stringify({
6
- attempt_generation: typeof row.attempt_generation === 'number' ? row.attempt_generation : row.attempt_generation ?? null,
7
- allocation_state: typeof row.allocation_state === 'string' ? row.allocation_state : row.allocation_state ?? null,
8
- desired_power_state: typeof row.desired_power_state === 'string'
9
- ? row.desired_power_state
10
- : row.desired_power_state ?? null,
11
- status: typeof row.status === 'string' ? row.status : row.status ?? null,
12
- runtime_state: typeof row.runtime_state === 'string' ? row.runtime_state : row.runtime_state ?? null,
13
- error: typeof row.error === 'string' ? row.error : row.error ?? null,
14
- });
15
- }
16
- export function readLinuxHostObservedState(value) {
17
- return {
18
- attemptGeneration: typeof value.attempt_generation === 'number'
19
- ? value.attempt_generation
20
- : value.attempt_generation === null || value.attempt_generation === undefined
21
- ? null
22
- : Number.isFinite(Number(value.attempt_generation))
23
- ? Number(value.attempt_generation)
24
- : null,
25
- allocationState: readNullableString(value.allocation_state),
26
- desiredPowerState: readNullableString(value.desired_power_state),
27
- status: readNullableString(value.status),
28
- runtimeState: readNullableString(value.runtime_state),
29
- error: readNullableString(value.error),
30
- };
31
- }
32
- export function describeLinuxHostStopReason(state, expectedAttemptGeneration) {
33
- if (state.attemptGeneration !== null && state.attemptGeneration !== expectedAttemptGeneration) {
34
- return `host attempt rotated to ${state.attemptGeneration}`;
35
- }
36
- if (state.allocationState !== null && state.allocationState !== 'warm') {
37
- return `host allocation is ${state.allocationState}`;
38
- }
39
- if (state.desiredPowerState !== null && state.desiredPowerState !== 'running') {
40
- return `desired power state is ${state.desiredPowerState}`;
41
- }
42
- if (state.status === 'stopping' || state.status === 'stopped') {
43
- return `host status is ${state.status}`;
44
- }
45
- if (state.runtimeState === 'stopping' || state.runtimeState === 'stopped') {
46
- return `host runtime_state is ${state.runtimeState}`;
47
- }
48
- return null;
49
- }
50
- //# sourceMappingURL=host-state.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"host-state.js","sourceRoot":"","sources":["../../src/managed-runtime/host-state.ts"],"names":[],"mappings":"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"}
@@ -1,25 +0,0 @@
1
- import { type LinuxHostObservedState } from './host-state.js';
2
- import { type ManagedGatewaySupabaseClient } from './runtime-utils.js';
3
- export declare function createManagedRealtimeClient(params: {
4
- supabaseUrl: string;
5
- supabaseAnonKey: string;
6
- hostControlToken: string;
7
- agentId: string;
8
- hostId: string;
9
- hostAttemptGeneration: number;
10
- controlTimeoutMs: number;
11
- }): Promise<{
12
- supabase: ManagedGatewaySupabaseClient;
13
- unsubscribeAuthStateChange: () => void;
14
- }>;
15
- export declare function startManagedRealtimeWakeLoop(params: {
16
- supabase: ManagedGatewaySupabaseClient;
17
- hostId: string;
18
- hostAttemptGeneration: number;
19
- retryBackoffMs: number;
20
- onReconnectRequired: () => void;
21
- onHostStateObserved: (state: LinuxHostObservedState, source: string) => void;
22
- requestWake: (reason: string) => void;
23
- shouldStop: () => boolean;
24
- }): () => Promise<void>;
25
- //# sourceMappingURL=realtime.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"realtime.d.ts","sourceRoot":"","sources":["../../src/managed-runtime/realtime.ts"],"names":[],"mappings":"AAEA,OAAO,EAGL,KAAK,sBAAsB,EAC5B,MAAM,iBAAiB,CAAA;AACxB,OAAO,EAGL,KAAK,4BAA4B,EAClC,MAAM,oBAAoB,CAAA;AAI3B,wBAAsB,2BAA2B,CAAC,MAAM,EAAE;IACxD,WAAW,EAAE,MAAM,CAAA;IACnB,eAAe,EAAE,MAAM,CAAA;IACvB,gBAAgB,EAAE,MAAM,CAAA;IACxB,OAAO,EAAE,MAAM,CAAA;IACf,MAAM,EAAE,MAAM,CAAA;IACd,qBAAqB,EAAE,MAAM,CAAA;IAC7B,gBAAgB,EAAE,MAAM,CAAA;CACzB,GAAG,OAAO,CAAC;IACV,QAAQ,EAAE,4BAA4B,CAAA;IACtC,0BAA0B,EAAE,MAAM,IAAI,CAAA;CACvC,CAAC,CAoED;AAED,wBAAgB,4BAA4B,CAAC,MAAM,EAAE;IACnD,QAAQ,EAAE,4BAA4B,CAAA;IACtC,MAAM,EAAE,MAAM,CAAA;IACd,qBAAqB,EAAE,MAAM,CAAA;IAC7B,cAAc,EAAE,MAAM,CAAA;IACtB,mBAAmB,EAAE,MAAM,IAAI,CAAA;IAC/B,mBAAmB,EAAE,CAAC,KAAK,EAAE,sBAAsB,EAAE,MAAM,EAAE,MAAM,KAAK,IAAI,CAAA;IAC5E,WAAW,EAAE,CAAC,MAAM,EAAE,MAAM,KAAK,IAAI,CAAA;IACrC,UAAU,EAAE,MAAM,OAAO,CAAA;CAC1B,GAAG,MAAM,OAAO,CAAC,IAAI,CAAC,CAiKtB"}
@@ -1,189 +0,0 @@
1
- import { createClient } from '@supabase/supabase-js';
2
- import { exchangeLinuxHostSession } from './control-client.js';
3
- import { readLinuxHostObservedState, readLinuxHostWakeState, } from './host-state.js';
4
- import { MANAGED_GATEWAY_LOG_PREFIX, normalizeRecord, } from './runtime-utils.js';
5
- const DEFAULT_REALTIME_EVENTS_PER_SECOND = 10;
6
- export async function createManagedRealtimeClient(params) {
7
- const sessionExchange = await exchangeLinuxHostSession({
8
- supabaseUrl: params.supabaseUrl,
9
- supabaseAnonKey: params.supabaseAnonKey,
10
- hostControlToken: params.hostControlToken,
11
- timeoutMs: params.controlTimeoutMs,
12
- });
13
- if (!sessionExchange.success) {
14
- throw new Error('Linux host session exchange returned an unsuccessful response.');
15
- }
16
- if (sessionExchange.agent_id !== params.agentId) {
17
- throw new Error(`Linux host session exchange returned agent ${sessionExchange.agent_id}, expected ${params.agentId}`);
18
- }
19
- if (sessionExchange.host_id !== params.hostId) {
20
- throw new Error(`Linux host session exchange returned host ${sessionExchange.host_id}, expected ${params.hostId}`);
21
- }
22
- if (sessionExchange.attempt_generation !== params.hostAttemptGeneration) {
23
- throw new Error(`Linux host session exchange returned attempt generation ${sessionExchange.attempt_generation}, expected ${params.hostAttemptGeneration}`);
24
- }
25
- const supabase = createClient(params.supabaseUrl, params.supabaseAnonKey, {
26
- auth: {
27
- persistSession: false,
28
- autoRefreshToken: true,
29
- detectSessionInUrl: false,
30
- },
31
- realtime: {
32
- params: {
33
- eventsPerSecond: DEFAULT_REALTIME_EVENTS_PER_SECOND,
34
- },
35
- },
36
- });
37
- const { data: sessionData, error: sessionError } = await supabase.auth.setSession({
38
- access_token: sessionExchange.access_token,
39
- refresh_token: sessionExchange.refresh_token,
40
- });
41
- if (sessionError || !sessionData?.session) {
42
- throw new Error(sessionError?.message || 'Linux host session exchange did not return a session.');
43
- }
44
- const authStateSubscription = supabase.auth.onAuthStateChange((event, session) => {
45
- if (!session) {
46
- return;
47
- }
48
- if (event === 'TOKEN_REFRESHED' || event === 'SIGNED_IN') {
49
- console.log(`${MANAGED_GATEWAY_LOG_PREFIX} refreshed managed runtime session`, {
50
- event,
51
- expiresAt: session.expires_at ?? null,
52
- });
53
- }
54
- });
55
- return {
56
- supabase,
57
- unsubscribeAuthStateChange() {
58
- authStateSubscription.data.subscription.unsubscribe();
59
- },
60
- };
61
- }
62
- export function startManagedRealtimeWakeLoop(params) {
63
- let activeChannel = null;
64
- let reconnectTimer = null;
65
- let lastHostWakeState = null;
66
- const syncHostWakeState = async () => {
67
- const { data, error } = await params.supabase
68
- .from('linux_agent_hosts')
69
- .select('attempt_generation, allocation_state, desired_power_state, status, runtime_state, error')
70
- .eq('id', params.hostId)
71
- .maybeSingle();
72
- if (error) {
73
- console.warn(`${MANAGED_GATEWAY_LOG_PREFIX} failed to seed managed host realtime baseline`, {
74
- hostId: params.hostId,
75
- error: error.message,
76
- });
77
- return;
78
- }
79
- if (data) {
80
- const normalized = normalizeRecord(data);
81
- lastHostWakeState = readLinuxHostWakeState(normalized);
82
- params.onHostStateObserved(readLinuxHostObservedState(normalized), 'baseline');
83
- }
84
- };
85
- const scheduleReconnect = (reason) => {
86
- if (params.shouldStop() || reconnectTimer) {
87
- return;
88
- }
89
- reconnectTimer = setTimeout(() => {
90
- reconnectTimer = null;
91
- void connectChannel(`reconnect:${reason}`);
92
- }, params.retryBackoffMs);
93
- };
94
- const handleHostPayload = (payload) => {
95
- const nextRow = normalizeRecord(payload.new);
96
- params.onHostStateObserved(readLinuxHostObservedState(nextRow), `realtime_${payload.eventType.toLowerCase()}`);
97
- const nextWakeState = readLinuxHostWakeState(nextRow);
98
- if (nextWakeState === lastHostWakeState) {
99
- return;
100
- }
101
- lastHostWakeState = nextWakeState;
102
- params.onReconnectRequired();
103
- params.requestWake(`host_${payload.eventType.toLowerCase()}`);
104
- };
105
- const handleExecutionPayload = (payload) => {
106
- const nextRow = normalizeRecord(payload.new);
107
- const nextStatus = typeof nextRow.status === 'string' ? nextRow.status : null;
108
- if (payload.eventType === 'INSERT' || nextStatus === 'queued') {
109
- params.requestWake(`execution_${payload.eventType.toLowerCase()}`);
110
- }
111
- };
112
- const connectChannel = async (reason) => {
113
- if (params.shouldStop()) {
114
- return;
115
- }
116
- const previousChannel = activeChannel;
117
- activeChannel = null;
118
- if (previousChannel) {
119
- try {
120
- await previousChannel.unsubscribe();
121
- }
122
- catch {
123
- // ignore unsubscribe failures during reconnect
124
- }
125
- }
126
- const nextChannel = params.supabase
127
- .channel(`managed_gateway_runtime_${params.hostId}_${params.hostAttemptGeneration}`)
128
- .on('postgres_changes', {
129
- event: 'UPDATE',
130
- schema: 'public',
131
- table: 'linux_agent_hosts',
132
- filter: `id=eq.${params.hostId}`,
133
- }, handleHostPayload)
134
- .on('postgres_changes', {
135
- event: 'INSERT',
136
- schema: 'public',
137
- table: 'linux_agent_executions',
138
- filter: `host_id=eq.${params.hostId}`,
139
- }, handleExecutionPayload)
140
- .on('postgres_changes', {
141
- event: 'UPDATE',
142
- schema: 'public',
143
- table: 'linux_agent_executions',
144
- filter: `host_id=eq.${params.hostId}`,
145
- }, handleExecutionPayload);
146
- activeChannel = nextChannel;
147
- nextChannel.subscribe((status, error) => {
148
- if (activeChannel !== nextChannel || params.shouldStop()) {
149
- return;
150
- }
151
- if (status === 'SUBSCRIBED') {
152
- void (async () => {
153
- await syncHostWakeState();
154
- console.log(`${MANAGED_GATEWAY_LOG_PREFIX} subscribed to managed host realtime channel`, {
155
- hostId: params.hostId,
156
- attemptGeneration: params.hostAttemptGeneration,
157
- reason,
158
- });
159
- params.onReconnectRequired();
160
- params.requestWake(`realtime_subscribed:${reason}`);
161
- })();
162
- return;
163
- }
164
- if (status === 'CHANNEL_ERROR' || status === 'TIMED_OUT' || status === 'CLOSED') {
165
- console.error(`${MANAGED_GATEWAY_LOG_PREFIX} managed host realtime channel unavailable`, {
166
- status,
167
- reason,
168
- error: error?.message ?? null,
169
- });
170
- params.onReconnectRequired();
171
- scheduleReconnect(status.toLowerCase());
172
- }
173
- });
174
- };
175
- void connectChannel('startup');
176
- return async () => {
177
- if (reconnectTimer) {
178
- clearTimeout(reconnectTimer);
179
- reconnectTimer = null;
180
- }
181
- const channelToClose = activeChannel;
182
- activeChannel = null;
183
- if (channelToClose) {
184
- await channelToClose.unsubscribe().catch(() => undefined);
185
- }
186
- await params.supabase.removeAllChannels().catch(() => undefined);
187
- };
188
- }
189
- //# sourceMappingURL=realtime.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"realtime.js","sourceRoot":"","sources":["../../src/managed-runtime/realtime.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAA6D,MAAM,uBAAuB,CAAA;AAC/G,OAAO,EAAE,wBAAwB,EAAE,MAAM,qBAAqB,CAAA;AAC9D,OAAO,EACL,0BAA0B,EAC1B,sBAAsB,GAEvB,MAAM,iBAAiB,CAAA;AACxB,OAAO,EACL,0BAA0B,EAC1B,eAAe,GAEhB,MAAM,oBAAoB,CAAA;AAE3B,MAAM,kCAAkC,GAAG,EAAE,CAAA;AAE7C,MAAM,CAAC,KAAK,UAAU,2BAA2B,CAAC,MAQjD;IAIC,MAAM,eAAe,GAAG,MAAM,wBAAwB,CAAC;QACrD,WAAW,EAAE,MAAM,CAAC,WAAW;QAC/B,eAAe,EAAE,MAAM,CAAC,eAAe;QACvC,gBAAgB,EAAE,MAAM,CAAC,gBAAgB;QACzC,SAAS,EAAE,MAAM,CAAC,gBAAgB;KACnC,CAAC,CAAA;IAEF,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,CAAC;QAC7B,MAAM,IAAI,KAAK,CAAC,gEAAgE,CAAC,CAAA;IACnF,CAAC;IACD,IAAI,eAAe,CAAC,QAAQ,KAAK,MAAM,CAAC,OAAO,EAAE,CAAC;QAChD,MAAM,IAAI,KAAK,CACb,8CAA8C,eAAe,CAAC,QAAQ,cAAc,MAAM,CAAC,OAAO,EAAE,CACrG,CAAA;IACH,CAAC;IACD,IAAI,eAAe,CAAC,OAAO,KAAK,MAAM,CAAC,MAAM,EAAE,CAAC;QAC9C,MAAM,IAAI,KAAK,CACb,6CAA6C,eAAe,CAAC,OAAO,cAAc,MAAM,CAAC,MAAM,EAAE,CAClG,CAAA;IACH,CAAC;IACD,IAAI,eAAe,CAAC,kBAAkB,KAAK,MAAM,CAAC,qBAAqB,EAAE,CAAC;QACxE,MAAM,IAAI,KAAK,CACb,2DAA2D,eAAe,CAAC,kBAAkB,cAAc,MAAM,CAAC,qBAAqB,EAAE,CAC1I,CAAA;IACH,CAAC;IAED,MAAM,QAAQ,GAAG,YAAY,CAAC,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,eAAe,EAAE;QACxE,IAAI,EAAE;YACJ,cAAc,EAAE,KAAK;YACrB,gBAAgB,EAAE,IAAI;YACtB,kBAAkB,EAAE,KAAK;SAC1B;QACD,QAAQ,EAAE;YACR,MAAM,EAAE;gBACN,eAAe,EAAE,kCAAkC;aACpD;SACF;KACF,CAAiC,CAAA;IAElC,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,KAAK,EAAE,YAAY,EAAE,GAAG,MAAM,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC;QAChF,YAAY,EAAE,eAAe,CAAC,YAAY;QAC1C,aAAa,EAAE,eAAe,CAAC,aAAa;KAC7C,CAAC,CAAA;IAEF,IAAI,YAAY,IAAI,CAAC,WAAW,EAAE,OAAO,EAAE,CAAC;QAC1C,MAAM,IAAI,KAAK,CAAC,YAAY,EAAE,OAAO,IAAI,uDAAuD,CAAC,CAAA;IACnG,CAAC;IAED,MAAM,qBAAqB,GAAG,QAAQ,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;QAC/E,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,OAAM;QACR,CAAC;QAED,IAAI,KAAK,KAAK,iBAAiB,IAAI,KAAK,KAAK,WAAW,EAAE,CAAC;YACzD,OAAO,CAAC,GAAG,CAAC,GAAG,0BAA0B,oCAAoC,EAAE;gBAC7E,KAAK;gBACL,SAAS,EAAE,OAAO,CAAC,UAAU,IAAI,IAAI;aACtC,CAAC,CAAA;QACJ,CAAC;IACH,CAAC,CAAC,CAAA;IAEF,OAAO;QACL,QAAQ;QACR,0BAA0B;YACxB,qBAAqB,CAAC,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAA;QACvD,CAAC;KACF,CAAA;AACH,CAAC;AAED,MAAM,UAAU,4BAA4B,CAAC,MAS5C;IACC,IAAI,aAAa,GAA2B,IAAI,CAAA;IAChD,IAAI,cAAc,GAA0B,IAAI,CAAA;IAChD,IAAI,iBAAiB,GAAkB,IAAI,CAAA;IAE3C,MAAM,iBAAiB,GAAG,KAAK,IAAI,EAAE;QACnC,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,MAAM,MAAM,CAAC,QAAQ;aAC1C,IAAI,CAAC,mBAAmB,CAAC;aACzB,MAAM,CAAC,yFAAyF,CAAC;aACjG,EAAE,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,CAAC;aACvB,WAAW,EAAE,CAAA;QAEhB,IAAI,KAAK,EAAE,CAAC;YACV,OAAO,CAAC,IAAI,CAAC,GAAG,0BAA0B,gDAAgD,EAAE;gBAC1F,MAAM,EAAE,MAAM,CAAC,MAAM;gBACrB,KAAK,EAAE,KAAK,CAAC,OAAO;aACrB,CAAC,CAAA;YACF,OAAM;QACR,CAAC;QAED,IAAI,IAAI,EAAE,CAAC;YACT,MAAM,UAAU,GAAG,eAAe,CAAC,IAAI,CAAC,CAAA;YACxC,iBAAiB,GAAG,sBAAsB,CAAC,UAAU,CAAC,CAAA;YACtD,MAAM,CAAC,mBAAmB,CAAC,0BAA0B,CAAC,UAAU,CAAC,EAAE,UAAU,CAAC,CAAA;QAChF,CAAC;IACH,CAAC,CAAA;IAED,MAAM,iBAAiB,GAAG,CAAC,MAAc,EAAE,EAAE;QAC3C,IAAI,MAAM,CAAC,UAAU,EAAE,IAAI,cAAc,EAAE,CAAC;YAC1C,OAAM;QACR,CAAC;QAED,cAAc,GAAG,UAAU,CAAC,GAAG,EAAE;YAC/B,cAAc,GAAG,IAAI,CAAA;YACrB,KAAK,cAAc,CAAC,aAAa,MAAM,EAAE,CAAC,CAAA;QAC5C,CAAC,EAAE,MAAM,CAAC,cAAc,CAAC,CAAA;IAC3B,CAAC,CAAA;IAED,MAAM,iBAAiB,GAAG,CAAC,OAAgE,EAAE,EAAE;QAC7F,MAAM,OAAO,GAAG,eAAe,CAAC,OAAO,CAAC,GAAG,CAAC,CAAA;QAC5C,MAAM,CAAC,mBAAmB,CACxB,0BAA0B,CAAC,OAAO,CAAC,EACnC,YAAY,OAAO,CAAC,SAAS,CAAC,WAAW,EAAE,EAAE,CAC9C,CAAA;QACD,MAAM,aAAa,GAAG,sBAAsB,CAAC,OAAO,CAAC,CAAA;QACrD,IAAI,aAAa,KAAK,iBAAiB,EAAE,CAAC;YACxC,OAAM;QACR,CAAC;QACD,iBAAiB,GAAG,aAAa,CAAA;QAEjC,MAAM,CAAC,mBAAmB,EAAE,CAAA;QAC5B,MAAM,CAAC,WAAW,CAAC,QAAQ,OAAO,CAAC,SAAS,CAAC,WAAW,EAAE,EAAE,CAAC,CAAA;IAC/D,CAAC,CAAA;IAED,MAAM,sBAAsB,GAAG,CAC7B,OAAgE,EAChE,EAAE;QACF,MAAM,OAAO,GAAG,eAAe,CAAC,OAAO,CAAC,GAAG,CAAC,CAAA;QAC5C,MAAM,UAAU,GAAG,OAAO,OAAO,CAAC,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAA;QAC7E,IAAI,OAAO,CAAC,SAAS,KAAK,QAAQ,IAAI,UAAU,KAAK,QAAQ,EAAE,CAAC;YAC9D,MAAM,CAAC,WAAW,CAAC,aAAa,OAAO,CAAC,SAAS,CAAC,WAAW,EAAE,EAAE,CAAC,CAAA;QACpE,CAAC;IACH,CAAC,CAAA;IAED,MAAM,cAAc,GAAG,KAAK,EAAE,MAAc,EAAE,EAAE;QAC9C,IAAI,MAAM,CAAC,UAAU,EAAE,EAAE,CAAC;YACxB,OAAM;QACR,CAAC;QAED,MAAM,eAAe,GAAG,aAAa,CAAA;QACrC,aAAa,GAAG,IAAI,CAAA;QACpB,IAAI,eAAe,EAAE,CAAC;YACpB,IAAI,CAAC;gBACH,MAAM,eAAe,CAAC,WAAW,EAAE,CAAA;YACrC,CAAC;YAAC,MAAM,CAAC;gBACP,+CAA+C;YACjD,CAAC;QACH,CAAC;QAED,MAAM,WAAW,GAAG,MAAM,CAAC,QAAQ;aAChC,OAAO,CAAC,2BAA2B,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC,qBAAqB,EAAE,CAAC;aACnF,EAAE,CACD,kBAAkB,EAClB;YACE,KAAK,EAAE,QAAQ;YACf,MAAM,EAAE,QAAQ;YAChB,KAAK,EAAE,mBAAmB;YAC1B,MAAM,EAAE,SAAS,MAAM,CAAC,MAAM,EAAE;SACjC,EACD,iBAAiB,CAClB;aACA,EAAE,CACD,kBAAkB,EAClB;YACE,KAAK,EAAE,QAAQ;YACf,MAAM,EAAE,QAAQ;YAChB,KAAK,EAAE,wBAAwB;YAC/B,MAAM,EAAE,cAAc,MAAM,CAAC,MAAM,EAAE;SACtC,EACD,sBAAsB,CACvB;aACA,EAAE,CACD,kBAAkB,EAClB;YACE,KAAK,EAAE,QAAQ;YACf,MAAM,EAAE,QAAQ;YAChB,KAAK,EAAE,wBAAwB;YAC/B,MAAM,EAAE,cAAc,MAAM,CAAC,MAAM,EAAE;SACtC,EACD,sBAAsB,CACvB,CAAA;QAEH,aAAa,GAAG,WAAW,CAAA;QAE3B,WAAW,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,EAAE;YACtC,IAAI,aAAa,KAAK,WAAW,IAAI,MAAM,CAAC,UAAU,EAAE,EAAE,CAAC;gBACzD,OAAM;YACR,CAAC;YAED,IAAI,MAAM,KAAK,YAAY,EAAE,CAAC;gBAC5B,KAAK,CAAC,KAAK,IAAI,EAAE;oBACf,MAAM,iBAAiB,EAAE,CAAA;oBACzB,OAAO,CAAC,GAAG,CAAC,GAAG,0BAA0B,8CAA8C,EAAE;wBACvF,MAAM,EAAE,MAAM,CAAC,MAAM;wBACrB,iBAAiB,EAAE,MAAM,CAAC,qBAAqB;wBAC/C,MAAM;qBACP,CAAC,CAAA;oBACF,MAAM,CAAC,mBAAmB,EAAE,CAAA;oBAC5B,MAAM,CAAC,WAAW,CAAC,uBAAuB,MAAM,EAAE,CAAC,CAAA;gBACrD,CAAC,CAAC,EAAE,CAAA;gBACJ,OAAM;YACR,CAAC;YAED,IAAI,MAAM,KAAK,eAAe,IAAI,MAAM,KAAK,WAAW,IAAI,MAAM,KAAK,QAAQ,EAAE,CAAC;gBAChF,OAAO,CAAC,KAAK,CAAC,GAAG,0BAA0B,4CAA4C,EAAE;oBACvF,MAAM;oBACN,MAAM;oBACN,KAAK,EAAE,KAAK,EAAE,OAAO,IAAI,IAAI;iBAC9B,CAAC,CAAA;gBACF,MAAM,CAAC,mBAAmB,EAAE,CAAA;gBAC5B,iBAAiB,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,CAAA;YACzC,CAAC;QACH,CAAC,CAAC,CAAA;IACJ,CAAC,CAAA;IAED,KAAK,cAAc,CAAC,SAAS,CAAC,CAAA;IAE9B,OAAO,KAAK,IAAI,EAAE;QAChB,IAAI,cAAc,EAAE,CAAC;YACnB,YAAY,CAAC,cAAc,CAAC,CAAA;YAC5B,cAAc,GAAG,IAAI,CAAA;QACvB,CAAC;QAED,MAAM,cAAc,GAAG,aAAa,CAAA;QACpC,aAAa,GAAG,IAAI,CAAA;QACpB,IAAI,cAAc,EAAE,CAAC;YACnB,MAAM,cAAc,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,CAAA;QAC3D,CAAC;QAED,MAAM,MAAM,CAAC,QAAQ,CAAC,iBAAiB,EAAE,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,CAAA;IAClE,CAAC,CAAA;AACH,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"runtime-utils.d.ts","sourceRoot":"","sources":["../../src/managed-runtime/runtime-utils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAA;AAC3D,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAA;AAEpD,eAAO,MAAM,0BAA0B,+BAA+B,CAAA;AAEtE,MAAM,MAAM,4BAA4B,GAAG,cAAc,CAAC,QAAQ,CAAC,CAAA;AAEnE,wBAAgB,OAAO,CAAC,KAAK,EAAE,OAAO,GAAG,KAAK,CAE7C;AAED,wBAAsB,gBAAgB,CAAC,CAAC,EACtC,SAAS,EAAE,MAAM,EACjB,cAAc,EAAE,MAAM,EACtB,SAAS,EAAE,CAAC,MAAM,EAAE,WAAW,KAAK,OAAO,CAAC,CAAC,CAAC,EAC9C,cAAc,CAAC,EAAE,WAAW,GAC3B,OAAO,CAAC,CAAC,CAAC,CA0BZ;AAED,wBAAgB,eAAe,CAAC,KAAK,EAAE,OAAO,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAMvE"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"runtime-utils.js","sourceRoot":"","sources":["../../src/managed-runtime/runtime-utils.ts"],"names":[],"mappings":"AAGA,MAAM,CAAC,MAAM,0BAA0B,GAAG,4BAA4B,CAAA;AAItE,MAAM,UAAU,OAAO,CAAC,KAAc;IACpC,OAAO,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAA;AAClE,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,gBAAgB,CACpC,SAAiB,EACjB,cAAsB,EACtB,SAA8C,EAC9C,cAA4B;IAE5B,MAAM,UAAU,GAAG,IAAI,eAAe,EAAE,CAAA;IACxC,IAAI,QAAQ,GAAG,KAAK,CAAA;IACpB,MAAM,aAAa,GAAG,UAAU,CAAC,GAAG,EAAE;QACpC,QAAQ,GAAG,IAAI,CAAA;QACf,UAAU,CAAC,KAAK,EAAE,CAAA;IACpB,CAAC,EAAE,SAAS,CAAC,CAAA;IACb,MAAM,uBAAuB,GAAG,GAAG,EAAE,CAAC,UAAU,CAAC,KAAK,EAAE,CAAA;IAExD,IAAI,cAAc,EAAE,OAAO,EAAE,CAAC;QAC5B,UAAU,CAAC,KAAK,EAAE,CAAA;IACpB,CAAC;SAAM,CAAC;QACN,cAAc,EAAE,gBAAgB,CAAC,OAAO,EAAE,uBAAuB,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAA;IACpF,CAAC;IAED,IAAI,CAAC;QACH,OAAO,MAAM,SAAS,CAAC,UAAU,CAAC,MAAM,CAAC,CAAA;IAC3C,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,IAAI,QAAQ,EAAE,CAAC;YACb,MAAM,IAAI,KAAK,CAAC,cAAc,CAAC,CAAA;QACjC,CAAC;QACD,MAAM,KAAK,CAAA;IACb,CAAC;YAAS,CAAC;QACT,YAAY,CAAC,aAAa,CAAC,CAAA;QAC3B,cAAc,EAAE,mBAAmB,CAAC,OAAO,EAAE,uBAAuB,CAAC,CAAA;IACvE,CAAC;AACH,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,KAAc;IAC5C,IAAI,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;QAChE,OAAO,KAAgC,CAAA;IACzC,CAAC;IAED,OAAO,EAAE,CAAA;AACX,CAAC"}
@@ -1,33 +0,0 @@
1
- import { type ControlSignal } from '@panorama/shared/control-signals';
2
- export type CommandExecutionResult = {
3
- status: 'succeeded' | 'failed' | 'timed_out' | 'cancelled';
4
- stdout: string;
5
- stderr: string;
6
- stdoutObservedBytes: number;
7
- stderrObservedBytes: number;
8
- stdoutCapturedBytes: number;
9
- stderrCapturedBytes: number;
10
- stdoutTruncated: boolean;
11
- stderrTruncated: boolean;
12
- outputCaptureBytes: number;
13
- exitCode: number | null;
14
- durationMs: number;
15
- error: string | null;
16
- };
17
- export type ExecuteCommandOptions = {
18
- registerCancellation?: (cancel: (() => void) | null) => void;
19
- env?: NodeJS.ProcessEnv;
20
- outputCaptureBytes?: number;
21
- };
22
- export declare function executeCommand(command: string, timeoutMs: number, options?: ExecuteCommandOptions): Promise<CommandExecutionResult>;
23
- export declare function buildManagedShellExecutionEnv(params: {
24
- baseEnv: NodeJS.ProcessEnv;
25
- agentId: string;
26
- cycleId: string | null;
27
- toolExecutionUrl: string;
28
- toolExecutionToken: string;
29
- controlSignalPath: string;
30
- }): NodeJS.ProcessEnv;
31
- export declare function buildControlSignalPath(executionId: string): string;
32
- export declare function readCommandControlSignal(path: string): Promise<ControlSignal | null>;
33
- //# sourceMappingURL=shell-execution.d.ts.map