experimental-agent 0.1.3 → 0.2.0
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/agent-workflow.d.mts +2 -1
- package/dist/agent-workflow.d.ts +2 -1
- package/dist/agent-workflow.js +1382 -552
- package/dist/agent-workflow.mjs +3 -2
- package/dist/chunk-FQ67QZOI.mjs +75 -0
- package/dist/{chunk-RXPVLORL.mjs → chunk-GL7Q3MDU.mjs} +3 -7
- package/dist/{chunk-24UDM5XV.mjs → chunk-NXDVNJRS.mjs} +1 -1
- package/dist/chunk-OCF5I43X.mjs +2367 -0
- package/dist/chunk-OZZVS6L5.mjs +139 -0
- package/dist/{chunk-2ZXHR6T6.mjs → chunk-SJVFFE5D.mjs} +18 -17
- package/dist/chunk-TGNVXSMX.mjs +399 -0
- package/dist/chunk-UCVXI7LW.mjs +1287 -0
- package/dist/chunk-ZIAHPXOJ.mjs +595 -0
- package/dist/{client-SNN3XDKO.mjs → client-BKA7XBGW.mjs} +1 -1
- package/dist/{client-Bkuq-Dfa.d.mts → client-CSTexnLF.d.mts} +158 -122
- package/dist/{client-Bkuq-Dfa.d.ts → client-CSTexnLF.d.ts} +158 -122
- package/dist/{sandbox-IFK5MVRM.mjs → docker-FB2MJTHJ.mjs} +6 -4
- package/dist/{handler-WFNQWR6V.mjs → handler-FRUPZ4LX.mjs} +1 -1
- package/dist/index.d.mts +3 -2
- package/dist/index.d.ts +3 -2
- package/dist/index.js +1555 -596
- package/dist/index.mjs +140 -36
- package/dist/lifecycle-workflow.d.mts +2 -1
- package/dist/lifecycle-workflow.d.ts +2 -1
- package/dist/lifecycle-workflow.js +29 -18
- package/dist/lifecycle-workflow.mjs +1 -1
- package/dist/{local-fs-handlers-ESZBRAWK.mjs → local-fs-handlers-SYOCKTPN.mjs} +10 -2
- package/dist/next/loader.js +16 -12
- package/dist/next/loader.mjs +15 -7
- package/dist/next.d.mts +1 -1
- package/dist/next.d.ts +1 -1
- package/dist/next.js +3 -10
- package/dist/next.mjs +2 -5
- package/dist/{process-manager-ZCET3VD2.mjs → process-manager-JDUJDYGU.mjs} +1 -1
- package/dist/sandbox-HRGGTEHF.mjs +21 -0
- package/dist/{storage-FCSHTDLC.mjs → storage-LSDMRW73.mjs} +2 -2
- package/package.json +2 -6
- package/dist/chunk-4WDKWMVB.mjs +0 -389
- package/dist/chunk-64THY7Y7.mjs +0 -155
- package/dist/chunk-IACG26TC.mjs +0 -2212
- package/dist/chunk-NGLND33F.mjs +0 -1247
package/dist/chunk-64THY7Y7.mjs
DELETED
|
@@ -1,155 +0,0 @@
|
|
|
1
|
-
// src/sandbox/process-manager.ts
|
|
2
|
-
var DEFAULT_WAIT_UNTIL = 2e3;
|
|
3
|
-
var RUN_SCRIPT = `#!/bin/sh
|
|
4
|
-
# Process runner for Agent SDK
|
|
5
|
-
# All parameters passed via environment variables to avoid escaping issues
|
|
6
|
-
# Output is base64 encoded to avoid JSON escaping issues
|
|
7
|
-
|
|
8
|
-
AGENT_DIR="$HOME/.agent"
|
|
9
|
-
CWD_FILE="$AGENT_DIR/cwd/$SESSION_ID"
|
|
10
|
-
|
|
11
|
-
# Get current working directory (per-session)
|
|
12
|
-
if [ -f "$CWD_FILE" ]; then
|
|
13
|
-
CWD=$(cat "$CWD_FILE")
|
|
14
|
-
else
|
|
15
|
-
CWD="$HOME"
|
|
16
|
-
fi
|
|
17
|
-
|
|
18
|
-
# Decode command
|
|
19
|
-
CMD=$(echo "$CMD_BASE64" | base64 -d)
|
|
20
|
-
|
|
21
|
-
# Background mode (waitUntil = 0)
|
|
22
|
-
if [ "$WAIT_UNTIL" = "0" ]; then
|
|
23
|
-
cd "$CWD" || cd "$HOME"
|
|
24
|
-
|
|
25
|
-
# Generate a simple numeric ID for output file
|
|
26
|
-
OUTPUT_ID="$(date +%s)$$"
|
|
27
|
-
OUTPUT_FILE="$AGENT_DIR/outputs/$OUTPUT_ID.log"
|
|
28
|
-
|
|
29
|
-
# Double-fork to fully detach the process
|
|
30
|
-
(
|
|
31
|
-
(
|
|
32
|
-
eval "$CMD"
|
|
33
|
-
pwd > "$CWD_FILE" 2>/dev/null
|
|
34
|
-
) > "$OUTPUT_FILE" 2>&1 < /dev/null &
|
|
35
|
-
echo $! > "$AGENT_DIR/pids/$OUTPUT_ID.pid"
|
|
36
|
-
)
|
|
37
|
-
|
|
38
|
-
# Small delay to ensure PID file is written
|
|
39
|
-
sleep 0.05
|
|
40
|
-
|
|
41
|
-
# Read PID
|
|
42
|
-
if [ -f "$AGENT_DIR/pids/$OUTPUT_ID.pid" ]; then
|
|
43
|
-
PID=$(cat "$AGENT_DIR/pids/$OUTPUT_ID.pid")
|
|
44
|
-
else
|
|
45
|
-
PID=0
|
|
46
|
-
fi
|
|
47
|
-
|
|
48
|
-
# Output JSON result (no output for background, so no encoding needed)
|
|
49
|
-
printf '{"pid":%d,"outputBase64":"","exitCode":-1,"status":"running","outputFile":"%s","cwd":"%s"}\\n' \\
|
|
50
|
-
"$PID" "$OUTPUT_FILE" "$CWD"
|
|
51
|
-
exit 0
|
|
52
|
-
fi
|
|
53
|
-
|
|
54
|
-
# Foreground mode (waitUntil > 0) - run directly and capture output
|
|
55
|
-
cd "$CWD" || cd "$HOME"
|
|
56
|
-
|
|
57
|
-
# Run command, capture output and exit code
|
|
58
|
-
OUTPUT=$(eval "$CMD" 2>&1)
|
|
59
|
-
EXIT_CODE=$?
|
|
60
|
-
|
|
61
|
-
# Update CWD after command
|
|
62
|
-
NEW_CWD=$(pwd)
|
|
63
|
-
echo "$NEW_CWD" > "$CWD_FILE"
|
|
64
|
-
|
|
65
|
-
# Determine status
|
|
66
|
-
if [ $EXIT_CODE -eq 0 ]; then
|
|
67
|
-
STATUS="completed"
|
|
68
|
-
else
|
|
69
|
-
STATUS="failed"
|
|
70
|
-
fi
|
|
71
|
-
|
|
72
|
-
# Base64 encode output to avoid ALL escaping issues
|
|
73
|
-
OUTPUT_BASE64=$(printf '%s' "$OUTPUT" | base64 | tr -d '\\n')
|
|
74
|
-
|
|
75
|
-
# Output JSON result with base64-encoded output
|
|
76
|
-
printf '{"pid":0,"outputBase64":"%s","exitCode":%d,"status":"%s","outputFile":"","cwd":"%s"}\\n' \\
|
|
77
|
-
"$OUTPUT_BASE64" "$EXIT_CODE" "$STATUS" "$NEW_CWD"
|
|
78
|
-
`;
|
|
79
|
-
var createProcessManager = (opts) => {
|
|
80
|
-
const { sandbox, sessionId } = opts;
|
|
81
|
-
let initialized = false;
|
|
82
|
-
const init = async () => {
|
|
83
|
-
if (initialized) {
|
|
84
|
-
return;
|
|
85
|
-
}
|
|
86
|
-
const result = await sandbox.exec({
|
|
87
|
-
command: "sh",
|
|
88
|
-
args: [
|
|
89
|
-
"-c",
|
|
90
|
-
`mkdir -p $HOME/.agent/bin $HOME/.agent/pids $HOME/.agent/outputs $HOME/.agent/cwd
|
|
91
|
-
cat > $HOME/.agent/bin/run.sh << 'SCRIPT_EOF'
|
|
92
|
-
${RUN_SCRIPT}
|
|
93
|
-
SCRIPT_EOF
|
|
94
|
-
chmod +x $HOME/.agent/bin/run.sh`
|
|
95
|
-
]
|
|
96
|
-
});
|
|
97
|
-
if (result instanceof Error) {
|
|
98
|
-
throw result;
|
|
99
|
-
}
|
|
100
|
-
await result.result;
|
|
101
|
-
initialized = true;
|
|
102
|
-
};
|
|
103
|
-
const run = async (opts2) => {
|
|
104
|
-
await init();
|
|
105
|
-
const { command, waitUntil = DEFAULT_WAIT_UNTIL } = opts2;
|
|
106
|
-
const cmdBase64 = Buffer.from(command, "utf-8").toString("base64");
|
|
107
|
-
const result = await sandbox.exec({
|
|
108
|
-
command: "sh",
|
|
109
|
-
args: [
|
|
110
|
-
"-c",
|
|
111
|
-
`CMD_BASE64="${cmdBase64}" WAIT_UNTIL="${waitUntil}" SESSION_ID="${sessionId}" $HOME/.agent/bin/run.sh`
|
|
112
|
-
]
|
|
113
|
-
});
|
|
114
|
-
if (result instanceof Error) {
|
|
115
|
-
throw result;
|
|
116
|
-
}
|
|
117
|
-
const { stdout } = await result.result;
|
|
118
|
-
const parsed = JSON.parse(stdout.trim());
|
|
119
|
-
const output = parsed.outputBase64 ? Buffer.from(parsed.outputBase64, "base64").toString("utf-8") : "";
|
|
120
|
-
return {
|
|
121
|
-
pid: parsed.pid,
|
|
122
|
-
output,
|
|
123
|
-
exitCode: parsed.exitCode,
|
|
124
|
-
status: parsed.status,
|
|
125
|
-
cwd: parsed.cwd,
|
|
126
|
-
outputFile: parsed.outputFile
|
|
127
|
-
};
|
|
128
|
-
};
|
|
129
|
-
const getCwd = async () => {
|
|
130
|
-
await init();
|
|
131
|
-
const result = await sandbox.exec({
|
|
132
|
-
command: "sh",
|
|
133
|
-
args: [
|
|
134
|
-
"-c",
|
|
135
|
-
`cat $HOME/.agent/cwd/${sessionId} 2>/dev/null || echo "$HOME"`
|
|
136
|
-
]
|
|
137
|
-
});
|
|
138
|
-
if (result instanceof Error) {
|
|
139
|
-
return process.cwd();
|
|
140
|
-
}
|
|
141
|
-
const { stdout } = await result.result;
|
|
142
|
-
return stdout.trim() || process.cwd();
|
|
143
|
-
};
|
|
144
|
-
return {
|
|
145
|
-
init,
|
|
146
|
-
run,
|
|
147
|
-
getCwd
|
|
148
|
-
};
|
|
149
|
-
};
|
|
150
|
-
|
|
151
|
-
export {
|
|
152
|
-
DEFAULT_WAIT_UNTIL,
|
|
153
|
-
createProcessManager
|
|
154
|
-
};
|
|
155
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/sandbox/process-manager.ts"],
  "sourcesContent": ["import type { BashResult, Sandbox } from \"./types\";\n\nexport const DEFAULT_WAIT_UNTIL = 2000;\n\n/**\n * Shell script that handles all process execution logic.\n * Installed to ~/.agent/bin/run.sh during init().\n */\nconst RUN_SCRIPT = `#!/bin/sh\n# Process runner for Agent SDK\n# All parameters passed via environment variables to avoid escaping issues\n# Output is base64 encoded to avoid JSON escaping issues\n\nAGENT_DIR=\"$HOME/.agent\"\nCWD_FILE=\"$AGENT_DIR/cwd/$SESSION_ID\"\n\n# Get current working directory (per-session)\nif [ -f \"$CWD_FILE\" ]; then\n  CWD=$(cat \"$CWD_FILE\")\nelse\n  CWD=\"$HOME\"\nfi\n\n# Decode command\nCMD=$(echo \"$CMD_BASE64\" | base64 -d)\n\n# Background mode (waitUntil = 0)\nif [ \"$WAIT_UNTIL\" = \"0\" ]; then\n  cd \"$CWD\" || cd \"$HOME\"\n\n  # Generate a simple numeric ID for output file\n  OUTPUT_ID=\"$(date +%s)$$\"\n  OUTPUT_FILE=\"$AGENT_DIR/outputs/$OUTPUT_ID.log\"\n\n  # Double-fork to fully detach the process\n  (\n    (\n      eval \"$CMD\"\n      pwd > \"$CWD_FILE\" 2>/dev/null\n    ) > \"$OUTPUT_FILE\" 2>&1 < /dev/null &\n    echo $! > \"$AGENT_DIR/pids/$OUTPUT_ID.pid\"\n  )\n\n  # Small delay to ensure PID file is written\n  sleep 0.05\n\n  # Read PID\n  if [ -f \"$AGENT_DIR/pids/$OUTPUT_ID.pid\" ]; then\n    PID=$(cat \"$AGENT_DIR/pids/$OUTPUT_ID.pid\")\n  else\n    PID=0\n  fi\n\n  # Output JSON result (no output for background, so no encoding needed)\n  printf '{\"pid\":%d,\"outputBase64\":\"\",\"exitCode\":-1,\"status\":\"running\",\"outputFile\":\"%s\",\"cwd\":\"%s\"}\\\\n' \\\\\n    \"$PID\" \"$OUTPUT_FILE\" \"$CWD\"\n  exit 0\nfi\n\n# Foreground mode (waitUntil > 0) - run directly and capture output\ncd \"$CWD\" || cd \"$HOME\"\n\n# Run command, capture output and exit code\nOUTPUT=$(eval \"$CMD\" 2>&1)\nEXIT_CODE=$?\n\n# Update CWD after command\nNEW_CWD=$(pwd)\necho \"$NEW_CWD\" > \"$CWD_FILE\"\n\n# Determine status\nif [ $EXIT_CODE -eq 0 ]; then\n  STATUS=\"completed\"\nelse\n  STATUS=\"failed\"\nfi\n\n# Base64 encode output to avoid ALL escaping issues\nOUTPUT_BASE64=$(printf '%s' \"$OUTPUT\" | base64 | tr -d '\\\\n')\n\n# Output JSON result with base64-encoded output\nprintf '{\"pid\":0,\"outputBase64\":\"%s\",\"exitCode\":%d,\"status\":\"%s\",\"outputFile\":\"\",\"cwd\":\"%s\"}\\\\n' \\\\\n  \"$OUTPUT_BASE64\" \"$EXIT_CODE\" \"$STATUS\" \"$NEW_CWD\"\n`;\n\ntype RunOptions = {\n  command: string;\n  /**\n   * Max ms to wait for completion.\n   * - 0: Background mode - return immediately with PID\n   * - >0: Foreground mode - wait for completion (default: 30000)\n   */\n  waitUntil?: number;\n};\n\n/**\n * Process manager that uses a single shell script to handle all execution logic.\n * Reduces round-trips to the sandbox by doing everything in one exec call.\n */\nexport const createProcessManager = (opts: {\n  sandbox: Sandbox;\n  sessionId: string;\n}) => {\n  const { sandbox, sessionId } = opts;\n  let initialized = false;\n\n  const init = async (): Promise<void> => {\n    if (initialized) {\n      return;\n    }\n\n    const result = await sandbox.exec({\n      command: \"sh\",\n      args: [\n        \"-c\",\n        `mkdir -p $HOME/.agent/bin $HOME/.agent/pids $HOME/.agent/outputs $HOME/.agent/cwd\ncat > $HOME/.agent/bin/run.sh << 'SCRIPT_EOF'\n${RUN_SCRIPT}\nSCRIPT_EOF\nchmod +x $HOME/.agent/bin/run.sh`,\n      ],\n    });\n\n    if (result instanceof Error) {\n      throw result;\n    }\n    await result.result;\n    initialized = true;\n  };\n\n  const run = async (opts: RunOptions): Promise<BashResult> => {\n    await init();\n\n    const { command, waitUntil = DEFAULT_WAIT_UNTIL } = opts;\n    const cmdBase64 = Buffer.from(command, \"utf-8\").toString(\"base64\");\n\n    const result = await sandbox.exec({\n      command: \"sh\",\n      args: [\n        \"-c\",\n        `CMD_BASE64=\"${cmdBase64}\" WAIT_UNTIL=\"${waitUntil}\" SESSION_ID=\"${sessionId}\" $HOME/.agent/bin/run.sh`,\n      ],\n    });\n\n    if (result instanceof Error) {\n      throw result;\n    }\n\n    const { stdout } = await result.result;\n    const parsed = JSON.parse(stdout.trim()) as {\n      pid: number;\n      outputBase64: string;\n      exitCode: number;\n      status: \"running\" | \"completed\" | \"failed\";\n      outputFile: string;\n      cwd: string;\n    };\n\n    // Decode base64 output\n    const output = parsed.outputBase64\n      ? Buffer.from(parsed.outputBase64, \"base64\").toString(\"utf-8\")\n      : \"\";\n\n    return {\n      pid: parsed.pid,\n      output,\n      exitCode: parsed.exitCode,\n      status: parsed.status,\n      cwd: parsed.cwd,\n      outputFile: parsed.outputFile,\n    };\n  };\n\n  const getCwd = async (): Promise<string> => {\n    await init();\n\n    const result = await sandbox.exec({\n      command: \"sh\",\n      args: [\n        \"-c\",\n        `cat $HOME/.agent/cwd/${sessionId} 2>/dev/null || echo \"$HOME\"`,\n      ],\n    });\n\n    if (result instanceof Error) {\n      return process.cwd();\n    }\n\n    const { stdout } = await result.result;\n    return stdout.trim() || process.cwd();\n  };\n\n  return {\n    init,\n    run,\n    getCwd,\n  };\n};\n\nexport type ProcessManager = ReturnType<typeof createProcessManager>;\n"],
  "mappings": ";AAEO,IAAM,qBAAqB;AAMlC,IAAM,aAAa;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AA2FZ,IAAM,uBAAuB,CAAC,SAG/B;AACJ,QAAM,EAAE,SAAS,UAAU,IAAI;AAC/B,MAAI,cAAc;AAElB,QAAM,OAAO,YAA2B;AACtC,QAAI,aAAa;AACf;AAAA,IACF;AAEA,UAAM,SAAS,MAAM,QAAQ,KAAK;AAAA,MAChC,SAAS;AAAA,MACT,MAAM;AAAA,QACJ;AAAA,QACA;AAAA;AAAA,EAEN,UAAU;AAAA;AAAA;AAAA,MAGN;AAAA,IACF,CAAC;AAED,QAAI,kBAAkB,OAAO;AAC3B,YAAM;AAAA,IACR;AACA,UAAM,OAAO;AACb,kBAAc;AAAA,EAChB;AAEA,QAAM,MAAM,OAAOA,UAA0C;AAC3D,UAAM,KAAK;AAEX,UAAM,EAAE,SAAS,YAAY,mBAAmB,IAAIA;AACpD,UAAM,YAAY,OAAO,KAAK,SAAS,OAAO,EAAE,SAAS,QAAQ;AAEjE,UAAM,SAAS,MAAM,QAAQ,KAAK;AAAA,MAChC,SAAS;AAAA,MACT,MAAM;AAAA,QACJ;AAAA,QACA,eAAe,SAAS,iBAAiB,SAAS,iBAAiB,SAAS;AAAA,MAC9E;AAAA,IACF,CAAC;AAED,QAAI,kBAAkB,OAAO;AAC3B,YAAM;AAAA,IACR;AAEA,UAAM,EAAE,OAAO,IAAI,MAAM,OAAO;AAChC,UAAM,SAAS,KAAK,MAAM,OAAO,KAAK,CAAC;AAUvC,UAAM,SAAS,OAAO,eAClB,OAAO,KAAK,OAAO,cAAc,QAAQ,EAAE,SAAS,OAAO,IAC3D;AAEJ,WAAO;AAAA,MACL,KAAK,OAAO;AAAA,MACZ;AAAA,MACA,UAAU,OAAO;AAAA,MACjB,QAAQ,OAAO;AAAA,MACf,KAAK,OAAO;AAAA,MACZ,YAAY,OAAO;AAAA,IACrB;AAAA,EACF;AAEA,QAAM,SAAS,YAA6B;AAC1C,UAAM,KAAK;AAEX,UAAM,SAAS,MAAM,QAAQ,KAAK;AAAA,MAChC,SAAS;AAAA,MACT,MAAM;AAAA,QACJ;AAAA,QACA,wBAAwB,SAAS;AAAA,MACnC;AAAA,IACF,CAAC;AAED,QAAI,kBAAkB,OAAO;AAC3B,aAAO,QAAQ,IAAI;AAAA,IACrB;AAEA,UAAM,EAAE,OAAO,IAAI,MAAM,OAAO;AAChC,WAAO,OAAO,KAAK,KAAK,QAAQ,IAAI;AAAA,EACtC;AAEA,SAAO;AAAA,IACL;AAAA,IACA;AAAA,IACA;AAAA,EACF;AACF;",
  "names": ["opts"]
}

|