localant 1.0.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 (218) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +290 -0
  3. package/SECURITY.md +87 -0
  4. package/examples/skills/hello-world/CHANGELOG.md +4 -0
  5. package/examples/skills/hello-world/LICENSE +1 -0
  6. package/examples/skills/hello-world/README.md +20 -0
  7. package/examples/skills/hello-world/examples/example.json +1 -0
  8. package/examples/skills/hello-world/package.json +9 -0
  9. package/examples/skills/hello-world/skill.json +32 -0
  10. package/examples/skills/hello-world/src/index.ts +19 -0
  11. package/examples/skills/hello-world/tests/index.test.ts +19 -0
  12. package/package.json +63 -0
  13. package/packages/cli/dist/bin.d.ts +3 -0
  14. package/packages/cli/dist/bin.d.ts.map +1 -0
  15. package/packages/cli/dist/bin.js +261 -0
  16. package/packages/cli/dist/bin.js.map +1 -0
  17. package/packages/cli/dist/doctor.d.ts +3 -0
  18. package/packages/cli/dist/doctor.d.ts.map +1 -0
  19. package/packages/cli/dist/doctor.js +35 -0
  20. package/packages/cli/dist/doctor.js.map +1 -0
  21. package/packages/cli/dist/index.d.ts +3 -0
  22. package/packages/cli/dist/index.d.ts.map +1 -0
  23. package/packages/cli/dist/index.js +3 -0
  24. package/packages/cli/dist/index.js.map +1 -0
  25. package/packages/cli/dist/runtime.d.ts +11 -0
  26. package/packages/cli/dist/runtime.d.ts.map +1 -0
  27. package/packages/cli/dist/runtime.js +82 -0
  28. package/packages/cli/dist/runtime.js.map +1 -0
  29. package/packages/cli/dist/util.d.ts +18 -0
  30. package/packages/cli/dist/util.d.ts.map +1 -0
  31. package/packages/cli/dist/util.js +47 -0
  32. package/packages/cli/dist/util.js.map +1 -0
  33. package/packages/cli/package.json +19 -0
  34. package/packages/dashboard/dist/index.d.ts +10 -0
  35. package/packages/dashboard/dist/index.d.ts.map +1 -0
  36. package/packages/dashboard/dist/index.js +178 -0
  37. package/packages/dashboard/dist/index.js.map +1 -0
  38. package/packages/dashboard/package.json +10 -0
  39. package/packages/gateway/dist/gateway.d.ts +85 -0
  40. package/packages/gateway/dist/gateway.d.ts.map +1 -0
  41. package/packages/gateway/dist/gateway.js +234 -0
  42. package/packages/gateway/dist/gateway.js.map +1 -0
  43. package/packages/gateway/dist/index.d.ts +13 -0
  44. package/packages/gateway/dist/index.d.ts.map +1 -0
  45. package/packages/gateway/dist/index.js +16 -0
  46. package/packages/gateway/dist/index.js.map +1 -0
  47. package/packages/gateway/dist/managers/coding-agent-manager.d.ts +71 -0
  48. package/packages/gateway/dist/managers/coding-agent-manager.d.ts.map +1 -0
  49. package/packages/gateway/dist/managers/coding-agent-manager.js +179 -0
  50. package/packages/gateway/dist/managers/coding-agent-manager.js.map +1 -0
  51. package/packages/gateway/dist/managers/fs-manager.d.ts +63 -0
  52. package/packages/gateway/dist/managers/fs-manager.d.ts.map +1 -0
  53. package/packages/gateway/dist/managers/fs-manager.js +229 -0
  54. package/packages/gateway/dist/managers/fs-manager.js.map +1 -0
  55. package/packages/gateway/dist/managers/git-manager.d.ts +21 -0
  56. package/packages/gateway/dist/managers/git-manager.d.ts.map +1 -0
  57. package/packages/gateway/dist/managers/git-manager.js +67 -0
  58. package/packages/gateway/dist/managers/git-manager.js.map +1 -0
  59. package/packages/gateway/dist/managers/mcp-bridge.d.ts +26 -0
  60. package/packages/gateway/dist/managers/mcp-bridge.d.ts.map +1 -0
  61. package/packages/gateway/dist/managers/mcp-bridge.js +92 -0
  62. package/packages/gateway/dist/managers/mcp-bridge.js.map +1 -0
  63. package/packages/gateway/dist/managers/project-registry.d.ts +17 -0
  64. package/packages/gateway/dist/managers/project-registry.d.ts.map +1 -0
  65. package/packages/gateway/dist/managers/project-registry.js +90 -0
  66. package/packages/gateway/dist/managers/project-registry.js.map +1 -0
  67. package/packages/gateway/dist/managers/shell-manager.d.ts +48 -0
  68. package/packages/gateway/dist/managers/shell-manager.d.ts.map +1 -0
  69. package/packages/gateway/dist/managers/shell-manager.js +132 -0
  70. package/packages/gateway/dist/managers/shell-manager.js.map +1 -0
  71. package/packages/gateway/dist/managers/skill-runtime.d.ts +37 -0
  72. package/packages/gateway/dist/managers/skill-runtime.d.ts.map +1 -0
  73. package/packages/gateway/dist/managers/skill-runtime.js +310 -0
  74. package/packages/gateway/dist/managers/skill-runtime.js.map +1 -0
  75. package/packages/gateway/dist/managers/tunnel-manager.d.ts +23 -0
  76. package/packages/gateway/dist/managers/tunnel-manager.d.ts.map +1 -0
  77. package/packages/gateway/dist/managers/tunnel-manager.js +106 -0
  78. package/packages/gateway/dist/managers/tunnel-manager.js.map +1 -0
  79. package/packages/gateway/dist/registry.d.ts +28 -0
  80. package/packages/gateway/dist/registry.d.ts.map +1 -0
  81. package/packages/gateway/dist/registry.js +20 -0
  82. package/packages/gateway/dist/registry.js.map +1 -0
  83. package/packages/gateway/dist/security/command-guard.d.ts +35 -0
  84. package/packages/gateway/dist/security/command-guard.d.ts.map +1 -0
  85. package/packages/gateway/dist/security/command-guard.js +105 -0
  86. package/packages/gateway/dist/security/command-guard.js.map +1 -0
  87. package/packages/gateway/dist/security/path-guard.d.ts +31 -0
  88. package/packages/gateway/dist/security/path-guard.d.ts.map +1 -0
  89. package/packages/gateway/dist/security/path-guard.js +101 -0
  90. package/packages/gateway/dist/security/path-guard.js.map +1 -0
  91. package/packages/gateway/dist/skill-runner.d.ts +2 -0
  92. package/packages/gateway/dist/skill-runner.d.ts.map +1 -0
  93. package/packages/gateway/dist/skill-runner.js +38 -0
  94. package/packages/gateway/dist/skill-runner.js.map +1 -0
  95. package/packages/gateway/dist/stores/approval-store.d.ts +34 -0
  96. package/packages/gateway/dist/stores/approval-store.d.ts.map +1 -0
  97. package/packages/gateway/dist/stores/approval-store.js +108 -0
  98. package/packages/gateway/dist/stores/approval-store.js.map +1 -0
  99. package/packages/gateway/dist/stores/audit-log.d.ts +23 -0
  100. package/packages/gateway/dist/stores/audit-log.d.ts.map +1 -0
  101. package/packages/gateway/dist/stores/audit-log.js +70 -0
  102. package/packages/gateway/dist/stores/audit-log.js.map +1 -0
  103. package/packages/gateway/dist/stores/config-store.d.ts +14 -0
  104. package/packages/gateway/dist/stores/config-store.d.ts.map +1 -0
  105. package/packages/gateway/dist/stores/config-store.js +57 -0
  106. package/packages/gateway/dist/stores/config-store.js.map +1 -0
  107. package/packages/gateway/dist/stores/secret-vault.d.ts +23 -0
  108. package/packages/gateway/dist/stores/secret-vault.d.ts.map +1 -0
  109. package/packages/gateway/dist/stores/secret-vault.js +74 -0
  110. package/packages/gateway/dist/stores/secret-vault.js.map +1 -0
  111. package/packages/gateway/dist/tools/adapters.d.ts +8 -0
  112. package/packages/gateway/dist/tools/adapters.d.ts.map +1 -0
  113. package/packages/gateway/dist/tools/adapters.js +178 -0
  114. package/packages/gateway/dist/tools/adapters.js.map +1 -0
  115. package/packages/gateway/dist/tools/adb.d.ts +3 -0
  116. package/packages/gateway/dist/tools/adb.d.ts.map +1 -0
  117. package/packages/gateway/dist/tools/adb.js +60 -0
  118. package/packages/gateway/dist/tools/adb.js.map +1 -0
  119. package/packages/gateway/dist/tools/article.d.ts +3 -0
  120. package/packages/gateway/dist/tools/article.d.ts.map +1 -0
  121. package/packages/gateway/dist/tools/article.js +230 -0
  122. package/packages/gateway/dist/tools/article.js.map +1 -0
  123. package/packages/gateway/dist/tools/audit-approval.d.ts +4 -0
  124. package/packages/gateway/dist/tools/audit-approval.d.ts.map +1 -0
  125. package/packages/gateway/dist/tools/audit-approval.js +64 -0
  126. package/packages/gateway/dist/tools/audit-approval.js.map +1 -0
  127. package/packages/gateway/dist/tools/browser.d.ts +3 -0
  128. package/packages/gateway/dist/tools/browser.d.ts.map +1 -0
  129. package/packages/gateway/dist/tools/browser.js +55 -0
  130. package/packages/gateway/dist/tools/browser.js.map +1 -0
  131. package/packages/gateway/dist/tools/coding-agent.d.ts +3 -0
  132. package/packages/gateway/dist/tools/coding-agent.d.ts.map +1 -0
  133. package/packages/gateway/dist/tools/coding-agent.js +103 -0
  134. package/packages/gateway/dist/tools/coding-agent.js.map +1 -0
  135. package/packages/gateway/dist/tools/filesystem.d.ts +3 -0
  136. package/packages/gateway/dist/tools/filesystem.d.ts.map +1 -0
  137. package/packages/gateway/dist/tools/filesystem.js +141 -0
  138. package/packages/gateway/dist/tools/filesystem.js.map +1 -0
  139. package/packages/gateway/dist/tools/git.d.ts +3 -0
  140. package/packages/gateway/dist/tools/git.d.ts.map +1 -0
  141. package/packages/gateway/dist/tools/git.js +92 -0
  142. package/packages/gateway/dist/tools/git.js.map +1 -0
  143. package/packages/gateway/dist/tools/index.d.ts +4 -0
  144. package/packages/gateway/dist/tools/index.d.ts.map +1 -0
  145. package/packages/gateway/dist/tools/index.js +29 -0
  146. package/packages/gateway/dist/tools/index.js.map +1 -0
  147. package/packages/gateway/dist/tools/project.d.ts +3 -0
  148. package/packages/gateway/dist/tools/project.d.ts.map +1 -0
  149. package/packages/gateway/dist/tools/project.js +86 -0
  150. package/packages/gateway/dist/tools/project.js.map +1 -0
  151. package/packages/gateway/dist/tools/shell.d.ts +3 -0
  152. package/packages/gateway/dist/tools/shell.d.ts.map +1 -0
  153. package/packages/gateway/dist/tools/shell.js +98 -0
  154. package/packages/gateway/dist/tools/shell.js.map +1 -0
  155. package/packages/gateway/dist/tools/skill.d.ts +3 -0
  156. package/packages/gateway/dist/tools/skill.d.ts.map +1 -0
  157. package/packages/gateway/dist/tools/skill.js +231 -0
  158. package/packages/gateway/dist/tools/skill.js.map +1 -0
  159. package/packages/gateway/dist/tools/system.d.ts +3 -0
  160. package/packages/gateway/dist/tools/system.d.ts.map +1 -0
  161. package/packages/gateway/dist/tools/system.js +78 -0
  162. package/packages/gateway/dist/tools/system.js.map +1 -0
  163. package/packages/gateway/dist/util/exec.d.ts +21 -0
  164. package/packages/gateway/dist/util/exec.d.ts.map +1 -0
  165. package/packages/gateway/dist/util/exec.js +50 -0
  166. package/packages/gateway/dist/util/exec.js.map +1 -0
  167. package/packages/gateway/package.json +18 -0
  168. package/packages/mcp/dist/http-server.d.ts +16 -0
  169. package/packages/mcp/dist/http-server.d.ts.map +1 -0
  170. package/packages/mcp/dist/http-server.js +138 -0
  171. package/packages/mcp/dist/http-server.js.map +1 -0
  172. package/packages/mcp/dist/index.d.ts +4 -0
  173. package/packages/mcp/dist/index.d.ts.map +1 -0
  174. package/packages/mcp/dist/index.js +3 -0
  175. package/packages/mcp/dist/index.js.map +1 -0
  176. package/packages/mcp/dist/mcp-server.d.ts +9 -0
  177. package/packages/mcp/dist/mcp-server.d.ts.map +1 -0
  178. package/packages/mcp/dist/mcp-server.js +26 -0
  179. package/packages/mcp/dist/mcp-server.js.map +1 -0
  180. package/packages/mcp/package.json +18 -0
  181. package/packages/shared/dist/config.d.ts +314 -0
  182. package/packages/shared/dist/config.d.ts.map +1 -0
  183. package/packages/shared/dist/config.js +146 -0
  184. package/packages/shared/dist/config.js.map +1 -0
  185. package/packages/shared/dist/index.d.ts +8 -0
  186. package/packages/shared/dist/index.d.ts.map +1 -0
  187. package/packages/shared/dist/index.js +8 -0
  188. package/packages/shared/dist/index.js.map +1 -0
  189. package/packages/shared/dist/logger.d.ts +8 -0
  190. package/packages/shared/dist/logger.d.ts.map +1 -0
  191. package/packages/shared/dist/logger.js +26 -0
  192. package/packages/shared/dist/logger.js.map +1 -0
  193. package/packages/shared/dist/net.d.ts +10 -0
  194. package/packages/shared/dist/net.d.ts.map +1 -0
  195. package/packages/shared/dist/net.js +35 -0
  196. package/packages/shared/dist/net.js.map +1 -0
  197. package/packages/shared/dist/paths.d.ts +30 -0
  198. package/packages/shared/dist/paths.d.ts.map +1 -0
  199. package/packages/shared/dist/paths.js +70 -0
  200. package/packages/shared/dist/paths.js.map +1 -0
  201. package/packages/shared/dist/redaction.d.ts +15 -0
  202. package/packages/shared/dist/redaction.d.ts.map +1 -0
  203. package/packages/shared/dist/redaction.js +58 -0
  204. package/packages/shared/dist/redaction.js.map +1 -0
  205. package/packages/shared/dist/risk.d.ts +23 -0
  206. package/packages/shared/dist/risk.d.ts.map +1 -0
  207. package/packages/shared/dist/risk.js +28 -0
  208. package/packages/shared/dist/risk.js.map +1 -0
  209. package/packages/shared/dist/types.d.ts +94 -0
  210. package/packages/shared/dist/types.d.ts.map +1 -0
  211. package/packages/shared/dist/types.js +2 -0
  212. package/packages/shared/dist/types.js.map +1 -0
  213. package/packages/shared/package.json +13 -0
  214. package/packages/skill-sdk/dist/index.d.ts +36 -0
  215. package/packages/skill-sdk/dist/index.d.ts.map +1 -0
  216. package/packages/skill-sdk/dist/index.js +20 -0
  217. package/packages/skill-sdk/dist/index.js.map +1 -0
  218. package/packages/skill-sdk/package.json +14 -0
