@action-llama/action-llama 0.2.0 → 0.4.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.
Files changed (235) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +61 -90
  3. package/dist/agents/container-entry.js +183 -43
  4. package/dist/agents/container-entry.js.map +1 -1
  5. package/dist/agents/container-runner.d.ts +11 -4
  6. package/dist/agents/container-runner.d.ts.map +1 -1
  7. package/dist/agents/container-runner.js +107 -99
  8. package/dist/agents/container-runner.js.map +1 -1
  9. package/dist/agents/prompt.d.ts +2 -0
  10. package/dist/agents/prompt.d.ts.map +1 -1
  11. package/dist/agents/prompt.js +18 -10
  12. package/dist/agents/prompt.js.map +1 -1
  13. package/dist/agents/runner.d.ts +10 -1
  14. package/dist/agents/runner.d.ts.map +1 -1
  15. package/dist/agents/runner.js +95 -9
  16. package/dist/agents/runner.js.map +1 -1
  17. package/dist/cli/commands/cloud-setup.d.ts +4 -0
  18. package/dist/cli/commands/cloud-setup.d.ts.map +1 -0
  19. package/dist/cli/commands/cloud-setup.js +565 -0
  20. package/dist/cli/commands/cloud-setup.js.map +1 -0
  21. package/dist/cli/commands/cloud-teardown.d.ts +6 -0
  22. package/dist/cli/commands/cloud-teardown.d.ts.map +1 -0
  23. package/dist/cli/commands/cloud-teardown.js +152 -0
  24. package/dist/cli/commands/cloud-teardown.js.map +1 -0
  25. package/dist/cli/commands/{setup.d.ts → console.d.ts} +1 -1
  26. package/dist/cli/commands/console.d.ts.map +1 -0
  27. package/dist/cli/commands/console.js +273 -0
  28. package/dist/cli/commands/console.js.map +1 -0
  29. package/dist/cli/commands/creds.d.ts +2 -0
  30. package/dist/cli/commands/creds.d.ts.map +1 -0
  31. package/dist/cli/commands/creds.js +62 -0
  32. package/dist/cli/commands/creds.js.map +1 -0
  33. package/dist/cli/commands/doctor.d.ts +7 -0
  34. package/dist/cli/commands/doctor.d.ts.map +1 -0
  35. package/dist/cli/commands/doctor.js +405 -0
  36. package/dist/cli/commands/doctor.js.map +1 -0
  37. package/dist/cli/commands/logs.d.ts +1 -0
  38. package/dist/cli/commands/logs.d.ts.map +1 -1
  39. package/dist/cli/commands/logs.js +67 -0
  40. package/dist/cli/commands/logs.js.map +1 -1
  41. package/dist/cli/commands/new.d.ts.map +1 -1
  42. package/dist/cli/commands/new.js +30 -28
  43. package/dist/cli/commands/new.js.map +1 -1
  44. package/dist/cli/commands/run.d.ts +6 -0
  45. package/dist/cli/commands/run.d.ts.map +1 -0
  46. package/dist/cli/commands/run.js +121 -0
  47. package/dist/cli/commands/run.js.map +1 -0
  48. package/dist/cli/commands/start.d.ts +2 -1
  49. package/dist/cli/commands/start.d.ts.map +1 -1
  50. package/dist/cli/commands/start.js +41 -14
  51. package/dist/cli/commands/start.js.map +1 -1
  52. package/dist/cli/commands/status.d.ts +1 -0
  53. package/dist/cli/commands/status.d.ts.map +1 -1
  54. package/dist/cli/commands/status.js +39 -2
  55. package/dist/cli/commands/status.js.map +1 -1
  56. package/dist/cli/main.js +61 -12
  57. package/dist/cli/main.js.map +1 -1
  58. package/dist/credentials/builtins/anthropic-key.d.ts.map +1 -1
  59. package/dist/credentials/builtins/anthropic-key.js +3 -4
  60. package/dist/credentials/builtins/anthropic-key.js.map +1 -1
  61. package/dist/credentials/builtins/aws.d.ts +4 -0
  62. package/dist/credentials/builtins/aws.d.ts.map +1 -0
  63. package/dist/credentials/builtins/aws.js +33 -0
  64. package/dist/credentials/builtins/aws.js.map +1 -0
  65. package/dist/credentials/builtins/bugsnag-token.d.ts +4 -0
  66. package/dist/credentials/builtins/bugsnag-token.d.ts.map +1 -0
  67. package/dist/credentials/builtins/bugsnag-token.js +18 -0
  68. package/dist/credentials/builtins/bugsnag-token.js.map +1 -0
  69. package/dist/credentials/builtins/github-token.d.ts.map +1 -1
  70. package/dist/credentials/builtins/github-token.js +1 -2
  71. package/dist/credentials/builtins/github-token.js.map +1 -1
  72. package/dist/credentials/builtins/github-webhook-secret.js +3 -3
  73. package/dist/credentials/builtins/github-webhook-secret.js.map +1 -1
  74. package/dist/credentials/builtins/id-rsa.d.ts +2 -2
  75. package/dist/credentials/builtins/id-rsa.d.ts.map +1 -1
  76. package/dist/credentials/builtins/id-rsa.js +75 -47
  77. package/dist/credentials/builtins/id-rsa.js.map +1 -1
  78. package/dist/credentials/builtins/index.d.ts.map +1 -1
  79. package/dist/credentials/builtins/index.js +17 -7
  80. package/dist/credentials/builtins/index.js.map +1 -1
  81. package/dist/credentials/builtins/netlify-token.d.ts +4 -0
  82. package/dist/credentials/builtins/netlify-token.d.ts.map +1 -0
  83. package/dist/credentials/builtins/netlify-token.js +18 -0
  84. package/dist/credentials/builtins/netlify-token.js.map +1 -0
  85. package/dist/credentials/builtins/openai-key.d.ts +4 -0
  86. package/dist/credentials/builtins/openai-key.d.ts.map +1 -0
  87. package/dist/credentials/builtins/openai-key.js +38 -0
  88. package/dist/credentials/builtins/openai-key.js.map +1 -0
  89. package/dist/credentials/builtins/sentry-client-secret.d.ts.map +1 -1
  90. package/dist/credentials/builtins/sentry-client-secret.js +1 -2
  91. package/dist/credentials/builtins/sentry-client-secret.js.map +1 -1
  92. package/dist/credentials/builtins/sentry-token.d.ts.map +1 -1
  93. package/dist/credentials/builtins/sentry-token.js +2 -3
  94. package/dist/credentials/builtins/sentry-token.js.map +1 -1
  95. package/dist/credentials/builtins/x-twitter-api.d.ts +4 -0
  96. package/dist/credentials/builtins/x-twitter-api.d.ts.map +1 -0
  97. package/dist/credentials/builtins/x-twitter-api.js +28 -0
  98. package/dist/credentials/builtins/x-twitter-api.js.map +1 -0
  99. package/dist/credentials/prompter.d.ts +1 -1
  100. package/dist/credentials/prompter.d.ts.map +1 -1
  101. package/dist/credentials/prompter.js +14 -21
  102. package/dist/credentials/prompter.js.map +1 -1
  103. package/dist/credentials/schema.d.ts +0 -1
  104. package/dist/credentials/schema.d.ts.map +1 -1
  105. package/dist/credentials/schema.js +2 -3
  106. package/dist/credentials/schema.js.map +1 -1
  107. package/dist/docker/cloud-run-runtime.d.ts +61 -0
  108. package/dist/docker/cloud-run-runtime.d.ts.map +1 -0
  109. package/dist/docker/cloud-run-runtime.js +510 -0
  110. package/dist/docker/cloud-run-runtime.js.map +1 -0
  111. package/dist/docker/ecs-runtime.d.ts +73 -0
  112. package/dist/docker/ecs-runtime.d.ts.map +1 -0
  113. package/dist/docker/ecs-runtime.js +596 -0
  114. package/dist/docker/ecs-runtime.js.map +1 -0
  115. package/dist/docker/image.d.ts +8 -0
  116. package/dist/docker/image.d.ts.map +1 -1
  117. package/dist/docker/image.js +28 -3
  118. package/dist/docker/image.js.map +1 -1
  119. package/dist/docker/local-runtime.d.ts +19 -0
  120. package/dist/docker/local-runtime.d.ts.map +1 -0
  121. package/dist/docker/local-runtime.js +209 -0
  122. package/dist/docker/local-runtime.js.map +1 -0
  123. package/dist/docker/network.d.ts +1 -1
  124. package/dist/docker/network.d.ts.map +1 -1
  125. package/dist/docker/network.js +2 -1
  126. package/dist/docker/network.js.map +1 -1
  127. package/dist/docker/runtime.d.ts +90 -0
  128. package/dist/docker/runtime.d.ts.map +1 -0
  129. package/dist/docker/runtime.js +2 -0
  130. package/dist/docker/runtime.js.map +1 -0
  131. package/dist/gateway/index.d.ts +8 -2
  132. package/dist/gateway/index.d.ts.map +1 -1
  133. package/dist/gateway/index.js +16 -8
  134. package/dist/gateway/index.js.map +1 -1
  135. package/dist/gateway/routes/credentials.d.ts +5 -0
  136. package/dist/gateway/routes/credentials.d.ts.map +1 -0
  137. package/dist/gateway/routes/credentials.js +17 -0
  138. package/dist/gateway/routes/credentials.js.map +1 -0
  139. package/dist/gateway/routes/logs.d.ts +5 -0
  140. package/dist/gateway/routes/logs.d.ts.map +1 -0
  141. package/dist/gateway/routes/logs.js +31 -0
  142. package/dist/gateway/routes/logs.js.map +1 -0
  143. package/dist/gateway/routes/shutdown.d.ts +2 -1
  144. package/dist/gateway/routes/shutdown.d.ts.map +1 -1
  145. package/dist/gateway/routes/shutdown.js +7 -16
  146. package/dist/gateway/routes/shutdown.js.map +1 -1
  147. package/dist/gateway/routes/webhooks.d.ts +2 -1
  148. package/dist/gateway/routes/webhooks.d.ts.map +1 -1
  149. package/dist/gateway/routes/webhooks.js +11 -4
  150. package/dist/gateway/routes/webhooks.js.map +1 -1
  151. package/dist/gateway/types.d.ts +6 -0
  152. package/dist/gateway/types.d.ts.map +1 -0
  153. package/dist/gateway/types.js +2 -0
  154. package/dist/gateway/types.js.map +1 -0
  155. package/dist/scheduler/index.d.ts +3 -2
  156. package/dist/scheduler/index.d.ts.map +1 -1
  157. package/dist/scheduler/index.js +299 -59
  158. package/dist/scheduler/index.js.map +1 -1
  159. package/dist/setup/prompts.d.ts.map +1 -1
  160. package/dist/setup/prompts.js +14 -21
  161. package/dist/setup/prompts.js.map +1 -1
  162. package/dist/setup/scaffold.d.ts +2 -2
  163. package/dist/setup/scaffold.d.ts.map +1 -1
  164. package/dist/setup/scaffold.js +369 -27
  165. package/dist/setup/scaffold.js.map +1 -1
  166. package/dist/setup/validators.d.ts +14 -0
  167. package/dist/setup/validators.d.ts.map +1 -1
  168. package/dist/setup/validators.js +53 -0
  169. package/dist/setup/validators.js.map +1 -1
  170. package/dist/shared/asm-backend.d.ts +25 -0
  171. package/dist/shared/asm-backend.d.ts.map +1 -0
  172. package/dist/shared/asm-backend.js +107 -0
  173. package/dist/shared/asm-backend.js.map +1 -0
  174. package/dist/shared/aws-constants.d.ts +55 -0
  175. package/dist/shared/aws-constants.d.ts.map +1 -0
  176. package/dist/shared/aws-constants.js +55 -0
  177. package/dist/shared/aws-constants.js.map +1 -0
  178. package/dist/shared/config.d.ts +25 -5
  179. package/dist/shared/config.d.ts.map +1 -1
  180. package/dist/shared/config.js +15 -22
  181. package/dist/shared/config.js.map +1 -1
  182. package/dist/shared/credential-backend.d.ts +28 -0
  183. package/dist/shared/credential-backend.d.ts.map +1 -0
  184. package/dist/shared/credential-backend.js +2 -0
  185. package/dist/shared/credential-backend.js.map +1 -0
  186. package/dist/shared/credentials.d.ts +75 -5
  187. package/dist/shared/credentials.d.ts.map +1 -1
  188. package/dist/shared/credentials.js +141 -24
  189. package/dist/shared/credentials.js.map +1 -1
  190. package/dist/shared/filesystem-backend.d.ts +18 -0
  191. package/dist/shared/filesystem-backend.d.ts.map +1 -0
  192. package/dist/shared/filesystem-backend.js +86 -0
  193. package/dist/shared/filesystem-backend.js.map +1 -0
  194. package/dist/shared/git.js +1 -1
  195. package/dist/shared/git.js.map +1 -1
  196. package/dist/shared/gsm-backend.d.ts +35 -0
  197. package/dist/shared/gsm-backend.d.ts.map +1 -0
  198. package/dist/shared/gsm-backend.js +208 -0
  199. package/dist/shared/gsm-backend.js.map +1 -0
  200. package/dist/shared/remote.d.ts +11 -0
  201. package/dist/shared/remote.d.ts.map +1 -0
  202. package/dist/shared/remote.js +29 -0
  203. package/dist/shared/remote.js.map +1 -0
  204. package/dist/tui/App.d.ts.map +1 -1
  205. package/dist/tui/App.js +22 -7
  206. package/dist/tui/App.js.map +1 -1
  207. package/dist/tui/status-tracker.d.ts +6 -3
  208. package/dist/tui/status-tracker.d.ts.map +1 -1
  209. package/dist/tui/status-tracker.js +14 -2
  210. package/dist/tui/status-tracker.js.map +1 -1
  211. package/dist/webhooks/definitions/github.js +1 -1
  212. package/dist/webhooks/definitions/sentry.js +1 -1
  213. package/dist/webhooks/providers/github.d.ts +1 -1
  214. package/dist/webhooks/providers/github.d.ts.map +1 -1
  215. package/dist/webhooks/providers/github.js +13 -9
  216. package/dist/webhooks/providers/github.js.map +1 -1
  217. package/dist/webhooks/providers/sentry.d.ts +1 -1
  218. package/dist/webhooks/providers/sentry.d.ts.map +1 -1
  219. package/dist/webhooks/providers/sentry.js +12 -9
  220. package/dist/webhooks/providers/sentry.js.map +1 -1
  221. package/dist/webhooks/registry.d.ts +1 -1
  222. package/dist/webhooks/registry.d.ts.map +1 -1
  223. package/dist/webhooks/registry.js +20 -13
  224. package/dist/webhooks/registry.js.map +1 -1
  225. package/dist/webhooks/types.d.ts +16 -6
  226. package/dist/webhooks/types.d.ts.map +1 -1
  227. package/docker/Dockerfile +4 -11
  228. package/package.json +12 -3
  229. package/dist/cli/commands/setup.d.ts.map +0 -1
  230. package/dist/cli/commands/setup.js +0 -60
  231. package/dist/cli/commands/setup.js.map +0 -1
  232. package/dist/docker/container.d.ts +0 -19
  233. package/dist/docker/container.d.ts.map +0 -1
  234. package/dist/docker/container.js +0 -73
  235. package/dist/docker/container.js.map +0 -1
