@panorama-ai/gateway 2.30.279 → 2.31.37
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/README.md +51 -65
- package/dist/cli-args.d.ts +0 -2
- package/dist/cli-args.d.ts.map +1 -1
- package/dist/cli-args.js +0 -8
- package/dist/cli-args.js.map +1 -1
- package/dist/database.types.d.ts +119 -760
- package/dist/database.types.d.ts.map +1 -1
- package/dist/database.types.js.map +1 -1
- package/dist/drive-sync/config.d.ts +14 -0
- package/dist/drive-sync/config.d.ts.map +1 -0
- package/dist/drive-sync/config.js +45 -0
- package/dist/drive-sync/config.js.map +1 -0
- package/dist/drive-sync/drive-sync-filesystem.d.ts.map +1 -0
- package/dist/drive-sync/drive-sync-filesystem.js.map +1 -0
- package/dist/drive-sync/drive-sync-planner.d.ts.map +1 -0
- package/dist/drive-sync/drive-sync-planner.js.map +1 -0
- package/dist/drive-sync/drive-sync-remote-planner.d.ts.map +1 -0
- package/dist/drive-sync/drive-sync-remote-planner.js.map +1 -0
- package/dist/{managed-runtime → drive-sync}/drive-sync-scheduler.d.ts +12 -11
- package/dist/drive-sync/drive-sync-scheduler.d.ts.map +1 -0
- package/dist/{managed-runtime → drive-sync}/drive-sync-scheduler.js +7 -5
- package/dist/drive-sync/drive-sync-scheduler.js.map +1 -0
- package/dist/drive-sync/drive-sync-state-applier.d.ts.map +1 -0
- package/dist/drive-sync/drive-sync-state-applier.js.map +1 -0
- package/dist/drive-sync/drive-sync-transfer.d.ts.map +1 -0
- package/dist/drive-sync/drive-sync-transfer.js.map +1 -0
- package/dist/{managed-runtime → drive-sync}/drive-sync.d.ts +29 -12
- package/dist/drive-sync/drive-sync.d.ts.map +1 -0
- package/dist/{managed-runtime → drive-sync}/drive-sync.js +64 -28
- package/dist/drive-sync/drive-sync.js.map +1 -0
- package/dist/{managed-runtime → drive-sync}/runtime-utils.d.ts +2 -2
- package/dist/drive-sync/runtime-utils.d.ts.map +1 -0
- package/dist/{managed-runtime → drive-sync}/runtime-utils.js +1 -1
- package/dist/drive-sync/runtime-utils.js.map +1 -0
- package/dist/gateway-local-runtime.d.ts +7 -1
- package/dist/gateway-local-runtime.d.ts.map +1 -1
- package/dist/gateway-local-runtime.js +26 -5
- package/dist/gateway-local-runtime.js.map +1 -1
- package/dist/gateway-state.d.ts +4 -0
- package/dist/gateway-state.d.ts.map +1 -1
- package/dist/gateway-state.js +6 -2
- package/dist/gateway-state.js.map +1 -1
- package/dist/index.js +2177 -3627
- package/dist/index.js.map +4 -4
- package/dist/local-runtime/drive-sync-supervisor.d.ts +14 -0
- package/dist/local-runtime/drive-sync-supervisor.d.ts.map +1 -0
- package/dist/local-runtime/drive-sync-supervisor.js +79 -0
- package/dist/local-runtime/drive-sync-supervisor.js.map +1 -0
- package/dist/local-runtime/shutdown-supervisor.d.ts +1 -0
- package/dist/local-runtime/shutdown-supervisor.d.ts.map +1 -1
- package/dist/local-runtime/shutdown-supervisor.js +5 -2
- package/dist/local-runtime/shutdown-supervisor.js.map +1 -1
- package/package.json +6 -6
- package/dist/managed-runtime/config.d.ts +0 -33
- package/dist/managed-runtime/config.d.ts.map +0 -1
- package/dist/managed-runtime/config.js +0 -111
- package/dist/managed-runtime/config.js.map +0 -1
- package/dist/managed-runtime/control-client.d.ts +0 -66
- package/dist/managed-runtime/control-client.d.ts.map +0 -1
- package/dist/managed-runtime/control-client.js +0 -142
- package/dist/managed-runtime/control-client.js.map +0 -1
- package/dist/managed-runtime/dependencies.d.ts +0 -19
- package/dist/managed-runtime/dependencies.d.ts.map +0 -1
- package/dist/managed-runtime/dependencies.js +0 -30
- package/dist/managed-runtime/dependencies.js.map +0 -1
- package/dist/managed-runtime/drive-sync-filesystem.d.ts.map +0 -1
- package/dist/managed-runtime/drive-sync-filesystem.js.map +0 -1
- package/dist/managed-runtime/drive-sync-planner.d.ts.map +0 -1
- package/dist/managed-runtime/drive-sync-planner.js.map +0 -1
- package/dist/managed-runtime/drive-sync-remote-planner.d.ts.map +0 -1
- package/dist/managed-runtime/drive-sync-remote-planner.js.map +0 -1
- package/dist/managed-runtime/drive-sync-scheduler.d.ts.map +0 -1
- package/dist/managed-runtime/drive-sync-scheduler.js.map +0 -1
- package/dist/managed-runtime/drive-sync-state-applier.d.ts.map +0 -1
- package/dist/managed-runtime/drive-sync-state-applier.js.map +0 -1
- package/dist/managed-runtime/drive-sync-transfer.d.ts.map +0 -1
- package/dist/managed-runtime/drive-sync-transfer.js.map +0 -1
- package/dist/managed-runtime/drive-sync.d.ts.map +0 -1
- package/dist/managed-runtime/drive-sync.js.map +0 -1
- package/dist/managed-runtime/execution-dispatcher.d.ts +0 -25
- package/dist/managed-runtime/execution-dispatcher.d.ts.map +0 -1
- package/dist/managed-runtime/execution-dispatcher.js +0 -155
- package/dist/managed-runtime/execution-dispatcher.js.map +0 -1
- package/dist/managed-runtime/heartbeat.d.ts +0 -7
- package/dist/managed-runtime/heartbeat.d.ts.map +0 -1
- package/dist/managed-runtime/heartbeat.js +0 -44
- package/dist/managed-runtime/heartbeat.js.map +0 -1
- package/dist/managed-runtime/host-state.d.ts +0 -15
- package/dist/managed-runtime/host-state.d.ts.map +0 -1
- package/dist/managed-runtime/host-state.js +0 -50
- package/dist/managed-runtime/host-state.js.map +0 -1
- package/dist/managed-runtime/realtime.d.ts +0 -25
- package/dist/managed-runtime/realtime.d.ts.map +0 -1
- package/dist/managed-runtime/realtime.js +0 -189
- package/dist/managed-runtime/realtime.js.map +0 -1
- package/dist/managed-runtime/runtime-utils.d.ts.map +0 -1
- package/dist/managed-runtime/runtime-utils.js.map +0 -1
- package/dist/managed-runtime/shell-execution.d.ts +0 -33
- package/dist/managed-runtime/shell-execution.d.ts.map +0 -1
- package/dist/managed-runtime/shell-execution.js +0 -186
- package/dist/managed-runtime/shell-execution.js.map +0 -1
- package/dist/managed-runtime/step-result.d.ts +0 -22
- package/dist/managed-runtime/step-result.d.ts.map +0 -1
- package/dist/managed-runtime/step-result.js +0 -252
- package/dist/managed-runtime/step-result.js.map +0 -1
- package/dist/managed-runtime/wake-signal.d.ts +0 -5
- package/dist/managed-runtime/wake-signal.d.ts.map +0 -1
- package/dist/managed-runtime/wake-signal.js +0 -29
- package/dist/managed-runtime/wake-signal.js.map +0 -1
- package/dist/managed-runtime.d.ts +0 -8
- package/dist/managed-runtime.d.ts.map +0 -1
- package/dist/managed-runtime.js +0 -268
- package/dist/managed-runtime.js.map +0 -1
- /package/dist/{managed-runtime → drive-sync}/drive-sync-filesystem.d.ts +0 -0
- /package/dist/{managed-runtime → drive-sync}/drive-sync-filesystem.js +0 -0
- /package/dist/{managed-runtime → drive-sync}/drive-sync-planner.d.ts +0 -0
- /package/dist/{managed-runtime → drive-sync}/drive-sync-planner.js +0 -0
- /package/dist/{managed-runtime → drive-sync}/drive-sync-remote-planner.d.ts +0 -0
- /package/dist/{managed-runtime → drive-sync}/drive-sync-remote-planner.js +0 -0
- /package/dist/{managed-runtime → drive-sync}/drive-sync-state-applier.d.ts +0 -0
- /package/dist/{managed-runtime → drive-sync}/drive-sync-state-applier.js +0 -0
- /package/dist/{managed-runtime → drive-sync}/drive-sync-transfer.d.ts +0 -0
- /package/dist/{managed-runtime → drive-sync}/drive-sync-transfer.js +0 -0
|
@@ -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":"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"}
|
|
@@ -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
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"shell-execution.d.ts","sourceRoot":"","sources":["../../src/managed-runtime/shell-execution.ts"],"names":[],"mappings":"AAAA,OAAO,EAA+B,KAAK,aAAa,EAAE,MAAM,kCAAkC,CAAA;AAYlG,MAAM,MAAM,sBAAsB,GAAG;IACnC,MAAM,EAAE,WAAW,GAAG,QAAQ,GAAG,WAAW,GAAG,WAAW,CAAA;IAC1D,MAAM,EAAE,MAAM,CAAA;IACd,MAAM,EAAE,MAAM,CAAA;IACd,mBAAmB,EAAE,MAAM,CAAA;IAC3B,mBAAmB,EAAE,MAAM,CAAA;IAC3B,mBAAmB,EAAE,MAAM,CAAA;IAC3B,mBAAmB,EAAE,MAAM,CAAA;IAC3B,eAAe,EAAE,OAAO,CAAA;IACxB,eAAe,EAAE,OAAO,CAAA;IACxB,kBAAkB,EAAE,MAAM,CAAA;IAC1B,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAA;IACvB,UAAU,EAAE,MAAM,CAAA;IAClB,KAAK,EAAE,MAAM,GAAG,IAAI,CAAA;CACrB,CAAA;AAED,MAAM,MAAM,qBAAqB,GAAG;IAClC,oBAAoB,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,MAAM,IAAI,CAAC,GAAG,IAAI,KAAK,IAAI,CAAA;IAC5D,GAAG,CAAC,EAAE,MAAM,CAAC,UAAU,CAAA;IACvB,kBAAkB,CAAC,EAAE,MAAM,CAAA;CAC5B,CAAA;AAED,wBAAsB,cAAc,CAClC,OAAO,EAAE,MAAM,EACf,SAAS,EAAE,MAAM,EACjB,OAAO,GAAE,qBAA0B,GAClC,OAAO,CAAC,sBAAsB,CAAC,CAmIjC;AAED,wBAAgB,6BAA6B,CAAC,MAAM,EAAE;IACpD,OAAO,EAAE,MAAM,CAAC,UAAU,CAAA;IAC1B,OAAO,EAAE,MAAM,CAAA;IACf,OAAO,EAAE,MAAM,GAAG,IAAI,CAAA;IACtB,gBAAgB,EAAE,MAAM,CAAA;IACxB,kBAAkB,EAAE,MAAM,CAAA;IAC1B,iBAAiB,EAAE,MAAM,CAAA;CAC1B,GAAG,MAAM,CAAC,UAAU,CAkCpB;AAED,wBAAgB,sBAAsB,CAAC,WAAW,EAAE,MAAM,GAAG,MAAM,CAElE;AAED,wBAAsB,wBAAwB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,GAAG,IAAI,CAAC,CAa1F"}
|
|
@@ -1,186 +0,0 @@
|
|
|
1
|
-
import { parseControlSignalCandidate } from '@panorama/shared/control-signals';
|
|
2
|
-
import { spawn } from 'node:child_process';
|
|
3
|
-
import { randomUUID } from 'node:crypto';
|
|
4
|
-
import { readFile, unlink } from 'node:fs/promises';
|
|
5
|
-
import { tmpdir } from 'node:os';
|
|
6
|
-
import { join } from 'node:path';
|
|
7
|
-
import { BoundedOutputCapture } from '../process-output-capture.js';
|
|
8
|
-
const DEFAULT_SIGTERM_GRACE_MS = 5_000;
|
|
9
|
-
const DEFAULT_OUTPUT_CAPTURE_BYTES = 5_000_000;
|
|
10
|
-
const CONTROL_SIGNAL_PATH_ENV = 'PANORAMA_CONTROL_SIGNAL_PATH';
|
|
11
|
-
export async function executeCommand(command, timeoutMs, options = {}) {
|
|
12
|
-
const startedAt = Date.now();
|
|
13
|
-
const outputCaptureBytes = options.outputCaptureBytes ?? DEFAULT_OUTPUT_CAPTURE_BYTES;
|
|
14
|
-
return await new Promise((resolve) => {
|
|
15
|
-
const child = spawn('bash', ['-lc', command], {
|
|
16
|
-
stdio: ['ignore', 'pipe', 'pipe'],
|
|
17
|
-
detached: true,
|
|
18
|
-
env: options.env,
|
|
19
|
-
});
|
|
20
|
-
const stdoutOutput = new BoundedOutputCapture(outputCaptureBytes);
|
|
21
|
-
const stderrOutput = new BoundedOutputCapture(outputCaptureBytes);
|
|
22
|
-
let resolved = false;
|
|
23
|
-
let timedOut = false;
|
|
24
|
-
let spawnError = null;
|
|
25
|
-
let interrupted = false;
|
|
26
|
-
let forceKillHandle = null;
|
|
27
|
-
const finish = (result) => {
|
|
28
|
-
if (resolved)
|
|
29
|
-
return;
|
|
30
|
-
resolved = true;
|
|
31
|
-
clearTimeout(timeoutHandle);
|
|
32
|
-
if (forceKillHandle) {
|
|
33
|
-
clearTimeout(forceKillHandle);
|
|
34
|
-
forceKillHandle = null;
|
|
35
|
-
}
|
|
36
|
-
options.registerCancellation?.(null);
|
|
37
|
-
resolve(result);
|
|
38
|
-
};
|
|
39
|
-
const killProcessGroup = (signal) => {
|
|
40
|
-
if (!child.pid)
|
|
41
|
-
return;
|
|
42
|
-
try {
|
|
43
|
-
process.kill(-child.pid, signal);
|
|
44
|
-
}
|
|
45
|
-
catch {
|
|
46
|
-
try {
|
|
47
|
-
child.kill(signal);
|
|
48
|
-
}
|
|
49
|
-
catch {
|
|
50
|
-
// ignore best-effort kill failures
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
};
|
|
54
|
-
const scheduleForceKill = () => {
|
|
55
|
-
if (forceKillHandle)
|
|
56
|
-
return;
|
|
57
|
-
forceKillHandle = setTimeout(() => {
|
|
58
|
-
forceKillHandle = null;
|
|
59
|
-
killProcessGroup('SIGKILL');
|
|
60
|
-
}, DEFAULT_SIGTERM_GRACE_MS);
|
|
61
|
-
forceKillHandle.unref();
|
|
62
|
-
};
|
|
63
|
-
const timeoutHandle = setTimeout(() => {
|
|
64
|
-
if (resolved)
|
|
65
|
-
return;
|
|
66
|
-
timedOut = true;
|
|
67
|
-
killProcessGroup('SIGTERM');
|
|
68
|
-
scheduleForceKill();
|
|
69
|
-
}, timeoutMs);
|
|
70
|
-
options.registerCancellation?.(() => {
|
|
71
|
-
if (resolved || interrupted)
|
|
72
|
-
return;
|
|
73
|
-
interrupted = true;
|
|
74
|
-
killProcessGroup('SIGTERM');
|
|
75
|
-
scheduleForceKill();
|
|
76
|
-
});
|
|
77
|
-
child.stdout?.on('data', (chunk) => {
|
|
78
|
-
stdoutOutput.append(chunk);
|
|
79
|
-
});
|
|
80
|
-
child.stderr?.on('data', (chunk) => {
|
|
81
|
-
stderrOutput.append(chunk);
|
|
82
|
-
});
|
|
83
|
-
child.on('error', (error) => {
|
|
84
|
-
spawnError = error.message;
|
|
85
|
-
});
|
|
86
|
-
child.on('close', (code) => {
|
|
87
|
-
const stdout = stdoutOutput.readText();
|
|
88
|
-
const stderr = stderrOutput.readText();
|
|
89
|
-
const durationMs = Date.now() - startedAt;
|
|
90
|
-
const commonResult = {
|
|
91
|
-
stdout,
|
|
92
|
-
stderr,
|
|
93
|
-
stdoutObservedBytes: stdoutOutput.observedBytes,
|
|
94
|
-
stderrObservedBytes: stderrOutput.observedBytes,
|
|
95
|
-
stdoutCapturedBytes: stdoutOutput.capturedBytes,
|
|
96
|
-
stderrCapturedBytes: stderrOutput.capturedBytes,
|
|
97
|
-
stdoutTruncated: stdoutOutput.truncated,
|
|
98
|
-
stderrTruncated: stderrOutput.truncated,
|
|
99
|
-
outputCaptureBytes,
|
|
100
|
-
exitCode: code,
|
|
101
|
-
durationMs,
|
|
102
|
-
};
|
|
103
|
-
if (timedOut) {
|
|
104
|
-
finish({
|
|
105
|
-
...commonResult,
|
|
106
|
-
status: 'timed_out',
|
|
107
|
-
error: `Command timed out after ${timeoutMs}ms`,
|
|
108
|
-
});
|
|
109
|
-
return;
|
|
110
|
-
}
|
|
111
|
-
if (interrupted) {
|
|
112
|
-
finish({
|
|
113
|
-
...commonResult,
|
|
114
|
-
status: 'cancelled',
|
|
115
|
-
error: 'Command was interrupted because the managed gateway host was stopping.',
|
|
116
|
-
});
|
|
117
|
-
return;
|
|
118
|
-
}
|
|
119
|
-
if (spawnError) {
|
|
120
|
-
finish({
|
|
121
|
-
...commonResult,
|
|
122
|
-
status: 'failed',
|
|
123
|
-
error: spawnError,
|
|
124
|
-
});
|
|
125
|
-
return;
|
|
126
|
-
}
|
|
127
|
-
finish({
|
|
128
|
-
...commonResult,
|
|
129
|
-
status: code === 0 ? 'succeeded' : 'failed',
|
|
130
|
-
error: code === 0 ? null : `Command exited with code ${code ?? 'unknown'}`,
|
|
131
|
-
});
|
|
132
|
-
});
|
|
133
|
-
});
|
|
134
|
-
}
|
|
135
|
-
export function buildManagedShellExecutionEnv(params) {
|
|
136
|
-
const safeEnv = {};
|
|
137
|
-
const passthroughKeys = [
|
|
138
|
-
'HOME',
|
|
139
|
-
'HOSTNAME',
|
|
140
|
-
'LANG',
|
|
141
|
-
'LC_ALL',
|
|
142
|
-
'LOGNAME',
|
|
143
|
-
'PATH',
|
|
144
|
-
'PWD',
|
|
145
|
-
'SHELL',
|
|
146
|
-
'SHLVL',
|
|
147
|
-
'TERM',
|
|
148
|
-
'TMPDIR',
|
|
149
|
-
'USER',
|
|
150
|
-
];
|
|
151
|
-
for (const key of passthroughKeys) {
|
|
152
|
-
const value = params.baseEnv[key];
|
|
153
|
-
if (typeof value === 'string' && value.length > 0) {
|
|
154
|
-
safeEnv[key] = value;
|
|
155
|
-
}
|
|
156
|
-
}
|
|
157
|
-
safeEnv.PANORAMA_AGENT_ID = params.agentId;
|
|
158
|
-
safeEnv.PANORAMA_TOOL_EXECUTION_URL = params.toolExecutionUrl;
|
|
159
|
-
safeEnv.PANORAMA_TOOL_EXECUTION_TOKEN = params.toolExecutionToken;
|
|
160
|
-
safeEnv[CONTROL_SIGNAL_PATH_ENV] = params.controlSignalPath;
|
|
161
|
-
if (params.cycleId) {
|
|
162
|
-
safeEnv.PANORAMA_AGENT_CYCLE_ID = params.cycleId;
|
|
163
|
-
}
|
|
164
|
-
return safeEnv;
|
|
165
|
-
}
|
|
166
|
-
export function buildControlSignalPath(executionId) {
|
|
167
|
-
return join(tmpdir(), `panorama-control-${executionId}-${randomUUID()}.json`);
|
|
168
|
-
}
|
|
169
|
-
export async function readCommandControlSignal(path) {
|
|
170
|
-
try {
|
|
171
|
-
const raw = await readFile(path, 'utf8');
|
|
172
|
-
return parseControlSignalCandidate(JSON.parse(raw));
|
|
173
|
-
}
|
|
174
|
-
catch {
|
|
175
|
-
return null;
|
|
176
|
-
}
|
|
177
|
-
finally {
|
|
178
|
-
try {
|
|
179
|
-
await unlink(path);
|
|
180
|
-
}
|
|
181
|
-
catch {
|
|
182
|
-
// best-effort cleanup
|
|
183
|
-
}
|
|
184
|
-
}
|
|
185
|
-
}
|
|
186
|
-
//# sourceMappingURL=shell-execution.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"shell-execution.js","sourceRoot":"","sources":["../../src/managed-runtime/shell-execution.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import type { CommandExecutionResult } from './shell-execution.js';
|
|
2
|
-
export type LinuxStepTerminalStatus = 'completed' | 'failed' | 'uncertain';
|
|
3
|
-
export type LinuxExecutionCompletion = {
|
|
4
|
-
stepStatus: LinuxStepTerminalStatus;
|
|
5
|
-
toolCallStatus: 'completed' | 'failed';
|
|
6
|
-
controlSignal: 'continue' | 'pause' | 'stop';
|
|
7
|
-
pauseDuration?: number;
|
|
8
|
-
uncertaintyReason?: string;
|
|
9
|
-
};
|
|
10
|
-
export declare function buildPreview(text: string): {
|
|
11
|
-
preview: string | null;
|
|
12
|
-
truncated: boolean;
|
|
13
|
-
};
|
|
14
|
-
export declare function buildOutputCaptureMetadata(stream: 'stdout' | 'stderr', result: CommandExecutionResult): Record<string, unknown>;
|
|
15
|
-
export declare function buildLinuxStepResultPayload(params: {
|
|
16
|
-
executionId: string;
|
|
17
|
-
command: string;
|
|
18
|
-
result: CommandExecutionResult;
|
|
19
|
-
completion: LinuxExecutionCompletion;
|
|
20
|
-
executionMetadata?: Record<string, unknown> | null;
|
|
21
|
-
}): Record<string, unknown>;
|
|
22
|
-
//# sourceMappingURL=step-result.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"step-result.d.ts","sourceRoot":"","sources":["../../src/managed-runtime/step-result.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,sBAAsB,CAAA;AAMlE,MAAM,MAAM,uBAAuB,GAAG,WAAW,GAAG,QAAQ,GAAG,WAAW,CAAA;AAE1E,MAAM,MAAM,wBAAwB,GAAG;IACrC,UAAU,EAAE,uBAAuB,CAAA;IACnC,cAAc,EAAE,WAAW,GAAG,QAAQ,CAAA;IACtC,aAAa,EAAE,UAAU,GAAG,OAAO,GAAG,MAAM,CAAA;IAC5C,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,iBAAiB,CAAC,EAAE,MAAM,CAAA;CAC3B,CAAA;AAUD,wBAAgB,YAAY,CAAC,IAAI,EAAE,MAAM,GAAG;IAAE,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IAAC,SAAS,EAAE,OAAO,CAAA;CAAE,CAezF;AAoBD,wBAAgB,0BAA0B,CACxC,MAAM,EAAE,QAAQ,GAAG,QAAQ,EAC3B,MAAM,EAAE,sBAAsB,GAC7B,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAoBzB;AA0ED,wBAAgB,2BAA2B,CAAC,MAAM,EAAE;IAClD,WAAW,EAAE,MAAM,CAAA;IACnB,OAAO,EAAE,MAAM,CAAA;IACf,MAAM,EAAE,sBAAsB,CAAA;IAC9B,UAAU,EAAE,wBAAwB,CAAA;IACpC,iBAAiB,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAA;CACnD,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CA0K1B"}
|