@@ -0,0 +1,141 @@
1
+ import { z } from "zod";
2
+ export function registerFilesystemTools(gw) {
3
+ const r = gw.registry;
4
+ r.register({
5
+ name: "fs_list_allowed_directories",
6
+ description: "List directories the gateway is allowed to access.",
7
+ risk: 0,
8
+ inputSchema: z.object({}).strip(),
9
+ handler: () => ({ allowed: gw.pathGuard.allowed() }),
10
+ });
11
+ r.register({
12
+ name: "fs_add_allowed_directory",
13
+ description: "Add a directory to the filesystem allowlist.",
14
+ risk: 2,
15
+ inputSchema: z.object({ path: z.string() }),
16
+ summarize: (i) => `allow directory ${i.path}`,
17
+ handler: (i) => {
18
+ const cfg = gw.config();
19
+ const dirs = Array.from(new Set([...cfg.security.allowedDirectories, i.path]));
20
+ gw.saveConfig({ ...cfg, security: { ...cfg.security, allowedDirectories: dirs } });
21
+ return { allowed: gw.pathGuard.allowed() };
22
+ },
23
+ });
24
+ r.register({
25
+ name: "fs_remove_allowed_directory",
26
+ description: "Remove a directory from the filesystem allowlist.",
27
+ risk: 2,
28
+ inputSchema: z.object({ path: z.string() }),
29
+ handler: (i) => {
30
+ const cfg = gw.config();
31
+ const dirs = cfg.security.allowedDirectories.filter((d) => d !== i.path);
32
+ gw.saveConfig({ ...cfg, security: { ...cfg.security, allowedDirectories: dirs } });
33
+ return { allowed: gw.pathGuard.allowed() };
34
+ },
35
+ });
36
+ r.register({
37
+ name: "fs_list_files",
38
+ description: "List files in a directory inside the allowlist.",
39
+ risk: 0,
40
+ inputSchema: z.object({ path: z.string() }),
41
+ handler: (i) => gw.fs.listFiles(i.path),
42
+ });
43
+ r.register({
44
+ name: "fs_read_file",
45
+ description: "Read a text file inside the allowlist.",
46
+ risk: 0,
47
+ inputSchema: z.object({ path: z.string() }),
48
+ handler: (i) => ({ path: i.path, content: gw.fs.readFile(i.path) }),
49
+ });
50
+ r.register({
51
+ name: "fs_read_file_range",
52
+ description: "Read a line range from a file (1-indexed, inclusive).",
53
+ risk: 0,
54
+ inputSchema: z.object({ path: z.string(), startLine: z.number().int().min(1), endLine: z.number().int().min(1) }),
55
+ handler: (i) => ({ path: i.path, content: gw.fs.readRange(i.path, i.startLine, i.endLine) }),
56
+ });
57
+ r.register({
58
+ name: "fs_search_files",
59
+ description: "Find files by glob pattern under a directory.",
60
+ risk: 0,
61
+ inputSchema: z.object({ path: z.string(), pattern: z.string(), limit: z.number().int().min(1).max(1000).default(200) }),
62
+ handler: (i) => ({ matches: gw.fs.searchFiles(i.path, i.pattern, i.limit) }),
63
+ });
64
+ r.register({
65
+ name: "fs_search_content",
66
+ description: "Search file contents for a substring under a directory.",
67
+ risk: 0,
68
+ inputSchema: z.object({ path: z.string(), query: z.string(), limit: z.number().int().min(1).max(1000).default(200) }),
69
+ handler: (i) => ({ matches: gw.fs.searchContent(i.path, i.query, i.limit) }),
70
+ });
71
+ r.register({
72
+ name: "fs_get_file_info",
73
+ description: "Get metadata for a file or directory.",
74
+ risk: 0,
75
+ inputSchema: z.object({ path: z.string() }),
76
+ handler: (i) => gw.fs.getInfo(i.path),
77
+ });
78
+ r.register({
79
+ name: "fs_write_draft_file",
80
+ description: "Create a NEW draft file. Refuses to overwrite existing files.",
81
+ risk: 1,
82
+ inputSchema: z.object({ path: z.string(), content: z.string() }),
83
+ summarize: (i) => `write draft ${i.path}`,
84
+ handler: (i) => gw.fs.writeDraft(i.path, i.content),
85
+ });
86
+ r.register({
87
+ name: "fs_create_file",
88
+ description: "Create a file, optionally overwriting (a backup is kept on overwrite).",
89
+ risk: 2,
90
+ inputSchema: z.object({ path: z.string(), content: z.string(), overwrite: z.boolean().default(false) }),
91
+ summarize: (i) => `create file ${i.path}${i.overwrite ? " (overwrite)" : ""}`,
92
+ handler: (i) => gw.fs.createFile(i.path, i.content, i.overwrite),
93
+ });
94
+ r.register({
95
+ name: "fs_apply_patch_with_backup",
96
+ description: "Replace an existing file's contents, keeping a backup.",
97
+ risk: 2,
98
+ inputSchema: z.object({ path: z.string(), content: z.string() }),
99
+ summarize: (i) => `patch file ${i.path}`,
100
+ handler: (i) => gw.fs.applyPatchWithBackup(i.path, i.content),
101
+ });
102
+ r.register({
103
+ name: "fs_move_file",
104
+ description: "Move/rename a file within the allowlist.",
105
+ risk: 2,
106
+ inputSchema: z.object({ from: z.string(), to: z.string() }),
107
+ summarize: (i) => `move ${i.from} -> ${i.to}`,
108
+ handler: (i) => gw.fs.moveFile(i.from, i.to),
109
+ });
110
+ r.register({
111
+ name: "fs_delete_file_with_approval",
112
+ description: "Delete a file (a backup is kept). Requires approval.",
113
+ risk: 3,
114
+ inputSchema: z.object({ path: z.string() }),
115
+ summarize: (i) => `delete file ${i.path}`,
116
+ handler: (i) => gw.fs.deleteFile(i.path),
117
+ });
118
+ r.register({
119
+ name: "fs_backup_file",
120
+ description: "Create a backup of a file.",
121
+ risk: 1,
122
+ inputSchema: z.object({ path: z.string() }),
123
+ handler: (i) => gw.fs.backup(i.path),
124
+ });
125
+ r.register({
126
+ name: "fs_restore_backup",
127
+ description: "Restore a previously created backup by id.",
128
+ risk: 2,
129
+ inputSchema: z.object({ id: z.string() }),
130
+ summarize: (i) => `restore backup ${i.id}`,
131
+ handler: (i) => gw.fs.restoreBackup(i.id),
132
+ });
133
+ r.register({
134
+ name: "fs_list_backups",
135
+ description: "List available file backups.",
136
+ risk: 0,
137
+ inputSchema: z.object({}).strip(),
138
+ handler: () => gw.fs.listBackups(),
139
+ });
140
+ }
141
+ //# sourceMappingURL=filesystem.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"filesystem.js","sourceRoot":"","sources":["../../src/tools/filesystem.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { Gateway } from "../gateway.js";
2
+ export declare function registerGitTools(gw: Gateway): void;
3
+ //# sourceMappingURL=git.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"git.d.ts","sourceRoot":"","sources":["../../src/tools/git.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAQ7C,wBAAgB,gBAAgB,CAAC,EAAE,EAAE,OAAO,GAAG,IAAI,CAqFlD"}
@@ -0,0 +1,92 @@
1
+ import { z } from "zod";
2
+ /** Resolve a project id or raw path to a filesystem path. */
3
+ function resolveRepo(gw, repoOrId) {
4
+ const project = gw.projects.get(repoOrId);
5
+ return project ? project.path : repoOrId;
6
+ }
7
+ export function registerGitTools(gw) {
8
+ const r = gw.registry;
9
+ const repoArg = z.object({ repo: z.string().describe("Project id/name or path") });
10
+ r.register({
11
+ name: "git_status",
12
+ description: "Show git status for a project or repo path.",
13
+ risk: 0,
14
+ inputSchema: repoArg,
15
+ handler: async (i) => ({ output: await gw.git.status(resolveRepo(gw, i.repo)) }),
16
+ });
17
+ r.register({
18
+ name: "git_diff",
19
+ description: "Show the working-tree diff.",
20
+ risk: 0,
21
+ inputSchema: repoArg,
22
+ handler: async (i) => ({ output: await gw.git.diff(resolveRepo(gw, i.repo)) }),
23
+ });
24
+ r.register({
25
+ name: "git_diff_file",
26
+ description: "Show the diff for a single file.",
27
+ risk: 0,
28
+ inputSchema: z.object({ repo: z.string(), file: z.string() }),
29
+ handler: async (i) => ({ output: await gw.git.diffFile(resolveRepo(gw, i.repo), i.file) }),
30
+ });
31
+ r.register({
32
+ name: "git_list_changed_files",
33
+ description: "List changed files (porcelain).",
34
+ risk: 0,
35
+ inputSchema: repoArg,
36
+ handler: async (i) => ({ output: await gw.git.listChangedFiles(resolveRepo(gw, i.repo)) }),
37
+ });
38
+ r.register({
39
+ name: "git_branch",
40
+ description: "List branches.",
41
+ risk: 0,
42
+ inputSchema: repoArg,
43
+ handler: async (i) => ({ output: await gw.git.branch(resolveRepo(gw, i.repo)) }),
44
+ });
45
+ r.register({
46
+ name: "git_log",
47
+ description: "Show recent commit log.",
48
+ risk: 0,
49
+ inputSchema: z.object({ repo: z.string(), n: z.number().int().min(1).max(200).default(20) }),
50
+ handler: async (i) => ({ output: await gw.git.log(resolveRepo(gw, i.repo), i.n) }),
51
+ });
52
+ r.register({
53
+ name: "git_create_patch",
54
+ description: "Create a patch of current changes.",
55
+ risk: 0,
56
+ inputSchema: repoArg,
57
+ handler: async (i) => ({ patch: await gw.git.createPatch(resolveRepo(gw, i.repo)) }),
58
+ });
59
+ r.register({
60
+ name: "git_create_branch",
61
+ description: "Create and checkout a new branch.",
62
+ risk: 2,
63
+ inputSchema: z.object({ repo: z.string(), name: z.string() }),
64
+ summarize: (i) => `git branch ${i.name}`,
65
+ handler: async (i) => ({ output: await gw.git.createBranch(resolveRepo(gw, i.repo), i.name) }),
66
+ });
67
+ r.register({
68
+ name: "git_checkout_branch",
69
+ description: "Checkout an existing branch.",
70
+ risk: 2,
71
+ inputSchema: z.object({ repo: z.string(), name: z.string() }),
72
+ summarize: (i) => `git checkout ${i.name}`,
73
+ handler: async (i) => ({ output: await gw.git.checkoutBranch(resolveRepo(gw, i.repo), i.name) }),
74
+ });
75
+ r.register({
76
+ name: "git_commit",
77
+ description: "Commit changes with a message (optionally git add -A first).",
78
+ risk: 3,
79
+ inputSchema: z.object({ repo: z.string(), message: z.string(), addAll: z.boolean().default(true) }),
80
+ summarize: (i) => `git commit: ${i.message.slice(0, 60)}`,
81
+ handler: async (i) => ({ output: await gw.git.commit(resolveRepo(gw, i.repo), i.message, i.addAll) }),
82
+ });
83
+ r.register({
84
+ name: "git_restore_file",
85
+ description: "Discard changes to a file (git restore).",
86
+ risk: 3,
87
+ inputSchema: z.object({ repo: z.string(), file: z.string() }),
88
+ summarize: (i) => `git restore ${i.file}`,
89
+ handler: async (i) => ({ output: await gw.git.restoreFile(resolveRepo(gw, i.repo), i.file) }),
90
+ });
91
+ }
92
+ //# sourceMappingURL=git.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"git.js","sourceRoot":"","sources":["../../src/tools/git.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ import type { Gateway } from "../gateway.js";
2
+ /** Register every built-in tool family onto the gateway registry. */
3
+ export declare function registerAllTools(gw: Gateway): void;
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/tools/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAc7C,qEAAqE;AACrE,wBAAgB,gBAAgB,CAAC,EAAE,EAAE,OAAO,GAAG,IAAI,CAclD"}
@@ -0,0 +1,29 @@
1
+ import { registerSystemTools } from "./system.js";
2
+ import { registerAuditTools, registerApprovalTools } from "./audit-approval.js";
3
+ import { registerProjectTools } from "./project.js";
4
+ import { registerFilesystemTools } from "./filesystem.js";
5
+ import { registerGitTools } from "./git.js";
6
+ import { registerShellTools } from "./shell.js";
7
+ import { registerSkillTools } from "./skill.js";
8
+ import { registerCodingAgentTools } from "./coding-agent.js";
9
+ import { registerAdbTools } from "./adb.js";
10
+ import { registerBrowserTools } from "./browser.js";
11
+ import { registerArticleTools } from "./article.js";
12
+ import { registerAdapterTools } from "./adapters.js";
13
+ /** Register every built-in tool family onto the gateway registry. */
14
+ export function registerAllTools(gw) {
15
+ registerSystemTools(gw);
16
+ registerAuditTools(gw);
17
+ registerApprovalTools(gw);
18
+ registerProjectTools(gw);
19
+ registerFilesystemTools(gw);
20
+ registerGitTools(gw);
21
+ registerShellTools(gw);
22
+ registerSkillTools(gw);
23
+ registerCodingAgentTools(gw);
24
+ registerAdbTools(gw);
25
+ registerBrowserTools(gw);
26
+ registerArticleTools(gw);
27
+ registerAdapterTools(gw);
28
+ }
29
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/tools/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAClD,OAAO,EAAE,kBAAkB,EAAE,qBAAqB,EAAE,MAAM,qBAAqB,CAAC;AAChF,OAAO,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAC;AACpD,OAAO,EAAE,uBAAuB,EAAE,MAAM,iBAAiB,CAAC;AAC1D,OAAO,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAC;AAC5C,OAAO,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAChD,OAAO,EAAE,kBAAkB,EAAE,MAAM,YAAY,CAAC;AAChD,OAAO,EAAE,wBAAwB,EAAE,MAAM,mBAAmB,CAAC;AAC7D,OAAO,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAC;AAC5C,OAAO,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAC;AACpD,OAAO,EAAE,oBAAoB,EAAE,MAAM,cAAc,CAAC;AACpD,OAAO,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AAErD,qEAAqE;AACrE,MAAM,UAAU,gBAAgB,CAAC,EAAW;IAC1C,mBAAmB,CAAC,EAAE,CAAC,CAAC;IACxB,kBAAkB,CAAC,EAAE,CAAC,CAAC;IACvB,qBAAqB,CAAC,EAAE,CAAC,CAAC;IAC1B,oBAAoB,CAAC,EAAE,CAAC,CAAC;IACzB,uBAAuB,CAAC,EAAE,CAAC,CAAC;IAC5B,gBAAgB,CAAC,EAAE,CAAC,CAAC;IACrB,kBAAkB,CAAC,EAAE,CAAC,CAAC;IACvB,kBAAkB,CAAC,EAAE,CAAC,CAAC;IACvB,wBAAwB,CAAC,EAAE,CAAC,CAAC;IAC7B,gBAAgB,CAAC,EAAE,CAAC,CAAC;IACrB,oBAAoB,CAAC,EAAE,CAAC,CAAC;IACzB,oBAAoB,CAAC,EAAE,CAAC,CAAC;IACzB,oBAAoB,CAAC,EAAE,CAAC,CAAC;AAC3B,CAAC"}
@@ -0,0 +1,3 @@
1
+ import type { Gateway } from "../gateway.js";
2
+ export declare function registerProjectTools(gw: Gateway): void;
3
+ //# sourceMappingURL=project.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"project.d.ts","sourceRoot":"","sources":["../../src/tools/project.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAE7C,wBAAgB,oBAAoB,CAAC,EAAE,EAAE,OAAO,GAAG,IAAI,CAyFtD"}
@@ -0,0 +1,86 @@
1
+ import { z } from "zod";
2
+ export function registerProjectTools(gw) {
3
+ const r = gw.registry;
4
+ r.register({
5
+ name: "project_list",
6
+ description: "List registered local projects.",
7
+ risk: 0,
8
+ inputSchema: z.object({}).strip(),
9
+ handler: () => gw.projects.list(),
10
+ });
11
+ r.register({
12
+ name: "project_register",
13
+ description: "Register a local project directory (must be inside an allowed directory).",
14
+ risk: 1,
15
+ inputSchema: z.object({ path: z.string(), name: z.string().optional() }),
16
+ summarize: (i) => `register project ${i.name ?? i.path}`,
17
+ handler: (i) => gw.projects.register(i.path, i.name),
18
+ });
19
+ r.register({
20
+ name: "project_unregister",
21
+ description: "Remove a project from the registry (does not delete files).",
22
+ risk: 1,
23
+ inputSchema: z.object({ id: z.string() }),
24
+ handler: (i) => ({ removed: gw.projects.unregister(i.id) }),
25
+ });
26
+ r.register({
27
+ name: "project_get",
28
+ description: "Get a project by id or name.",
29
+ risk: 0,
30
+ inputSchema: z.object({ id: z.string() }),
31
+ handler: (i) => gw.projects.get(i.id) ?? { error: "not found" },
32
+ });
33
+ r.register({
34
+ name: "project_status",
35
+ description: "Get project details plus current git status.",
36
+ risk: 0,
37
+ inputSchema: z.object({ id: z.string() }),
38
+ handler: async (i) => {
39
+ const p = gw.projects.get(i.id);
40
+ if (!p)
41
+ return { error: "not found" };
42
+ let git;
43
+ try {
44
+ git = await gw.git.status(p.path);
45
+ }
46
+ catch (e) {
47
+ git = `(not a git repo or error: ${e.message})`;
48
+ }
49
+ return { project: p, git };
50
+ },
51
+ });
52
+ r.register({
53
+ name: "project_set_validate_command",
54
+ description: "Set the validate command for a project (e.g. 'pnpm validate').",
55
+ risk: 1,
56
+ inputSchema: z.object({ id: z.string(), command: z.string() }),
57
+ handler: (i) => gw.projects.update(i.id, { validateCommand: i.command }),
58
+ });
59
+ r.register({
60
+ name: "project_set_test_command",
61
+ description: "Set the test command for a project.",
62
+ risk: 1,
63
+ inputSchema: z.object({ id: z.string(), command: z.string() }),
64
+ handler: (i) => gw.projects.update(i.id, { testCommand: i.command }),
65
+ });
66
+ r.register({
67
+ name: "project_set_default_agent",
68
+ description: "Set the default coding agent for a project.",
69
+ risk: 1,
70
+ inputSchema: z.object({ id: z.string(), agent: z.string() }),
71
+ handler: (i) => gw.projects.update(i.id, { defaultAgent: i.agent }),
72
+ });
73
+ r.register({
74
+ name: "project_detect_stack",
75
+ description: "Detect the tech stack of a project directory.",
76
+ risk: 0,
77
+ inputSchema: z.object({ id: z.string() }),
78
+ handler: (i) => {
79
+ const p = gw.projects.get(i.id);
80
+ if (!p)
81
+ return { error: "not found" };
82
+ return { stack: gw.projects.detectStack(p.path) };
83
+ },
84
+ });
85
+ }
86
+ //# sourceMappingURL=project.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"project.js","sourceRoot":"","sources":["../../src/tools/project.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { Gateway } from "../gateway.js";
2
+ export declare function registerShellTools(gw: Gateway): void;
3
+ //# sourceMappingURL=shell.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shell.d.ts","sourceRoot":"","sources":["../../src/tools/shell.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAE7C,wBAAgB,kBAAkB,CAAC,EAAE,EAAE,OAAO,GAAG,IAAI,CA0GpD"}
@@ -0,0 +1,98 @@
1
+ import { z } from "zod";
2
+ import { nanoid } from "nanoid";
3
+ export function registerShellTools(gw) {
4
+ const r = gw.registry;
5
+ r.register({
6
+ name: "shell_list_allowed_commands",
7
+ description: "List the command prefixes that may be run without approval.",
8
+ risk: 0,
9
+ inputSchema: z.object({}).strip(),
10
+ handler: () => ({ allowed: gw.commandGuard.allowed(), blocked: gw.config().security.blockedCommandTokens }),
11
+ });
12
+ r.register({
13
+ name: "shell_add_allowed_command",
14
+ description: "Add a command prefix to the allowlist.",
15
+ risk: 2,
16
+ inputSchema: z.object({ command: z.string() }),
17
+ summarize: (i) => `allow command '${i.command}'`,
18
+ handler: (i) => {
19
+ const cfg = gw.config();
20
+ const cmds = Array.from(new Set([...cfg.security.allowedCommands, i.command]));
21
+ gw.saveConfig({ ...cfg, security: { ...cfg.security, allowedCommands: cmds } });
22
+ return { allowed: gw.commandGuard.allowed() };
23
+ },
24
+ });
25
+ r.register({
26
+ name: "shell_remove_allowed_command",
27
+ description: "Remove a command prefix from the allowlist.",
28
+ risk: 2,
29
+ inputSchema: z.object({ command: z.string() }),
30
+ handler: (i) => {
31
+ const cfg = gw.config();
32
+ const cmds = cfg.security.allowedCommands.filter((c) => c !== i.command);
33
+ gw.saveConfig({ ...cfg, security: { ...cfg.security, allowedCommands: cmds } });
34
+ return { allowed: gw.commandGuard.allowed() };
35
+ },
36
+ });
37
+ r.register({
38
+ name: "shell_run_allowed_command",
39
+ description: "Run a command from the allowlist. Pipelines/redirection/chaining are rejected.",
40
+ risk: 1,
41
+ inputSchema: z.object({ command: z.string(), cwd: z.string().optional() }),
42
+ summarize: (i) => `run '${i.command}'`,
43
+ handler: (i) => gw.shell.runAllowed(i.command, i.cwd),
44
+ });
45
+ r.register({
46
+ name: "shell_request_command_approval",
47
+ description: "Request approval to run a command that is NOT on the allowlist. Returns an approval id; once approved, call shell_run_approved_command.",
48
+ risk: 0,
49
+ inputSchema: z.object({ command: z.string(), reason: z.string().default("") }),
50
+ handler: (i, ctx) => {
51
+ const req = gw.approvals.create({
52
+ tool: "shell_run_approved_command",
53
+ risk: 3,
54
+ requirement: "single",
55
+ reason: i.reason || "Run a non-allowlisted command.",
56
+ summary: `run '${i.command}'`,
57
+ caller: ctx.caller,
58
+ sessionId: ctx.sessionId,
59
+ });
60
+ return {
61
+ approvalId: req.id,
62
+ message: `Approval requested. Approve with: localant approvals approve ${req.id}, then call shell_run_approved_command.`,
63
+ };
64
+ },
65
+ });
66
+ r.register({
67
+ name: "shell_run_approved_command",
68
+ description: "Run an arbitrary command (still subject to the hard blocklist). Requires approval (risk 3).",
69
+ risk: 3,
70
+ inputSchema: z.object({ command: z.string(), cwd: z.string().optional() }),
71
+ summarize: (i) => `run (approved) '${i.command}'`,
72
+ handler: (i) => gw.shell.runApproved(i.command, i.cwd),
73
+ });
74
+ r.register({
75
+ name: "shell_list_processes",
76
+ description: "List tracked long-running processes.",
77
+ risk: 0,
78
+ inputSchema: z.object({}).strip(),
79
+ handler: () => gw.shell.listProcesses(),
80
+ });
81
+ r.register({
82
+ name: "shell_get_process_output",
83
+ description: "Get captured output of a tracked process.",
84
+ risk: 0,
85
+ inputSchema: z.object({ id: z.string() }),
86
+ handler: (i) => gw.shell.getOutput(i.id),
87
+ });
88
+ r.register({
89
+ name: "shell_stop_process",
90
+ description: "Stop a tracked process.",
91
+ risk: 2,
92
+ inputSchema: z.object({ id: z.string() }),
93
+ summarize: (i) => `stop process ${i.id}`,
94
+ handler: (i) => gw.shell.stopProcess(i.id),
95
+ });
96
+ void nanoid;
97
+ }
98
+ //# sourceMappingURL=shell.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shell.js","sourceRoot":"","sources":["../../src/tools/shell.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { Gateway } from "../gateway.js";
2
+ export declare function registerSkillTools(gw: Gateway): void;
3
+ //# sourceMappingURL=skill.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"skill.d.ts","sourceRoot":"","sources":["../../src/tools/skill.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAe7C,wBAAgB,kBAAkB,CAAC,EAAE,EAAE,OAAO,GAAG,IAAI,CAuNpD"}