@@ -1,60 +0,0 @@
1
- import { resolve } from "path";
2
- import { discoverAgents, loadAgentConfig, loadGlobalConfig } from "../../shared/config.js";
3
- import { resolveCredential } from "../../credentials/registry.js";
4
- import { promptCredential } from "../../credentials/prompter.js";
5
- import { loadCredential, writeCredential, writeStructuredCredential } from "../../shared/credentials.js";
6
- function writeCredentialValues(def, values) {
7
- if (Object.keys(values).length === 0)
8
- return;
9
- if (def.fields.length === 1) {
10
- writeCredential(def.filename, values[def.fields[0].name]);
11
- }
12
- else {
13
- writeStructuredCredential(def.filename, values);
14
- }
15
- }
16
- export async function execute(opts) {
17
- const projectPath = resolve(opts.project);
18
- const agents = discoverAgents(projectPath);
19
- if (agents.length === 0) {
20
- console.log("No agents found. Create agents first, then re-run setup.");
21
- return;
22
- }
23
- // Collect all credential IDs from agents and global config
24
- const credentialIds = new Set();
25
- for (const name of agents) {
26
- const config = loadAgentConfig(projectPath, name);
27
- for (const id of config.credentials) {
28
- credentialIds.add(id);
29
- }
30
- }
31
- const globalConfig = loadGlobalConfig(projectPath);
32
- if (globalConfig.webhooks?.secretCredentials) {
33
- for (const id of Object.values(globalConfig.webhooks.secretCredentials)) {
34
- credentialIds.add(id);
35
- }
36
- }
37
- if (credentialIds.size === 0) {
38
- console.log("No credentials required by any agent.");
39
- return;
40
- }
41
- console.log(`\nChecking ${credentialIds.size} credential(s)...\n`);
42
- let okCount = 0;
43
- let promptedCount = 0;
44
- for (const id of credentialIds) {
45
- const def = resolveCredential(id);
46
- const existing = loadCredential(def.filename);
47
- if (existing) {
48
- console.log(` [ok] ${def.label}`);
49
- okCount++;
50
- continue;
51
- }
52
- const result = await promptCredential(def);
53
- if (result && Object.keys(result.values).length > 0) {
54
- writeCredentialValues(def, result.values);
55
- promptedCount++;
56
- }
57
- }
58
- console.log(`\nDone. ${okCount} already present, ${promptedCount} configured.`);
59
- }
60
- //# sourceMappingURL=setup.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"setup.js","sourceRoot":"","sources":["../../../src/cli/commands/setup.ts"],"names":[],"mappings":"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"}
@@ -1,19 +0,0 @@
1
- export interface ContainerOptions {
2
- image: string;
3
- agentName: string;
4
- agentConfig: string;
5
- shutdownSecret: string;
6
- gatewayUrl: string;
7
- prompt: string;
8
- credentialsStagingDir: string;
9
- memory?: string;
10
- cpus?: number;
11
- timeout?: number;
12
- }
13
- export declare function launchContainer(opts: ContainerOptions): string;
14
- export declare function waitForContainer(containerName: string, timeoutSeconds?: number): {
15
- exitCode: number;
16
- };
17
- export declare function getContainerLogs(containerName: string): string;
18
- export declare function removeContainer(containerName: string): void;
19
- //# sourceMappingURL=container.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"container.d.ts","sourceRoot":"","sources":["../../src/docker/container.ts"],"names":[],"mappings":"AAIA,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;IAClB,WAAW,EAAE,MAAM,CAAC;IACpB,cAAc,EAAE,MAAM,CAAC;IACvB,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,MAAM,CAAC;IACf,qBAAqB,EAAE,MAAM,CAAC;IAC9B,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AASD,wBAAgB,eAAe,CAAC,IAAI,EAAE,gBAAgB,GAAG,MAAM,CA+B9D;AAED,wBAAgB,gBAAgB,CAAC,aAAa,EAAE,MAAM,EAAE,cAAc,CAAC,EAAE,MAAM,GAAG;IAAE,QAAQ,EAAE,MAAM,CAAA;CAAE,CAerG;AAED,wBAAgB,gBAAgB,CAAC,aAAa,EAAE,MAAM,GAAG,MAAM,CAM9D;AAED,wBAAgB,eAAe,CAAC,aAAa,EAAE,MAAM,GAAG,IAAI,CAM3D"}
@@ -1,73 +0,0 @@
1
- import { execFileSync } from "child_process";
2
- import { randomUUID } from "crypto";
3
- import { NETWORK_NAME } from "./network.js";
4
- function docker(...args) {
5
- return execFileSync("docker", args, {
6
- encoding: "utf-8",
7
- timeout: 30000,
8
- }).trim();
9
- }
10
- export function launchContainer(opts) {
11
- const runId = randomUUID().slice(0, 8);
12
- const containerName = `al-${opts.agentName}-${runId}`;
13
- const memory = opts.memory || "4g";
14
- const cpus = opts.cpus || 2;
15
- const args = [
16
- "run", "-d",
17
- "--name", containerName,
18
- "--network", NETWORK_NAME,
19
- "--user", "1000:1000",
20
- "--read-only",
21
- "--tmpfs", "/tmp:rw,nosuid,uid=1000,gid=1000,size=512m",
22
- "--tmpfs", "/workspace:rw,exec,nosuid,uid=1000,gid=1000,size=2g",
23
- "--tmpfs", "/home/node:rw,nosuid,uid=1000,gid=1000,size=64m",
24
- "--cap-drop", "ALL",
25
- "--security-opt", "no-new-privileges:true",
26
- "--pids-limit", "256",
27
- "--memory", memory,
28
- "--cpus", String(cpus),
29
- "-v", `${opts.credentialsStagingDir}:/credentials:ro`,
30
- "-e", `GATEWAY_URL=${opts.gatewayUrl}`,
31
- "-e", `SHUTDOWN_SECRET=${opts.shutdownSecret}`,
32
- "-e", `AGENT_CONFIG=${opts.agentConfig}`,
33
- "-e", `PROMPT=${opts.prompt}`,
34
- opts.image,
35
- ];
36
- docker(...args);
37
- return containerName;
38
- }
39
- export function waitForContainer(containerName, timeoutSeconds) {
40
- const timeout = timeoutSeconds || 3600;
41
- try {
42
- const result = execFileSync("docker", ["wait", containerName], {
43
- encoding: "utf-8",
44
- timeout: timeout * 1000,
45
- }).trim();
46
- return { exitCode: parseInt(result, 10) };
47
- }
48
- catch (err) {
49
- // Timeout — kill the container
50
- try {
51
- docker("kill", containerName);
52
- }
53
- catch { /* already dead */ }
54
- throw new Error(`Container ${containerName} timed out after ${timeout}s`);
55
- }
56
- }
57
- export function getContainerLogs(containerName) {
58
- try {
59
- return docker("logs", containerName);
60
- }
61
- catch {
62
- return "";
63
- }
64
- }
65
- export function removeContainer(containerName) {
66
- try {
67
- docker("rm", "-f", containerName);
68
- }
69
- catch {
70
- // Container may already be removed
71
- }
72
- }
73
- //# sourceMappingURL=container.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"container.js","sourceRoot":"","sources":["../../src/docker/container.ts"],"names":[],"mappings":"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"}