@aigne/afs-cli 1.11.0-beta.6 → 1.11.0-beta.8

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 (346) hide show
  1. package/dist/_virtual/rolldown_runtime.mjs +7 -0
  2. package/dist/cli.cjs +27 -353
  3. package/dist/cli.d.cts +2 -1
  4. package/dist/cli.d.mts +2 -1
  5. package/dist/cli.mjs +28 -353
  6. package/dist/cli.mjs.map +1 -1
  7. package/dist/config/afs-loader.cjs +567 -0
  8. package/dist/config/afs-loader.d.cts +19 -0
  9. package/dist/config/afs-loader.d.cts.map +1 -0
  10. package/dist/config/afs-loader.d.mts +19 -0
  11. package/dist/config/afs-loader.d.mts.map +1 -0
  12. package/dist/config/afs-loader.mjs +565 -0
  13. package/dist/config/afs-loader.mjs.map +1 -0
  14. package/dist/config/loader.cjs +28 -11
  15. package/dist/config/loader.mjs +28 -11
  16. package/dist/config/loader.mjs.map +1 -1
  17. package/dist/config/mount-commands.cjs +208 -0
  18. package/dist/config/mount-commands.d.cts +14 -0
  19. package/dist/config/mount-commands.d.cts.map +1 -0
  20. package/dist/config/mount-commands.d.mts +14 -0
  21. package/dist/config/mount-commands.d.mts.map +1 -0
  22. package/dist/config/mount-commands.mjs +203 -0
  23. package/dist/config/mount-commands.mjs.map +1 -0
  24. package/dist/config/schema.cjs +10 -2
  25. package/dist/config/schema.mjs +10 -2
  26. package/dist/config/schema.mjs.map +1 -1
  27. package/dist/core/commands/delete.cjs +41 -0
  28. package/dist/core/commands/delete.d.cts +18 -0
  29. package/dist/core/commands/delete.d.cts.map +1 -0
  30. package/dist/core/commands/delete.d.mts +18 -0
  31. package/dist/core/commands/delete.d.mts.map +1 -0
  32. package/dist/core/commands/delete.mjs +42 -0
  33. package/dist/core/commands/delete.mjs.map +1 -0
  34. package/dist/core/commands/exec.cjs +98 -0
  35. package/dist/core/commands/exec.d.cts +26 -0
  36. package/dist/core/commands/exec.d.cts.map +1 -0
  37. package/dist/core/commands/exec.d.mts +26 -0
  38. package/dist/core/commands/exec.d.mts.map +1 -0
  39. package/dist/core/commands/exec.mjs +99 -0
  40. package/dist/core/commands/exec.mjs.map +1 -0
  41. package/dist/core/commands/explain.cjs +254 -0
  42. package/dist/core/commands/explain.d.cts +25 -0
  43. package/dist/core/commands/explain.d.cts.map +1 -0
  44. package/dist/core/commands/explain.d.mts +25 -0
  45. package/dist/core/commands/explain.d.mts.map +1 -0
  46. package/dist/core/commands/explain.mjs +255 -0
  47. package/dist/core/commands/explain.mjs.map +1 -0
  48. package/dist/core/commands/explore.cjs +30 -0
  49. package/dist/core/commands/explore.d.mts +2 -0
  50. package/dist/core/commands/explore.mjs +31 -0
  51. package/dist/core/commands/explore.mjs.map +1 -0
  52. package/dist/core/commands/index.cjs +36 -0
  53. package/dist/core/commands/index.d.cts +21 -0
  54. package/dist/core/commands/index.d.cts.map +1 -0
  55. package/dist/core/commands/index.d.mts +24 -0
  56. package/dist/core/commands/index.d.mts.map +1 -0
  57. package/dist/core/commands/index.mjs +37 -0
  58. package/dist/core/commands/index.mjs.map +1 -0
  59. package/dist/core/commands/ls.cjs +57 -0
  60. package/dist/core/commands/ls.d.cts +21 -0
  61. package/dist/core/commands/ls.d.cts.map +1 -0
  62. package/dist/core/commands/ls.d.mts +21 -0
  63. package/dist/core/commands/ls.d.mts.map +1 -0
  64. package/dist/core/commands/ls.mjs +58 -0
  65. package/dist/core/commands/ls.mjs.map +1 -0
  66. package/dist/core/commands/mount.cjs +222 -0
  67. package/dist/core/commands/mount.d.cts +35 -0
  68. package/dist/core/commands/mount.d.cts.map +1 -0
  69. package/dist/core/commands/mount.d.mts +35 -0
  70. package/dist/core/commands/mount.d.mts.map +1 -0
  71. package/dist/core/commands/mount.mjs +223 -0
  72. package/dist/core/commands/mount.mjs.map +1 -0
  73. package/dist/core/commands/read.cjs +48 -0
  74. package/dist/core/commands/read.d.cts +17 -0
  75. package/dist/core/commands/read.d.cts.map +1 -0
  76. package/dist/core/commands/read.d.mts +17 -0
  77. package/dist/core/commands/read.d.mts.map +1 -0
  78. package/dist/core/commands/read.mjs +49 -0
  79. package/dist/core/commands/read.mjs.map +1 -0
  80. package/dist/core/commands/search.cjs +40 -0
  81. package/dist/core/commands/search.d.mts +2 -0
  82. package/dist/core/commands/search.mjs +41 -0
  83. package/dist/core/commands/search.mjs.map +1 -0
  84. package/dist/core/commands/serve.cjs +267 -0
  85. package/dist/core/commands/serve.d.mts +2 -0
  86. package/dist/core/commands/serve.mjs +267 -0
  87. package/dist/core/commands/serve.mjs.map +1 -0
  88. package/dist/core/commands/stat.cjs +53 -0
  89. package/dist/core/commands/stat.d.cts +17 -0
  90. package/dist/core/commands/stat.d.cts.map +1 -0
  91. package/dist/core/commands/stat.d.mts +17 -0
  92. package/dist/core/commands/stat.d.mts.map +1 -0
  93. package/dist/core/commands/stat.mjs +54 -0
  94. package/dist/core/commands/stat.mjs.map +1 -0
  95. package/dist/core/commands/types.cjs +18 -0
  96. package/dist/core/commands/types.d.cts +54 -0
  97. package/dist/core/commands/types.d.cts.map +1 -0
  98. package/dist/core/commands/types.d.mts +54 -0
  99. package/dist/core/commands/types.d.mts.map +1 -0
  100. package/dist/core/commands/types.mjs +19 -0
  101. package/dist/core/commands/types.mjs.map +1 -0
  102. package/dist/core/commands/write.cjs +70 -0
  103. package/dist/core/commands/write.d.cts +20 -0
  104. package/dist/core/commands/write.d.cts.map +1 -0
  105. package/dist/core/commands/write.d.mts +20 -0
  106. package/dist/core/commands/write.d.mts.map +1 -0
  107. package/dist/core/commands/write.mjs +71 -0
  108. package/dist/core/commands/write.mjs.map +1 -0
  109. package/dist/core/executor/index.cjs +196 -0
  110. package/dist/core/executor/index.d.cts +77 -0
  111. package/dist/core/executor/index.d.cts.map +1 -0
  112. package/dist/core/executor/index.d.mts +77 -0
  113. package/dist/core/executor/index.d.mts.map +1 -0
  114. package/dist/core/executor/index.mjs +195 -0
  115. package/dist/core/executor/index.mjs.map +1 -0
  116. package/dist/core/formatters/delete.cjs +37 -0
  117. package/dist/core/formatters/delete.d.cts +18 -0
  118. package/dist/core/formatters/delete.d.cts.map +1 -0
  119. package/dist/core/formatters/delete.d.mts +18 -0
  120. package/dist/core/formatters/delete.d.mts.map +1 -0
  121. package/dist/core/formatters/delete.mjs +37 -0
  122. package/dist/core/formatters/delete.mjs.map +1 -0
  123. package/dist/core/formatters/exec.cjs +60 -0
  124. package/dist/core/formatters/exec.d.cts +18 -0
  125. package/dist/core/formatters/exec.d.cts.map +1 -0
  126. package/dist/core/formatters/exec.d.mts +18 -0
  127. package/dist/core/formatters/exec.d.mts.map +1 -0
  128. package/dist/core/formatters/exec.mjs +60 -0
  129. package/dist/core/formatters/exec.mjs.map +1 -0
  130. package/dist/core/formatters/explain.cjs +97 -0
  131. package/dist/core/formatters/explain.d.cts +11 -0
  132. package/dist/core/formatters/explain.d.cts.map +1 -0
  133. package/dist/core/formatters/explain.d.mts +11 -0
  134. package/dist/core/formatters/explain.d.mts.map +1 -0
  135. package/dist/core/formatters/explain.mjs +96 -0
  136. package/dist/core/formatters/explain.mjs.map +1 -0
  137. package/dist/core/formatters/index.d.mts +9 -0
  138. package/dist/core/formatters/ls.cjs +179 -0
  139. package/dist/core/formatters/ls.d.cts +20 -0
  140. package/dist/core/formatters/ls.d.cts.map +1 -0
  141. package/dist/core/formatters/ls.d.mts +20 -0
  142. package/dist/core/formatters/ls.d.mts.map +1 -0
  143. package/dist/core/formatters/ls.mjs +179 -0
  144. package/dist/core/formatters/ls.mjs.map +1 -0
  145. package/dist/core/formatters/mount.cjs +55 -0
  146. package/dist/core/formatters/mount.d.cts +15 -0
  147. package/dist/core/formatters/mount.d.cts.map +1 -0
  148. package/dist/core/formatters/mount.d.mts +15 -0
  149. package/dist/core/formatters/mount.d.mts.map +1 -0
  150. package/dist/core/formatters/mount.mjs +55 -0
  151. package/dist/core/formatters/mount.mjs.map +1 -0
  152. package/dist/core/formatters/read.cjs +100 -0
  153. package/dist/core/formatters/read.d.cts +22 -0
  154. package/dist/core/formatters/read.d.cts.map +1 -0
  155. package/dist/core/formatters/read.d.mts +22 -0
  156. package/dist/core/formatters/read.d.mts.map +1 -0
  157. package/dist/core/formatters/read.mjs +100 -0
  158. package/dist/core/formatters/read.mjs.map +1 -0
  159. package/dist/core/formatters/search.cjs +44 -0
  160. package/dist/core/formatters/search.d.mts +1 -0
  161. package/dist/core/formatters/search.mjs +44 -0
  162. package/dist/core/formatters/search.mjs.map +1 -0
  163. package/dist/core/formatters/stat.cjs +155 -0
  164. package/dist/core/formatters/stat.d.cts +15 -0
  165. package/dist/core/formatters/stat.d.cts.map +1 -0
  166. package/dist/core/formatters/stat.d.mts +15 -0
  167. package/dist/core/formatters/stat.d.mts.map +1 -0
  168. package/dist/core/formatters/stat.mjs +155 -0
  169. package/dist/core/formatters/stat.mjs.map +1 -0
  170. package/dist/core/formatters/write.cjs +51 -0
  171. package/dist/core/formatters/write.d.cts +22 -0
  172. package/dist/core/formatters/write.d.cts.map +1 -0
  173. package/dist/core/formatters/write.d.mts +22 -0
  174. package/dist/core/formatters/write.d.mts.map +1 -0
  175. package/dist/core/formatters/write.mjs +51 -0
  176. package/dist/core/formatters/write.mjs.map +1 -0
  177. package/dist/core/helpers/exec-args.cjs +142 -0
  178. package/dist/core/helpers/exec-args.d.cts +46 -0
  179. package/dist/core/helpers/exec-args.d.cts.map +1 -0
  180. package/dist/core/helpers/exec-args.d.mts +46 -0
  181. package/dist/core/helpers/exec-args.d.mts.map +1 -0
  182. package/dist/core/helpers/exec-args.mjs +139 -0
  183. package/dist/core/helpers/exec-args.mjs.map +1 -0
  184. package/dist/core/helpers/stdin.cjs +41 -0
  185. package/dist/core/helpers/stdin.d.cts +15 -0
  186. package/dist/core/helpers/stdin.d.cts.map +1 -0
  187. package/dist/core/helpers/stdin.d.mts +15 -0
  188. package/dist/core/helpers/stdin.d.mts.map +1 -0
  189. package/dist/core/helpers/stdin.mjs +41 -0
  190. package/dist/core/helpers/stdin.mjs.map +1 -0
  191. package/dist/core/index.cjs +49 -0
  192. package/dist/core/index.d.cts +24 -0
  193. package/dist/core/index.d.mts +25 -0
  194. package/dist/core/index.mjs +24 -0
  195. package/dist/core/path-utils.cjs +1 -0
  196. package/dist/core/path-utils.mjs +3 -0
  197. package/dist/core/types.d.cts +24 -0
  198. package/dist/core/types.d.cts.map +1 -0
  199. package/dist/core/types.d.mts +24 -0
  200. package/dist/core/types.d.mts.map +1 -0
  201. package/dist/credential/auth-server.cjs +247 -0
  202. package/dist/credential/auth-server.mjs +247 -0
  203. package/dist/credential/auth-server.mjs.map +1 -0
  204. package/dist/credential/cli-auth-context.cjs +86 -0
  205. package/dist/credential/cli-auth-context.d.mts +1 -0
  206. package/dist/credential/cli-auth-context.mjs +86 -0
  207. package/dist/credential/cli-auth-context.mjs.map +1 -0
  208. package/dist/credential/index.cjs +5 -0
  209. package/dist/credential/index.d.mts +4 -0
  210. package/dist/credential/index.mjs +7 -0
  211. package/dist/credential/mcp-auth-context.cjs +186 -0
  212. package/dist/credential/mcp-auth-context.d.mts +1 -0
  213. package/dist/credential/mcp-auth-context.mjs +186 -0
  214. package/dist/credential/mcp-auth-context.mjs.map +1 -0
  215. package/dist/credential/resolver.cjs +125 -0
  216. package/dist/credential/resolver.d.mts +1 -0
  217. package/dist/credential/resolver.mjs +125 -0
  218. package/dist/credential/resolver.mjs.map +1 -0
  219. package/dist/credential/store.cjs +106 -0
  220. package/dist/credential/store.d.cts +30 -0
  221. package/dist/credential/store.d.cts.map +1 -0
  222. package/dist/credential/store.d.mts +30 -0
  223. package/dist/credential/store.d.mts.map +1 -0
  224. package/dist/credential/store.mjs +106 -0
  225. package/dist/credential/store.mjs.map +1 -0
  226. package/dist/errors.cjs +0 -11
  227. package/dist/errors.mjs +1 -11
  228. package/dist/errors.mjs.map +1 -1
  229. package/dist/explorer/actions.cjs +67 -32
  230. package/dist/explorer/actions.mjs +66 -32
  231. package/dist/explorer/actions.mjs.map +1 -1
  232. package/dist/explorer/components/dialog.cjs +170 -46
  233. package/dist/explorer/components/dialog.mjs +170 -46
  234. package/dist/explorer/components/dialog.mjs.map +1 -1
  235. package/dist/explorer/components/metadata-panel.cjs +86 -3
  236. package/dist/explorer/components/metadata-panel.mjs +86 -3
  237. package/dist/explorer/components/metadata-panel.mjs.map +1 -1
  238. package/dist/explorer/screen.cjs +63 -27
  239. package/dist/explorer/screen.d.cts +23 -0
  240. package/dist/explorer/screen.d.cts.map +1 -0
  241. package/dist/explorer/screen.d.mts +23 -0
  242. package/dist/explorer/screen.d.mts.map +1 -0
  243. package/dist/explorer/screen.mjs +63 -27
  244. package/dist/explorer/screen.mjs.map +1 -1
  245. package/dist/explorer/theme.cjs +1 -1
  246. package/dist/explorer/theme.mjs +1 -1
  247. package/dist/explorer/theme.mjs.map +1 -1
  248. package/dist/index.cjs +10 -1
  249. package/dist/index.d.cts +5 -1
  250. package/dist/index.d.mts +6 -1
  251. package/dist/index.mjs +6 -1
  252. package/dist/mcp/http-transport.cjs +87 -0
  253. package/dist/mcp/http-transport.mjs +87 -0
  254. package/dist/mcp/http-transport.mjs.map +1 -0
  255. package/dist/mcp/prompts.cjs +48 -0
  256. package/dist/mcp/prompts.mjs +48 -0
  257. package/dist/mcp/prompts.mjs.map +1 -0
  258. package/dist/mcp/resources.cjs +25 -0
  259. package/dist/mcp/resources.mjs +25 -0
  260. package/dist/mcp/resources.mjs.map +1 -0
  261. package/dist/mcp/server.cjs +40 -0
  262. package/dist/mcp/server.mjs +39 -0
  263. package/dist/mcp/server.mjs.map +1 -0
  264. package/dist/mcp/tools.cjs +152 -0
  265. package/dist/mcp/tools.mjs +152 -0
  266. package/dist/mcp/tools.mjs.map +1 -0
  267. package/dist/node_modules/.pnpm/urlpattern-polyfill@10.1.0/node_modules/urlpattern-polyfill/dist/index.d.cts +10 -0
  268. package/dist/node_modules/.pnpm/urlpattern-polyfill@10.1.0/node_modules/urlpattern-polyfill/dist/index.d.cts.map +1 -0
  269. package/dist/node_modules/.pnpm/urlpattern-polyfill@10.1.0/node_modules/urlpattern-polyfill/dist/index.d.mts +10 -0
  270. package/dist/node_modules/.pnpm/urlpattern-polyfill@10.1.0/node_modules/urlpattern-polyfill/dist/index.d.mts.map +1 -0
  271. package/dist/node_modules/.pnpm/urlpattern-polyfill@10.1.0/node_modules/urlpattern-polyfill/dist/types.d.cts +46 -0
  272. package/dist/node_modules/.pnpm/urlpattern-polyfill@10.1.0/node_modules/urlpattern-polyfill/dist/types.d.cts.map +1 -0
  273. package/dist/node_modules/.pnpm/urlpattern-polyfill@10.1.0/node_modules/urlpattern-polyfill/dist/types.d.mts +46 -0
  274. package/dist/node_modules/.pnpm/urlpattern-polyfill@10.1.0/node_modules/urlpattern-polyfill/dist/types.d.mts.map +1 -0
  275. package/dist/node_modules/.pnpm/urlpattern-polyfill@10.1.0/node_modules/urlpattern-polyfill/dist/urlpattern.cjs +902 -0
  276. package/dist/node_modules/.pnpm/urlpattern-polyfill@10.1.0/node_modules/urlpattern-polyfill/dist/urlpattern.mjs +902 -0
  277. package/dist/node_modules/.pnpm/urlpattern-polyfill@10.1.0/node_modules/urlpattern-polyfill/dist/urlpattern.mjs.map +1 -0
  278. package/dist/node_modules/.pnpm/urlpattern-polyfill@10.1.0/node_modules/urlpattern-polyfill/index.cjs +6 -0
  279. package/dist/node_modules/.pnpm/urlpattern-polyfill@10.1.0/node_modules/urlpattern-polyfill/index.mjs +8 -0
  280. package/dist/node_modules/.pnpm/urlpattern-polyfill@10.1.0/node_modules/urlpattern-polyfill/index.mjs.map +1 -0
  281. package/dist/path-utils.d.cts +50 -0
  282. package/dist/path-utils.d.cts.map +1 -0
  283. package/dist/path-utils.d.mts +50 -0
  284. package/dist/path-utils.d.mts.map +1 -0
  285. package/dist/repl.cjs +491 -0
  286. package/dist/repl.d.cts +15 -0
  287. package/dist/repl.d.cts.map +1 -0
  288. package/dist/repl.d.mts +16 -0
  289. package/dist/repl.d.mts.map +1 -0
  290. package/dist/repl.mjs +491 -0
  291. package/dist/repl.mjs.map +1 -0
  292. package/dist/serve.cjs +146 -0
  293. package/dist/serve.d.cts +41 -0
  294. package/dist/serve.d.cts.map +1 -0
  295. package/dist/serve.d.mts +41 -0
  296. package/dist/serve.d.mts.map +1 -0
  297. package/dist/serve.mjs +146 -0
  298. package/dist/serve.mjs.map +1 -0
  299. package/dist/ui/header.cjs +1 -40
  300. package/dist/ui/header.mjs +1 -39
  301. package/dist/ui/header.mjs.map +1 -1
  302. package/dist/ui/index.cjs +2 -9
  303. package/dist/ui/index.mjs +2 -7
  304. package/dist/ui/index.mjs.map +1 -1
  305. package/dist/ui/terminal.cjs +1 -10
  306. package/dist/ui/terminal.mjs +1 -8
  307. package/dist/ui/terminal.mjs.map +1 -1
  308. package/package.json +30 -17
  309. package/dist/commands/exec.cjs +0 -164
  310. package/dist/commands/exec.mjs +0 -160
  311. package/dist/commands/exec.mjs.map +0 -1
  312. package/dist/commands/explain.cjs +0 -244
  313. package/dist/commands/explain.mjs +0 -242
  314. package/dist/commands/explain.mjs.map +0 -1
  315. package/dist/commands/index.cjs +0 -8
  316. package/dist/commands/index.mjs +0 -10
  317. package/dist/commands/ls.cjs +0 -242
  318. package/dist/commands/ls.mjs +0 -242
  319. package/dist/commands/ls.mjs.map +0 -1
  320. package/dist/commands/mount.cjs +0 -194
  321. package/dist/commands/mount.mjs +0 -190
  322. package/dist/commands/mount.mjs.map +0 -1
  323. package/dist/commands/read.cjs +0 -264
  324. package/dist/commands/read.mjs +0 -263
  325. package/dist/commands/read.mjs.map +0 -1
  326. package/dist/commands/serve.cjs +0 -144
  327. package/dist/commands/serve.mjs +0 -143
  328. package/dist/commands/serve.mjs.map +0 -1
  329. package/dist/commands/stat.cjs +0 -195
  330. package/dist/commands/stat.mjs +0 -195
  331. package/dist/commands/stat.mjs.map +0 -1
  332. package/dist/commands/write.cjs +0 -85
  333. package/dist/commands/write.mjs +0 -85
  334. package/dist/commands/write.mjs.map +0 -1
  335. package/dist/config/provider-factory.cjs +0 -400
  336. package/dist/config/provider-factory.mjs +0 -401
  337. package/dist/config/provider-factory.mjs.map +0 -1
  338. package/dist/config/uri-parser.cjs +0 -285
  339. package/dist/config/uri-parser.mjs +0 -285
  340. package/dist/config/uri-parser.mjs.map +0 -1
  341. package/dist/runtime.cjs +0 -120
  342. package/dist/runtime.mjs +0 -120
  343. package/dist/runtime.mjs.map +0 -1
  344. package/dist/utils/meta.cjs +0 -51
  345. package/dist/utils/meta.mjs +0 -49
  346. package/dist/utils/meta.mjs.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"explain.mjs","names":[],"sources":["../../../src/core/commands/explain.ts"],"sourcesContent":["/**\n * explain Command - Core Implementation\n *\n * Explains AFS paths or concepts.\n * Matches old version output format with topic/explanation/examples structure.\n */\n\nimport type { AFS } from \"@aigne/afs\";\nimport type { CommandModule } from \"yargs\";\nimport { configMountListCommand } from \"../../config/mount-commands.js\";\nimport { formatExplainOutput, formatPathExplainOutput } from \"../formatters/index.js\";\nimport { cliPathToCanonical } from \"../path-utils.js\";\nimport { type CommandFactoryOptions, resolveAFS } from \"./types.js\";\n\n/**\n * Result for concept explanations (mount, paths, uri, overview)\n */\nexport interface ExplainResult {\n topic: string;\n explanation: string;\n examples?: string[];\n}\n\n/**\n * Result for path explanations\n */\nexport interface PathExplainResult {\n path: string;\n type: string;\n description?: string;\n inputs?: string[];\n outputs?: string[];\n errors?: string[];\n sideEffects?: string[];\n meta?: Record<string, string>;\n}\n\n/**\n * Explain command arguments\n */\nexport interface ExplainArgs {\n topic?: string;\n}\n\n/**\n * Create explain command factory\n */\nexport function createExplainCommand(\n options: CommandFactoryOptions,\n): CommandModule<unknown, ExplainArgs> {\n return {\n command: \"explain [topic]\",\n describe: \"Explain AFS concepts or paths\",\n builder: {\n topic: {\n type: \"string\",\n description: \"Topic (mount, path, uri) or AFS path (e.g., /src)\",\n },\n },\n handler: async (argv) => {\n const target = argv.topic;\n\n // No target - explain overview\n if (!target) {\n options.onResult({\n command: \"explain\",\n result: explainOverview(),\n format: formatExplainOutput,\n });\n return;\n }\n\n // Check if it's a path (starts with /, @, or $)\n const isPath = target.startsWith(\"/\") || target.startsWith(\"@\") || target.startsWith(\"$\");\n\n if (isPath) {\n const afs = await resolveAFS(options);\n const canonicalPath = cliPathToCanonical(target);\n const result = await getPathExplanation(afs, target, canonicalPath);\n options.onResult({ command: \"explain\", result, format: formatPathExplainOutput });\n } else {\n const cwd = options.cwd ?? process.cwd();\n // Pass AFS instance for runtime mount info (DOC-2)\n let afs: AFS | undefined;\n try {\n afs = await resolveAFS(options);\n } catch {}\n const result = await getConceptExplanation(target.toLowerCase(), cwd, afs);\n options.onResult({\n command: \"explain\",\n result,\n format: formatExplainOutput,\n });\n }\n },\n };\n}\n\n/**\n * Get explanation for a path\n */\nasync function getPathExplanation(\n afs: AFS,\n path: string,\n canonicalPath: string,\n): Promise<PathExplainResult> {\n try {\n // Try stat first (lightweight metadata query), fallback to read\n let entry:\n | { path: string; meta?: Record<string, unknown> | null; content?: unknown }\n | undefined;\n\n try {\n const statResult = await afs.stat(canonicalPath);\n entry = statResult.data;\n } catch {}\n\n if (!entry) {\n try {\n const readResult = await afs.read(canonicalPath);\n entry = readResult.data;\n } catch {}\n }\n\n if (!entry) {\n return {\n path,\n type: \"unknown\",\n };\n }\n\n const metadata = entry.meta || {};\n // Determine type from childrenCount: if defined, it has children (directory-like); otherwise file-like\n const entryType =\n metadata.kind === \"afs:executable\"\n ? \"exec\"\n : typeof metadata.childrenCount === \"number\"\n ? \"directory\"\n : \"file\";\n\n const result: PathExplainResult = {\n path: entry.path,\n type: entryType,\n description: metadata.description as string | undefined,\n meta: {},\n };\n\n // Add metadata\n if (metadata.provider) {\n result.meta!.provider = String(metadata.provider);\n }\n if (metadata.permissions) {\n const perms = metadata.permissions;\n result.meta!.permissions = Array.isArray(perms) ? perms.join(\", \") : String(perms);\n }\n\n // For exec type, try to get schema info\n if (entryType === \"exec\") {\n if (metadata.inputs) {\n result.inputs = Array.isArray(metadata.inputs)\n ? (metadata.inputs as string[])\n : [String(metadata.inputs)];\n }\n if (metadata.outputs) {\n result.outputs = Array.isArray(metadata.outputs)\n ? (metadata.outputs as string[])\n : [String(metadata.outputs)];\n }\n if (metadata.errors) {\n result.errors = Array.isArray(metadata.errors)\n ? (metadata.errors as string[])\n : [String(metadata.errors)];\n }\n if (metadata.sideEffects) {\n result.sideEffects = Array.isArray(metadata.sideEffects)\n ? (metadata.sideEffects as string[])\n : [String(metadata.sideEffects)];\n }\n }\n\n // Clean up empty metadata\n if (Object.keys(result.meta!).length === 0) {\n delete result.meta;\n }\n\n return result;\n } catch (err) {\n return {\n path,\n type: \"error\",\n description: err instanceof Error ? err.message : String(err),\n };\n }\n}\n\n/**\n * Get explanation for a concept\n */\nasync function getConceptExplanation(\n topic: string,\n cwd: string,\n afs?: AFS,\n): Promise<ExplainResult> {\n switch (topic) {\n case \"mount\":\n case \"mounts\":\n return explainMounts(cwd, afs);\n case \"path\":\n case \"paths\":\n return explainPaths();\n case \"uri\":\n case \"provider\":\n case \"providers\":\n return explainUri();\n default:\n return {\n topic: \"Unknown Topic\",\n explanation: `Unknown topic: ${topic}\\n\\nAvailable topics: overview, mount, path, uri`,\n };\n }\n}\n\nfunction explainOverview(): ExplainResult {\n return {\n topic: \"AFS Overview\",\n explanation: `AFS (Abstract File System) is a virtual filesystem that unifies different data sources into a single namespace.\n\nCore Concepts:\n- mount: Mount a data source to a virtual path\n- path: Virtual path, e.g., /src, /data\n- uri: Data source address, e.g., fs://, git://, sqlite://\n\nData Flow:\n User Path -> AFS -> /{mount} -> Provider -> Actual Data`,\n examples: [\"afs mount add /src fs:///path/to/source\", \"afs ls /src\", \"afs read /src/file.txt\"],\n };\n}\n\nasync function explainMounts(cwd: string, afs?: AFS): Promise<ExplainResult> {\n const result = await configMountListCommand(cwd);\n\n if (result.mounts.length === 0) {\n // Try runtime mounts if no config mounts\n if (afs) {\n try {\n const listResult = await afs.list(\"$afs:/\");\n if (listResult.data?.length) {\n const runtimeMounts = listResult.data\n .map((entry) => ` ${entry.path} (runtime mount)`)\n .join(\"\\n\");\n\n return {\n topic: \"Mounts\",\n explanation: `Runtime mounts (mounted via API):\\n\\n${runtimeMounts}`,\n examples: listResult.data.slice(0, 3).map((entry) => `afs ls ${entry.path}`),\n };\n }\n } catch {}\n }\n\n return {\n topic: \"Mounts\",\n explanation: `No mounts configured.\n\nUse mount add to add a mount:\n afs mount add <path> <uri>\n\npath: Virtual path for accessing data in AFS\nuri: Data source URI specifying the data origin`,\n examples: [\n \"afs mount add /src fs:///Users/me/project\",\n \"afs mount add /data sqlite:///data.db\",\n ],\n };\n }\n\n const mountList = result.mounts\n .map((m) => ` ${m.path}${m.description ? ` - ${m.description}` : \"\"}`)\n .join(\"\\n\");\n\n return {\n topic: \"Mounts\",\n explanation: `Current mount configuration:\n\n${mountList}\n\nAfter mounting, data is accessed via the mount path:\n path=\"/src\" -> /src`,\n examples: result.mounts.map((m) => `afs ls ${m.path}`),\n };\n}\n\nfunction explainPaths(): ExplainResult {\n return {\n topic: \"Paths\",\n explanation: `AFS Path Structure:\n\n/ Root directory\n/{mount} Mounted data source\n/{mount}/{path} Files/nodes within a mount\n\nPath Mapping:\n config: path=\"/src\" -> access: /src\n config: path=\"/data\" -> access: /data\n\nMounts are accessed directly at their configured path.`,\n };\n}\n\nfunction explainUri(): ExplainResult {\n return {\n topic: \"URI\",\n explanation: `AFS URI Schemes and Objects:\n\nfs:// Local Filesystem Provider\n Format: fs:///absolute/path or fs://./relative/path\n Operations: list, read, write, delete\n\ngit:// Git Repository Provider\n Format: git:///local/repo or git://github.com/user/repo?branch=main\n Operations: list, read, exec (diff, create-branch, commit, merge)\n\nsqlite:// SQLite Database Provider\n Format: sqlite:///path/to/db.sqlite\n Operations: list, read, exec (SQL queries)\n\njson:// JSON Data Provider\n Format: json:///path/to/data.json\n Operations: list, read, write\n\ntoml:// TOML Data Provider\n Format: toml:///path/to/config.toml\n Operations: list, read, write\n\nsandbox:// Sandboxed Script Execution Provider\n Format: sandbox:///path/to/scripts\n Operations: list, read, exec\n\ngithub:// GitHub Issues/PRs Provider\n Format: github://owner/repo\n Operations: list, read, exec (create-issue, close-issue, etc.)\n\nhttp:// HTTP Proxy Provider\n Format: http://host:port/path\n Operations: list, read\n\nmcp:// MCP Server Provider\n Format: mcp:///path/to/server\n Operations: list, read, exec\n\ns3:// AWS S3 Storage Provider\n Format: s3://bucket-name\n Operations: list, read, write, delete\n\ngcs:// Google Cloud Storage Provider\n Format: gcs://bucket-name\n Operations: list, read, write, delete\n\nec2:// AWS EC2 Instances Provider\n Format: ec2://region\n Operations: list, read, exec (run-instances)\n\ngce:// Google Compute Engine Provider\n Format: gce://project/zone\n Operations: list, read, exec\n\ndns:// Cloud DNS Provider\n Format: dns://provider (route53, clouddns)\n Operations: list, read`,\n examples: [\n \"afs mount add /src fs:///Users/me/project\",\n \"afs mount add /repo git://github.com/user/repo\",\n \"afs mount add /db sqlite:///data.sqlite\",\n \"afs mount add /s3 s3://my-bucket\",\n ],\n };\n}\n"],"mappings":"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"}
@@ -0,0 +1,30 @@
1
+ const require_types = require('./types.cjs');
2
+ const require_version = require('../../version.cjs');
3
+
4
+ //#region src/core/commands/explore.ts
5
+ /**
6
+ * Create explore command
7
+ */
8
+ function createExploreCommand(options) {
9
+ return {
10
+ command: "explore [path]",
11
+ describe: "Interactive TUI explorer",
12
+ builder: { path: {
13
+ type: "string",
14
+ default: "/",
15
+ description: "Starting path"
16
+ } },
17
+ handler: async (argv) => {
18
+ const afs = await require_types.resolveAFS(options);
19
+ const { createExplorerScreen } = await Promise.resolve().then(() => require("../../explorer/screen.cjs"));
20
+ await createExplorerScreen({
21
+ afs,
22
+ startPath: argv.path,
23
+ version: require_version.VERSION
24
+ });
25
+ }
26
+ };
27
+ }
28
+
29
+ //#endregion
30
+ exports.createExploreCommand = createExploreCommand;
@@ -0,0 +1,2 @@
1
+ import "./types.mjs";
2
+ import { CommandModule } from "yargs";
@@ -0,0 +1,31 @@
1
+ import { resolveAFS } from "./types.mjs";
2
+ import { VERSION } from "../../version.mjs";
3
+
4
+ //#region src/core/commands/explore.ts
5
+ /**
6
+ * Create explore command
7
+ */
8
+ function createExploreCommand(options) {
9
+ return {
10
+ command: "explore [path]",
11
+ describe: "Interactive TUI explorer",
12
+ builder: { path: {
13
+ type: "string",
14
+ default: "/",
15
+ description: "Starting path"
16
+ } },
17
+ handler: async (argv) => {
18
+ const afs = await resolveAFS(options);
19
+ const { createExplorerScreen } = await import("../../explorer/screen.mjs");
20
+ await createExplorerScreen({
21
+ afs,
22
+ startPath: argv.path,
23
+ version: VERSION
24
+ });
25
+ }
26
+ };
27
+ }
28
+
29
+ //#endregion
30
+ export { createExploreCommand };
31
+ //# sourceMappingURL=explore.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"explore.mjs","names":[],"sources":["../../../src/core/commands/explore.ts"],"sourcesContent":["/**\n * AFS Explore Command\n *\n * Interactive TUI explorer for AFS\n */\n\nimport type { CommandModule } from \"yargs\";\nimport { VERSION } from \"../../version.js\";\nimport { type CommandFactoryOptions, resolveAFS } from \"./types.js\";\n\nexport interface ExploreArgs {\n path: string;\n}\n\n/**\n * Create explore command\n */\nexport function createExploreCommand(\n options: CommandFactoryOptions,\n): CommandModule<unknown, ExploreArgs> {\n return {\n command: \"explore [path]\",\n describe: \"Interactive TUI explorer\",\n builder: {\n path: { type: \"string\", default: \"/\", description: \"Starting path\" },\n },\n handler: async (argv) => {\n const afs = await resolveAFS(options);\n const { createExplorerScreen } = await import(\"../../explorer/screen.js\");\n await createExplorerScreen({ afs, startPath: argv.path, version: VERSION });\n },\n };\n}\n"],"mappings":";;;;;;;AAiBA,SAAgB,qBACd,SACqC;AACrC,QAAO;EACL,SAAS;EACT,UAAU;EACV,SAAS,EACP,MAAM;GAAE,MAAM;GAAU,SAAS;GAAK,aAAa;GAAiB,EACrE;EACD,SAAS,OAAO,SAAS;GACvB,MAAM,MAAM,MAAM,WAAW,QAAQ;GACrC,MAAM,EAAE,yBAAyB,MAAM,OAAO;AAC9C,SAAM,qBAAqB;IAAE;IAAK,WAAW,KAAK;IAAM,SAAS;IAAS,CAAC;;EAE9E"}
@@ -0,0 +1,36 @@
1
+ const require_types = require('./types.cjs');
2
+ const require_delete = require('./delete.cjs');
3
+ const require_exec_args = require('../helpers/exec-args.cjs');
4
+ const require_exec = require('./exec.cjs');
5
+ const require_explain = require('./explain.cjs');
6
+ const require_explore = require('./explore.cjs');
7
+ const require_ls = require('./ls.cjs');
8
+ const require_mount = require('./mount.cjs');
9
+ const require_read = require('./read.cjs');
10
+ const require_search = require('./search.cjs');
11
+ const require_serve = require('./serve.cjs');
12
+ const require_stat = require('./stat.cjs');
13
+ const require_write = require('./write.cjs');
14
+
15
+ //#region src/core/commands/index.ts
16
+ /**
17
+ * Array of all command factories
18
+ *
19
+ * Used by AFSCommandExecutor to register all commands.
20
+ */
21
+ const commandFactories = [
22
+ require_ls.createLsCommand,
23
+ require_read.createReadCommand,
24
+ require_write.createWriteCommand,
25
+ require_delete.createDeleteCommand,
26
+ require_stat.createStatCommand,
27
+ require_exec.createExecCommand,
28
+ require_explain.createExplainCommand,
29
+ require_search.createSearchCommand,
30
+ require_mount.createMountCommand,
31
+ require_serve.createServeCommand,
32
+ require_explore.createExploreCommand
33
+ ];
34
+
35
+ //#endregion
36
+ exports.commandFactories = commandFactories;
@@ -0,0 +1,21 @@
1
+ import { CommandFactory, CommandFactoryOptions, CommandOutput, FormatFunction } from "./types.cjs";
2
+ import { DeleteArgs, createDeleteCommand } from "./delete.cjs";
3
+ import { parseExecArgs, parseValueBySchema } from "../helpers/exec-args.cjs";
4
+ import { ExecArgs, createExecCommand } from "./exec.cjs";
5
+ import { ExplainArgs, createExplainCommand } from "./explain.cjs";
6
+ import { LsArgs, createLsCommand } from "./ls.cjs";
7
+ import { MountAddArgs, MountListArgs, MountRemoveArgs, createMountCommand } from "./mount.cjs";
8
+ import { ReadArgs, createReadCommand } from "./read.cjs";
9
+ import { StatArgs, createStatCommand } from "./stat.cjs";
10
+ import { WriteArgs, createWriteCommand } from "./write.cjs";
11
+
12
+ //#region src/core/commands/index.d.ts
13
+ /**
14
+ * Array of all command factories
15
+ *
16
+ * Used by AFSCommandExecutor to register all commands.
17
+ */
18
+ declare const commandFactories: CommandFactory[];
19
+ //#endregion
20
+ export { commandFactories };
21
+ //# sourceMappingURL=index.d.cts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.cts","names":[],"sources":["../../../src/core/commands/index.ts"],"mappings":";;;;;;;;;;;;;;;;;cAmDa,gBAAA,EAAkB,cAAA"}
@@ -0,0 +1,24 @@
1
+ import { CommandFactory, CommandFactoryOptions, CommandOutput, FormatFunction } from "./types.mjs";
2
+ import { DeleteArgs, createDeleteCommand } from "./delete.mjs";
3
+ import { parseExecArgs, parseValueBySchema } from "../helpers/exec-args.mjs";
4
+ import { ExecArgs, createExecCommand } from "./exec.mjs";
5
+ import { ExplainArgs, createExplainCommand } from "./explain.mjs";
6
+ import "./explore.mjs";
7
+ import { LsArgs, createLsCommand } from "./ls.mjs";
8
+ import { MountAddArgs, MountListArgs, MountRemoveArgs, createMountCommand } from "./mount.mjs";
9
+ import { ReadArgs, createReadCommand } from "./read.mjs";
10
+ import "./search.mjs";
11
+ import "./serve.mjs";
12
+ import { StatArgs, createStatCommand } from "./stat.mjs";
13
+ import { WriteArgs, createWriteCommand } from "./write.mjs";
14
+
15
+ //#region src/core/commands/index.d.ts
16
+ /**
17
+ * Array of all command factories
18
+ *
19
+ * Used by AFSCommandExecutor to register all commands.
20
+ */
21
+ declare const commandFactories: CommandFactory[];
22
+ //#endregion
23
+ export { commandFactories };
24
+ //# sourceMappingURL=index.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.mts","names":[],"sources":["../../../src/core/commands/index.ts"],"mappings":";;;;;;;;;;;;;;;;;;;;cAmDa,gBAAA,EAAkB,cAAA"}
@@ -0,0 +1,37 @@
1
+ import { resolveAFS } from "./types.mjs";
2
+ import { createDeleteCommand } from "./delete.mjs";
3
+ import { parseExecArgs, parseValueBySchema } from "../helpers/exec-args.mjs";
4
+ import { createExecCommand } from "./exec.mjs";
5
+ import { createExplainCommand } from "./explain.mjs";
6
+ import { createExploreCommand } from "./explore.mjs";
7
+ import { createLsCommand } from "./ls.mjs";
8
+ import { createMountCommand } from "./mount.mjs";
9
+ import { createReadCommand } from "./read.mjs";
10
+ import { createSearchCommand } from "./search.mjs";
11
+ import { createServeCommand } from "./serve.mjs";
12
+ import { createStatCommand } from "./stat.mjs";
13
+ import { createWriteCommand } from "./write.mjs";
14
+
15
+ //#region src/core/commands/index.ts
16
+ /**
17
+ * Array of all command factories
18
+ *
19
+ * Used by AFSCommandExecutor to register all commands.
20
+ */
21
+ const commandFactories = [
22
+ createLsCommand,
23
+ createReadCommand,
24
+ createWriteCommand,
25
+ createDeleteCommand,
26
+ createStatCommand,
27
+ createExecCommand,
28
+ createExplainCommand,
29
+ createSearchCommand,
30
+ createMountCommand,
31
+ createServeCommand,
32
+ createExploreCommand
33
+ ];
34
+
35
+ //#endregion
36
+ export { commandFactories };
37
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","names":[],"sources":["../../../src/core/commands/index.ts"],"sourcesContent":["/**\n * CLI Core Commands\n *\n * Re-exports all command implementations and factories.\n */\n\n// Command factories and types\nexport { createDeleteCommand, type DeleteArgs } from \"./delete.js\";\nexport { createExecCommand, type ExecArgs, parseExecArgs, parseValueBySchema } from \"./exec.js\";\nexport { createExplainCommand, type ExplainArgs } from \"./explain.js\";\nexport { createExploreCommand, type ExploreArgs } from \"./explore.js\";\nexport { createLsCommand, type LsArgs } from \"./ls.js\";\nexport {\n createMountCommand,\n type MountAddArgs,\n type MountListArgs,\n type MountRemoveArgs,\n} from \"./mount.js\";\nexport { createReadCommand, type ReadArgs } from \"./read.js\";\nexport { createSearchCommand, type SearchArgs } from \"./search.js\";\nexport { createServeCommand, type ServeArgs, type ServeResult } from \"./serve.js\";\nexport { createStatCommand, type StatArgs } from \"./stat.js\";\n// Types and helpers\nexport type {\n CommandFactory,\n CommandFactoryOptions,\n CommandOutput,\n FormatFunction,\n} from \"./types.js\";\nexport { resolveAFS } from \"./types.js\";\nexport { createWriteCommand, type WriteArgs } from \"./write.js\";\n\n// Import factories for array export\nimport { createDeleteCommand } from \"./delete.js\";\nimport { createExecCommand } from \"./exec.js\";\nimport { createExplainCommand } from \"./explain.js\";\nimport { createExploreCommand } from \"./explore.js\";\nimport { createLsCommand } from \"./ls.js\";\nimport { createMountCommand } from \"./mount.js\";\nimport { createReadCommand } from \"./read.js\";\nimport { createSearchCommand } from \"./search.js\";\nimport { createServeCommand } from \"./serve.js\";\nimport { createStatCommand } from \"./stat.js\";\nimport type { CommandFactory } from \"./types.js\";\nimport { createWriteCommand } from \"./write.js\";\n\n/**\n * Array of all command factories\n *\n * Used by AFSCommandExecutor to register all commands.\n */\nexport const commandFactories: CommandFactory[] = [\n createLsCommand,\n createReadCommand,\n createWriteCommand,\n createDeleteCommand,\n createStatCommand,\n createExecCommand,\n createExplainCommand,\n createSearchCommand,\n createMountCommand,\n createServeCommand,\n createExploreCommand,\n];\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAmDA,MAAa,mBAAqC;CAChD;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACD"}
@@ -0,0 +1,57 @@
1
+ const require_ls = require('../formatters/ls.cjs');
2
+ const require_path_utils = require('../../path-utils.cjs');
3
+ require('../path-utils.cjs');
4
+ const require_types = require('./types.cjs');
5
+
6
+ //#region src/core/commands/ls.ts
7
+ /**
8
+ * Create ls command factory
9
+ */
10
+ function createLsCommand(options) {
11
+ return {
12
+ command: ["ls [path]", "list [path]"],
13
+ describe: "List directory contents",
14
+ builder: {
15
+ path: {
16
+ type: "string",
17
+ default: "/",
18
+ description: "Path to list"
19
+ },
20
+ depth: {
21
+ type: "number",
22
+ default: 1,
23
+ description: "Maximum depth to list"
24
+ },
25
+ limit: {
26
+ type: "number",
27
+ description: "Maximum number of entries to return"
28
+ },
29
+ "max-children": {
30
+ type: "number",
31
+ description: "Maximum children per directory"
32
+ },
33
+ pattern: {
34
+ type: "string",
35
+ description: "Glob pattern to filter entries"
36
+ }
37
+ },
38
+ handler: async (argv) => {
39
+ const afs = await require_types.resolveAFS(options);
40
+ const canonicalPath = require_path_utils.cliPathToCanonical(argv.path || "/");
41
+ const result = await afs.list(canonicalPath, {
42
+ maxDepth: argv.depth ?? 1,
43
+ limit: argv.limit,
44
+ maxChildren: argv.maxChildren,
45
+ pattern: argv.pattern
46
+ });
47
+ options.onResult({
48
+ command: "ls",
49
+ result,
50
+ format: require_ls.formatLsOutput
51
+ });
52
+ }
53
+ };
54
+ }
55
+
56
+ //#endregion
57
+ exports.createLsCommand = createLsCommand;
@@ -0,0 +1,21 @@
1
+ import { CommandFactoryOptions } from "./types.cjs";
2
+ import { CommandModule } from "yargs";
3
+
4
+ //#region src/core/commands/ls.d.ts
5
+ /**
6
+ * Ls command arguments
7
+ */
8
+ interface LsArgs {
9
+ path: string;
10
+ depth: number;
11
+ limit?: number;
12
+ maxChildren?: number;
13
+ pattern?: string;
14
+ }
15
+ /**
16
+ * Create ls command factory
17
+ */
18
+ declare function createLsCommand(options: CommandFactoryOptions): CommandModule<unknown, LsArgs>;
19
+ //#endregion
20
+ export { LsArgs, createLsCommand };
21
+ //# sourceMappingURL=ls.d.cts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ls.d.cts","names":[],"sources":["../../../src/core/commands/ls.ts"],"mappings":";;;;;;;UAeiB,MAAA;EACf,IAAA;EACA,KAAA;EACA,KAAA;EACA,WAAA;EACA,OAAA;AAAA;;;;iBAMc,eAAA,CAAgB,OAAA,EAAS,qBAAA,GAAwB,aAAA,UAAuB,MAAA"}
@@ -0,0 +1,21 @@
1
+ import { CommandFactoryOptions } from "./types.mjs";
2
+ import { CommandModule } from "yargs";
3
+
4
+ //#region src/core/commands/ls.d.ts
5
+ /**
6
+ * Ls command arguments
7
+ */
8
+ interface LsArgs {
9
+ path: string;
10
+ depth: number;
11
+ limit?: number;
12
+ maxChildren?: number;
13
+ pattern?: string;
14
+ }
15
+ /**
16
+ * Create ls command factory
17
+ */
18
+ declare function createLsCommand(options: CommandFactoryOptions): CommandModule<unknown, LsArgs>;
19
+ //#endregion
20
+ export { LsArgs, createLsCommand };
21
+ //# sourceMappingURL=ls.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ls.d.mts","names":[],"sources":["../../../src/core/commands/ls.ts"],"mappings":";;;;;;;UAeiB,MAAA;EACf,IAAA;EACA,KAAA;EACA,KAAA;EACA,WAAA;EACA,OAAA;AAAA;;;;iBAMc,eAAA,CAAgB,OAAA,EAAS,qBAAA,GAAwB,aAAA,UAAuB,MAAA"}
@@ -0,0 +1,58 @@
1
+ import { formatLsOutput } from "../formatters/ls.mjs";
2
+ import { cliPathToCanonical } from "../../path-utils.mjs";
3
+ import "../path-utils.mjs";
4
+ import { resolveAFS } from "./types.mjs";
5
+
6
+ //#region src/core/commands/ls.ts
7
+ /**
8
+ * Create ls command factory
9
+ */
10
+ function createLsCommand(options) {
11
+ return {
12
+ command: ["ls [path]", "list [path]"],
13
+ describe: "List directory contents",
14
+ builder: {
15
+ path: {
16
+ type: "string",
17
+ default: "/",
18
+ description: "Path to list"
19
+ },
20
+ depth: {
21
+ type: "number",
22
+ default: 1,
23
+ description: "Maximum depth to list"
24
+ },
25
+ limit: {
26
+ type: "number",
27
+ description: "Maximum number of entries to return"
28
+ },
29
+ "max-children": {
30
+ type: "number",
31
+ description: "Maximum children per directory"
32
+ },
33
+ pattern: {
34
+ type: "string",
35
+ description: "Glob pattern to filter entries"
36
+ }
37
+ },
38
+ handler: async (argv) => {
39
+ const afs = await resolveAFS(options);
40
+ const canonicalPath = cliPathToCanonical(argv.path || "/");
41
+ const result = await afs.list(canonicalPath, {
42
+ maxDepth: argv.depth ?? 1,
43
+ limit: argv.limit,
44
+ maxChildren: argv.maxChildren,
45
+ pattern: argv.pattern
46
+ });
47
+ options.onResult({
48
+ command: "ls",
49
+ result,
50
+ format: formatLsOutput
51
+ });
52
+ }
53
+ };
54
+ }
55
+
56
+ //#endregion
57
+ export { createLsCommand };
58
+ //# sourceMappingURL=ls.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ls.mjs","names":[],"sources":["../../../src/core/commands/ls.ts"],"sourcesContent":["/**\n * ls Command - Core Implementation\n *\n * Lists directory contents. Accepts AFS instance directly.\n * Returns AFSListResult directly (no custom type).\n */\n\nimport type { CommandModule } from \"yargs\";\nimport { formatLsOutput } from \"../formatters/index.js\";\nimport { cliPathToCanonical } from \"../path-utils.js\";\nimport { type CommandFactoryOptions, resolveAFS } from \"./types.js\";\n\n/**\n * Ls command arguments\n */\nexport interface LsArgs {\n path: string;\n depth: number;\n limit?: number;\n maxChildren?: number;\n pattern?: string;\n}\n\n/**\n * Create ls command factory\n */\nexport function createLsCommand(options: CommandFactoryOptions): CommandModule<unknown, LsArgs> {\n return {\n command: [\"ls [path]\", \"list [path]\"],\n describe: \"List directory contents\",\n builder: {\n path: {\n type: \"string\",\n default: \"/\",\n description: \"Path to list\",\n },\n depth: {\n type: \"number\",\n default: 1,\n description: \"Maximum depth to list\",\n },\n limit: {\n type: \"number\",\n description: \"Maximum number of entries to return\",\n },\n \"max-children\": {\n type: \"number\",\n description: \"Maximum children per directory\",\n },\n pattern: {\n type: \"string\",\n description: \"Glob pattern to filter entries\",\n },\n },\n handler: async (argv) => {\n const afs = await resolveAFS(options);\n const canonicalPath = cliPathToCanonical(argv.path || \"/\");\n const result = await afs.list(canonicalPath, {\n maxDepth: argv.depth ?? 1,\n limit: argv.limit,\n maxChildren: argv.maxChildren,\n pattern: argv.pattern,\n });\n options.onResult({\n command: \"ls\",\n result,\n format: formatLsOutput,\n });\n },\n };\n}\n"],"mappings":";;;;;;;;;AA0BA,SAAgB,gBAAgB,SAAgE;AAC9F,QAAO;EACL,SAAS,CAAC,aAAa,cAAc;EACrC,UAAU;EACV,SAAS;GACP,MAAM;IACJ,MAAM;IACN,SAAS;IACT,aAAa;IACd;GACD,OAAO;IACL,MAAM;IACN,SAAS;IACT,aAAa;IACd;GACD,OAAO;IACL,MAAM;IACN,aAAa;IACd;GACD,gBAAgB;IACd,MAAM;IACN,aAAa;IACd;GACD,SAAS;IACP,MAAM;IACN,aAAa;IACd;GACF;EACD,SAAS,OAAO,SAAS;GACvB,MAAM,MAAM,MAAM,WAAW,QAAQ;GACrC,MAAM,gBAAgB,mBAAmB,KAAK,QAAQ,IAAI;GAC1D,MAAM,SAAS,MAAM,IAAI,KAAK,eAAe;IAC3C,UAAU,KAAK,SAAS;IACxB,OAAO,KAAK;IACZ,aAAa,KAAK;IAClB,SAAS,KAAK;IACf,CAAC;AACF,WAAQ,SAAS;IACf,SAAS;IACT;IACA,QAAQ;IACT,CAAC;;EAEL"}
@@ -0,0 +1,222 @@
1
+ const require_schema = require('../../config/schema.cjs');
2
+ const require_mount_commands = require('../../config/mount-commands.cjs');
3
+ const require_mount = require('../formatters/mount.cjs');
4
+
5
+ //#region src/core/commands/mount.ts
6
+ /**
7
+ * Create mount command factory (with subcommands)
8
+ */
9
+ function createMountCommand(options) {
10
+ return {
11
+ command: "mount",
12
+ describe: "Mount management",
13
+ builder: (yargs) => yargs.command(createMountListSubcommand(options)).command(createMountAddSubcommand(options)).command(createMountRemoveSubcommand(options)).command(createMountValidateSubcommand(options)).demandCommand(1, "Please specify a subcommand").alias("help", "h"),
14
+ handler: () => {}
15
+ };
16
+ }
17
+ /**
18
+ * Create mount list subcommand
19
+ */
20
+ function createMountListSubcommand(options) {
21
+ return {
22
+ command: ["list", "ls"],
23
+ describe: "List all mounts",
24
+ builder: { namespace: {
25
+ type: "string",
26
+ description: "Filter by namespace"
27
+ } },
28
+ handler: async () => {
29
+ const result = await require_mount_commands.configMountListCommand(options.cwd ?? process.cwd());
30
+ options.onResult({
31
+ command: "mount list",
32
+ result: result.mounts,
33
+ format: require_mount.formatMountListOutput
34
+ });
35
+ }
36
+ };
37
+ }
38
+ /**
39
+ * Create mount add subcommand
40
+ */
41
+ /** Known argv keys that are NOT provider options */
42
+ const KNOWN_MOUNT_KEYS = new Set([
43
+ "path",
44
+ "uri",
45
+ "namespace",
46
+ "description",
47
+ "sensitive-args",
48
+ "sensitiveArgs",
49
+ "_",
50
+ "$0",
51
+ "help",
52
+ "h",
53
+ "version",
54
+ "v",
55
+ "json",
56
+ "yaml",
57
+ "view",
58
+ "interactive"
59
+ ]);
60
+ function createMountAddSubcommand(options) {
61
+ return {
62
+ command: "add <path> <uri>",
63
+ describe: "Add a mount",
64
+ builder: (yargs) => yargs.strict(false).positional("path", {
65
+ type: "string",
66
+ demandOption: true,
67
+ description: "Mount path (e.g., /src)"
68
+ }).positional("uri", {
69
+ type: "string",
70
+ demandOption: true,
71
+ description: "Provider URI (e.g., fs://./src)"
72
+ }).option("namespace", {
73
+ type: "string",
74
+ description: "Mount namespace"
75
+ }).option("description", {
76
+ type: "string",
77
+ description: "Mount description"
78
+ }).option("sensitive-args", {
79
+ type: "string",
80
+ array: true,
81
+ description: "Field names to treat as sensitive credentials"
82
+ }),
83
+ handler: async (argv) => {
84
+ const cwd = options.cwd ?? process.cwd();
85
+ if (!argv.uri || argv.uri.trim() === "") throw new Error("URI is required");
86
+ const resolvedUri = require_mount_commands.resolveUriPath(argv.uri, cwd);
87
+ const validation = require_schema.MountSchema.safeParse({
88
+ path: argv.path,
89
+ uri: resolvedUri,
90
+ description: argv.description
91
+ });
92
+ if (!validation.success) {
93
+ const errors = validation.error.issues.map((e) => e.message).join("; ");
94
+ throw new Error(errors);
95
+ }
96
+ const extraOptions = {};
97
+ for (const [key, value] of Object.entries(argv)) if (!KNOWN_MOUNT_KEYS.has(key) && !key.startsWith("-")) extraOptions[key] = value;
98
+ const sensitiveArgs = argv["sensitive-args"] ?? [];
99
+ const { resolveCredentialsForMount } = await Promise.resolve().then(() => require("../../config/afs-loader.cjs"));
100
+ const { createCLIAuthContext } = await Promise.resolve().then(() => require("../../credential/cli-auth-context.cjs"));
101
+ const { createCredentialStore } = await Promise.resolve().then(() => require("../../credential/store.cjs"));
102
+ const authContext = createCLIAuthContext();
103
+ const credentialStore = createCredentialStore();
104
+ const credResolveOptions = {
105
+ cwd,
106
+ uri: resolvedUri,
107
+ mountPath: validation.data.path,
108
+ authContext,
109
+ credentialStore,
110
+ extraOptions: Object.keys(extraOptions).length > 0 ? extraOptions : void 0,
111
+ sensitiveArgs
112
+ };
113
+ let credResult = await resolveCredentialsForMount(credResolveOptions);
114
+ const { verifyMount } = await Promise.resolve().then(() => require("../../config/afs-loader.cjs"));
115
+ let verifyOptions = {
116
+ ...extraOptions,
117
+ ...credResult?.allValues ?? {}
118
+ };
119
+ try {
120
+ await verifyMount(resolvedUri, validation.data.path, Object.keys(verifyOptions).length > 0 ? verifyOptions : void 0);
121
+ } catch (verifyError) {
122
+ if (credResult && !credResult.collected) {
123
+ credResult = await resolveCredentialsForMount({
124
+ ...credResolveOptions,
125
+ forceCollect: true
126
+ });
127
+ verifyOptions = {
128
+ ...extraOptions,
129
+ ...credResult?.allValues ?? {}
130
+ };
131
+ await verifyMount(resolvedUri, validation.data.path, Object.keys(verifyOptions).length > 0 ? verifyOptions : void 0);
132
+ } else throw verifyError;
133
+ }
134
+ if (credResult) await credResult.persistCredentials();
135
+ const nonSensitiveFromCreds = credResult?.nonSensitive ?? {};
136
+ const mountOptions = {
137
+ ...extraOptions,
138
+ ...nonSensitiveFromCreds
139
+ };
140
+ if (credResult?.sensitiveFields) for (const field of credResult.sensitiveFields) delete mountOptions[field];
141
+ const finalMountOptions = Object.keys(mountOptions).length > 0 ? mountOptions : void 0;
142
+ const persistUri = credResult?.configUri ?? validation.data.uri;
143
+ const result = await require_mount_commands.persistMount(cwd, {
144
+ path: validation.data.path,
145
+ uri: persistUri,
146
+ description: argv.description,
147
+ options: finalMountOptions
148
+ });
149
+ if (!result.success) throw new Error(result.message ?? "Failed to add mount");
150
+ options.onResult({
151
+ command: "mount add",
152
+ result: {
153
+ success: true,
154
+ path: argv.path,
155
+ uri: resolvedUri
156
+ },
157
+ format: (res) => `Mounted ${res.uri} at ${res.path}`
158
+ });
159
+ }
160
+ };
161
+ }
162
+ /**
163
+ * Create mount remove subcommand
164
+ */
165
+ function createMountRemoveSubcommand(options) {
166
+ return {
167
+ command: ["remove <path>", "rm <path>"],
168
+ describe: "Unmount a path",
169
+ builder: {
170
+ path: {
171
+ type: "string",
172
+ demandOption: true,
173
+ description: "Mount path to remove"
174
+ },
175
+ namespace: {
176
+ type: "string",
177
+ description: "Namespace of the mount"
178
+ }
179
+ },
180
+ handler: async (argv) => {
181
+ const result = await require_mount_commands.mountRemoveCommand(options.cwd ?? process.cwd(), argv.path);
182
+ if (!result.success) throw new Error(result.message ?? "Failed to remove mount");
183
+ options.onResult({
184
+ command: "mount remove",
185
+ result: {
186
+ success: true,
187
+ path: argv.path
188
+ },
189
+ format: (res) => res.success ? `Unmounted ${res.path}` : `Failed to unmount ${res.path}`
190
+ });
191
+ }
192
+ };
193
+ }
194
+ /**
195
+ * Format mount validate output
196
+ */
197
+ function formatMountValidateOutput(result, view) {
198
+ if (view === "json") return JSON.stringify(result, null, 2);
199
+ if (result.valid) return "Configuration is valid";
200
+ return ["Configuration validation failed:", ...result.errors.map((e) => ` - ${e}`)].join("\n");
201
+ }
202
+ /**
203
+ * Create mount validate subcommand
204
+ */
205
+ function createMountValidateSubcommand(options) {
206
+ return {
207
+ command: "validate",
208
+ describe: "Validate mount configuration",
209
+ handler: async () => {
210
+ const result = await require_mount_commands.mountValidateCommand(options.cwd ?? process.cwd());
211
+ options.onResult({
212
+ command: "mount validate",
213
+ result,
214
+ format: formatMountValidateOutput,
215
+ error: result.valid ? void 0 : { message: result.errors.join("; ") }
216
+ });
217
+ }
218
+ };
219
+ }
220
+
221
+ //#endregion
222
+ exports.createMountCommand = createMountCommand;