@agents-at-scale/ark 0.1.35-rc1 → 0.1.35

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 (207) hide show
  1. package/dist/commands/cluster/index.d.ts +1 -2
  2. package/dist/commands/cluster/index.js +5 -3
  3. package/dist/commands/completion.js +2 -159
  4. package/dist/commands/config.d.ts +3 -0
  5. package/dist/commands/config.js +321 -38
  6. package/dist/commands/generate/config.js +24 -5
  7. package/dist/commands/generate/generators/agent.js +2 -2
  8. package/dist/commands/generate/generators/mcpserver.d.ts +1 -2
  9. package/dist/commands/generate/generators/mcpserver.js +5 -26
  10. package/dist/commands/generate/generators/project.js +41 -22
  11. package/dist/commands/generate/generators/team.js +2 -2
  12. package/dist/commands/generate/index.d.ts +1 -2
  13. package/dist/commands/generate/index.js +1 -1
  14. package/dist/components/statusChecker.d.ts +23 -13
  15. package/dist/components/statusChecker.js +129 -275
  16. package/dist/config.d.ts +22 -3
  17. package/dist/config.js +161 -10
  18. package/dist/index.d.ts +1 -1
  19. package/dist/index.js +42 -40
  20. package/dist/lib/cluster.d.ts +1 -2
  21. package/dist/lib/cluster.js +16 -37
  22. package/dist/lib/config.d.ts +80 -26
  23. package/dist/lib/config.js +205 -70
  24. package/dist/lib/consts.d.ts +1 -0
  25. package/dist/lib/consts.js +2 -0
  26. package/dist/lib/errors.js +1 -1
  27. package/dist/lib/exec.d.ts +4 -0
  28. package/dist/lib/exec.js +11 -0
  29. package/dist/lib/types.d.ts +3 -10
  30. package/dist/ui/MainMenu.d.ts +1 -5
  31. package/dist/ui/MainMenu.js +91 -222
  32. package/dist/ui/statusFormatter.d.ts +7 -22
  33. package/dist/ui/statusFormatter.js +39 -39
  34. package/package.json +5 -17
  35. package/dist/arkServices.d.ts +0 -42
  36. package/dist/arkServices.js +0 -138
  37. package/dist/arkServices.spec.d.ts +0 -1
  38. package/dist/arkServices.spec.js +0 -24
  39. package/dist/charts/charts.d.ts +0 -5
  40. package/dist/charts/charts.js +0 -6
  41. package/dist/charts/dependencies.d.ts +0 -6
  42. package/dist/charts/dependencies.js +0 -50
  43. package/dist/charts/types.d.ts +0 -40
  44. package/dist/charts/types.js +0 -1
  45. package/dist/commands/agents/index.d.ts +0 -3
  46. package/dist/commands/agents/index.js +0 -51
  47. package/dist/commands/agents/index.spec.d.ts +0 -1
  48. package/dist/commands/agents/index.spec.js +0 -67
  49. package/dist/commands/agents/selector.d.ts +0 -8
  50. package/dist/commands/agents/selector.js +0 -53
  51. package/dist/commands/agents.d.ts +0 -2
  52. package/dist/commands/agents.js +0 -53
  53. package/dist/commands/chat/index.d.ts +0 -3
  54. package/dist/commands/chat/index.js +0 -29
  55. package/dist/commands/chat.d.ts +0 -2
  56. package/dist/commands/chat.js +0 -45
  57. package/dist/commands/cluster/get.d.ts +0 -2
  58. package/dist/commands/cluster/get.js +0 -39
  59. package/dist/commands/cluster/get.spec.d.ts +0 -1
  60. package/dist/commands/cluster/get.spec.js +0 -92
  61. package/dist/commands/cluster/index.spec.d.ts +0 -1
  62. package/dist/commands/cluster/index.spec.js +0 -24
  63. package/dist/commands/completion/index.d.ts +0 -3
  64. package/dist/commands/completion/index.js +0 -268
  65. package/dist/commands/completion/index.spec.d.ts +0 -1
  66. package/dist/commands/completion/index.spec.js +0 -34
  67. package/dist/commands/config/index.d.ts +0 -3
  68. package/dist/commands/config/index.js +0 -42
  69. package/dist/commands/config/index.spec.d.ts +0 -1
  70. package/dist/commands/config/index.spec.js +0 -78
  71. package/dist/commands/dashboard/index.d.ts +0 -4
  72. package/dist/commands/dashboard/index.js +0 -39
  73. package/dist/commands/dashboard.d.ts +0 -3
  74. package/dist/commands/dashboard.js +0 -39
  75. package/dist/commands/dev/index.d.ts +0 -3
  76. package/dist/commands/dev/index.js +0 -9
  77. package/dist/commands/dev/tool/check.d.ts +0 -2
  78. package/dist/commands/dev/tool/check.js +0 -142
  79. package/dist/commands/dev/tool/clean.d.ts +0 -2
  80. package/dist/commands/dev/tool/clean.js +0 -153
  81. package/dist/commands/dev/tool/generate.d.ts +0 -2
  82. package/dist/commands/dev/tool/generate.js +0 -28
  83. package/dist/commands/dev/tool/index.d.ts +0 -2
  84. package/dist/commands/dev/tool/index.js +0 -14
  85. package/dist/commands/dev/tool/init.d.ts +0 -2
  86. package/dist/commands/dev/tool/init.js +0 -320
  87. package/dist/commands/dev/tool/shared.d.ts +0 -5
  88. package/dist/commands/dev/tool/shared.js +0 -256
  89. package/dist/commands/dev/tool/status.d.ts +0 -2
  90. package/dist/commands/dev/tool/status.js +0 -136
  91. package/dist/commands/dev/tool-generate.spec.d.ts +0 -1
  92. package/dist/commands/dev/tool-generate.spec.js +0 -163
  93. package/dist/commands/dev/tool.d.ts +0 -2
  94. package/dist/commands/dev/tool.js +0 -559
  95. package/dist/commands/dev/tool.spec.d.ts +0 -1
  96. package/dist/commands/dev/tool.spec.js +0 -48
  97. package/dist/commands/install/index.d.ts +0 -8
  98. package/dist/commands/install/index.js +0 -302
  99. package/dist/commands/install/index.spec.d.ts +0 -1
  100. package/dist/commands/install/index.spec.js +0 -135
  101. package/dist/commands/install.d.ts +0 -3
  102. package/dist/commands/install.js +0 -147
  103. package/dist/commands/models/create.d.ts +0 -1
  104. package/dist/commands/models/create.js +0 -213
  105. package/dist/commands/models/create.spec.d.ts +0 -1
  106. package/dist/commands/models/create.spec.js +0 -125
  107. package/dist/commands/models/index.d.ts +0 -3
  108. package/dist/commands/models/index.js +0 -60
  109. package/dist/commands/models/index.spec.d.ts +0 -1
  110. package/dist/commands/models/index.spec.js +0 -76
  111. package/dist/commands/models/selector.d.ts +0 -8
  112. package/dist/commands/models/selector.js +0 -53
  113. package/dist/commands/routes/index.d.ts +0 -3
  114. package/dist/commands/routes/index.js +0 -93
  115. package/dist/commands/routes.d.ts +0 -2
  116. package/dist/commands/routes.js +0 -101
  117. package/dist/commands/status/index.d.ts +0 -4
  118. package/dist/commands/status/index.js +0 -232
  119. package/dist/commands/status.d.ts +0 -3
  120. package/dist/commands/status.js +0 -33
  121. package/dist/commands/targets/index.d.ts +0 -3
  122. package/dist/commands/targets/index.js +0 -65
  123. package/dist/commands/targets/index.spec.d.ts +0 -1
  124. package/dist/commands/targets/index.spec.js +0 -105
  125. package/dist/commands/targets.d.ts +0 -2
  126. package/dist/commands/targets.js +0 -65
  127. package/dist/commands/teams/index.d.ts +0 -3
  128. package/dist/commands/teams/index.js +0 -49
  129. package/dist/commands/teams/index.spec.d.ts +0 -1
  130. package/dist/commands/teams/index.spec.js +0 -70
  131. package/dist/commands/teams/selector.d.ts +0 -8
  132. package/dist/commands/teams/selector.js +0 -55
  133. package/dist/commands/tools/index.d.ts +0 -3
  134. package/dist/commands/tools/index.js +0 -49
  135. package/dist/commands/tools/index.spec.d.ts +0 -1
  136. package/dist/commands/tools/index.spec.js +0 -70
  137. package/dist/commands/tools/selector.d.ts +0 -8
  138. package/dist/commands/tools/selector.js +0 -53
  139. package/dist/commands/uninstall/index.d.ts +0 -3
  140. package/dist/commands/uninstall/index.js +0 -107
  141. package/dist/commands/uninstall/index.spec.d.ts +0 -1
  142. package/dist/commands/uninstall/index.spec.js +0 -117
  143. package/dist/commands/uninstall.d.ts +0 -2
  144. package/dist/commands/uninstall.js +0 -83
  145. package/dist/components/ChatUI.d.ts +0 -16
  146. package/dist/components/ChatUI.js +0 -801
  147. package/dist/components/StatusView.d.ts +0 -10
  148. package/dist/components/StatusView.js +0 -39
  149. package/dist/lib/arkApiClient.d.ts +0 -53
  150. package/dist/lib/arkApiClient.js +0 -102
  151. package/dist/lib/arkApiProxy.d.ts +0 -9
  152. package/dist/lib/arkApiProxy.js +0 -22
  153. package/dist/lib/arkServiceProxy.d.ts +0 -14
  154. package/dist/lib/arkServiceProxy.js +0 -95
  155. package/dist/lib/arkStatus.d.ts +0 -10
  156. package/dist/lib/arkStatus.js +0 -79
  157. package/dist/lib/arkStatus.spec.d.ts +0 -1
  158. package/dist/lib/arkStatus.spec.js +0 -49
  159. package/dist/lib/chatClient.d.ts +0 -33
  160. package/dist/lib/chatClient.js +0 -99
  161. package/dist/lib/cluster.spec.d.ts +0 -1
  162. package/dist/lib/cluster.spec.js +0 -338
  163. package/dist/lib/commandUtils.d.ts +0 -4
  164. package/dist/lib/commandUtils.js +0 -18
  165. package/dist/lib/commandUtils.test.d.ts +0 -1
  166. package/dist/lib/commandUtils.test.js +0 -44
  167. package/dist/lib/commands.d.ts +0 -16
  168. package/dist/lib/commands.js +0 -29
  169. package/dist/lib/commands.spec.d.ts +0 -1
  170. package/dist/lib/commands.spec.js +0 -146
  171. package/dist/lib/config.spec.d.ts +0 -1
  172. package/dist/lib/config.spec.js +0 -99
  173. package/dist/lib/config.test.d.ts +0 -1
  174. package/dist/lib/config.test.js +0 -93
  175. package/dist/lib/consts.spec.d.ts +0 -1
  176. package/dist/lib/consts.spec.js +0 -15
  177. package/dist/lib/dev/tools/analyzer.d.ts +0 -30
  178. package/dist/lib/dev/tools/analyzer.js +0 -190
  179. package/dist/lib/dev/tools/discover_tools.py +0 -392
  180. package/dist/lib/dev/tools/mcp-types.d.ts +0 -28
  181. package/dist/lib/dev/tools/mcp-types.js +0 -86
  182. package/dist/lib/dev/tools/types.d.ts +0 -50
  183. package/dist/lib/dev/tools/types.js +0 -1
  184. package/dist/lib/errors.spec.d.ts +0 -1
  185. package/dist/lib/errors.spec.js +0 -221
  186. package/dist/lib/output.d.ts +0 -36
  187. package/dist/lib/output.js +0 -89
  188. package/dist/lib/output.spec.d.ts +0 -1
  189. package/dist/lib/output.spec.js +0 -123
  190. package/dist/lib/portUtils.d.ts +0 -8
  191. package/dist/lib/portUtils.js +0 -39
  192. package/dist/lib/startup.d.ts +0 -5
  193. package/dist/lib/startup.js +0 -73
  194. package/dist/lib/startup.spec.d.ts +0 -1
  195. package/dist/lib/startup.spec.js +0 -168
  196. package/dist/types/types.d.ts +0 -40
  197. package/dist/types/types.js +0 -1
  198. package/dist/ui/AgentSelector.d.ts +0 -8
  199. package/dist/ui/AgentSelector.js +0 -53
  200. package/dist/ui/ModelSelector.d.ts +0 -8
  201. package/dist/ui/ModelSelector.js +0 -53
  202. package/dist/ui/TeamSelector.d.ts +0 -8
  203. package/dist/ui/TeamSelector.js +0 -55
  204. package/dist/ui/ToolSelector.d.ts +0 -8
  205. package/dist/ui/ToolSelector.js +0 -53
  206. package/dist/ui/statusFormatter.spec.d.ts +0 -1
  207. package/dist/ui/statusFormatter.spec.js +0 -58
@@ -1,92 +0,0 @@
1
- import { jest } from '@jest/globals';
2
- import { Command } from 'commander';
3
- const mockGetClusterInfo = jest.fn();
4
- jest.unstable_mockModule('../../lib/cluster.js', () => ({
5
- getClusterInfo: mockGetClusterInfo,
6
- }));
7
- const mockOutput = {
8
- error: jest.fn(),
9
- };
10
- jest.unstable_mockModule('../../lib/output.js', () => ({
11
- default: mockOutput,
12
- }));
13
- const mockExit = jest.spyOn(process, 'exit').mockImplementation((() => {
14
- throw new Error('process.exit called');
15
- }));
16
- const mockConsoleLog = jest.spyOn(console, 'log').mockImplementation(() => { });
17
- const { createGetCommand } = await import('./get.js');
18
- describe('cluster get command', () => {
19
- beforeEach(() => {
20
- jest.clearAllMocks();
21
- });
22
- it('creates command with correct structure', () => {
23
- const command = createGetCommand();
24
- expect(command).toBeInstanceOf(Command);
25
- expect(command.name()).toBe('get');
26
- });
27
- it('displays cluster info in text format by default', async () => {
28
- mockGetClusterInfo.mockResolvedValue({
29
- context: 'test-cluster',
30
- namespace: 'default',
31
- type: 'minikube',
32
- ip: '192.168.1.1',
33
- });
34
- const command = createGetCommand();
35
- await command.parseAsync(['node', 'test']);
36
- expect(mockGetClusterInfo).toHaveBeenCalledWith(undefined);
37
- expect(mockConsoleLog).toHaveBeenCalledWith('context: test-cluster');
38
- expect(mockConsoleLog).toHaveBeenCalledWith('namespace: default');
39
- expect(mockConsoleLog).toHaveBeenCalledWith('type: minikube');
40
- expect(mockConsoleLog).toHaveBeenCalledWith('ip: 192.168.1.1');
41
- });
42
- it('displays cluster info in json format when requested', async () => {
43
- const clusterInfo = {
44
- context: 'prod-cluster',
45
- namespace: 'production',
46
- type: 'eks',
47
- ip: '10.0.0.1',
48
- };
49
- mockGetClusterInfo.mockResolvedValue(clusterInfo);
50
- const command = createGetCommand();
51
- await command.parseAsync(['node', 'test', '-o', 'json']);
52
- expect(mockConsoleLog).toHaveBeenCalledWith(JSON.stringify(clusterInfo, null, 2));
53
- });
54
- it('uses specified context when provided', async () => {
55
- mockGetClusterInfo.mockResolvedValue({
56
- context: 'custom-context',
57
- namespace: 'custom',
58
- type: 'kind',
59
- ip: '127.0.0.1',
60
- });
61
- const command = createGetCommand();
62
- await command.parseAsync(['node', 'test', '-c', 'custom-context']);
63
- expect(mockGetClusterInfo).toHaveBeenCalledWith('custom-context');
64
- });
65
- it('handles missing ip gracefully', async () => {
66
- mockGetClusterInfo.mockResolvedValue({
67
- context: 'test-cluster',
68
- namespace: 'default',
69
- type: 'unknown',
70
- ip: undefined,
71
- });
72
- const command = createGetCommand();
73
- await command.parseAsync(['node', 'test']);
74
- expect(mockConsoleLog).toHaveBeenCalledWith('ip: unknown');
75
- });
76
- it('exits with error when cluster info has error', async () => {
77
- mockGetClusterInfo.mockResolvedValue({
78
- error: 'No cluster found',
79
- });
80
- const command = createGetCommand();
81
- await expect(command.parseAsync(['node', 'test'])).rejects.toThrow('process.exit called');
82
- expect(mockOutput.error).toHaveBeenCalledWith('getting cluster info:', 'No cluster found');
83
- expect(mockExit).toHaveBeenCalledWith(1);
84
- });
85
- it('handles exceptions gracefully', async () => {
86
- mockGetClusterInfo.mockRejectedValue(new Error('Connection failed'));
87
- const command = createGetCommand();
88
- await expect(command.parseAsync(['node', 'test'])).rejects.toThrow('process.exit called');
89
- expect(mockOutput.error).toHaveBeenCalledWith('failed to get cluster info:', 'Connection failed');
90
- expect(mockExit).toHaveBeenCalledWith(1);
91
- });
92
- });
@@ -1 +0,0 @@
1
- export {};
@@ -1,24 +0,0 @@
1
- import { jest } from '@jest/globals';
2
- import { Command } from 'commander';
3
- const mockCreateGetCommand = jest.fn();
4
- jest.unstable_mockModule('./get.js', () => ({
5
- createGetCommand: mockCreateGetCommand,
6
- }));
7
- const { createClusterCommand } = await import('./index.js');
8
- describe('cluster command', () => {
9
- beforeEach(() => {
10
- jest.clearAllMocks();
11
- mockCreateGetCommand.mockReturnValue(new Command('get'));
12
- });
13
- it('creates command with correct structure', () => {
14
- const command = createClusterCommand({});
15
- expect(command).toBeInstanceOf(Command);
16
- expect(command.name()).toBe('cluster');
17
- });
18
- it('adds get subcommand', () => {
19
- const command = createClusterCommand({});
20
- expect(mockCreateGetCommand).toHaveBeenCalled();
21
- const getCommand = command.commands.find((cmd) => cmd.name() === 'get');
22
- expect(getCommand).toBeDefined();
23
- });
24
- });
@@ -1,3 +0,0 @@
1
- import { Command } from 'commander';
2
- import type { ArkConfig } from '../../lib/config.js';
3
- export declare function createCompletionCommand(_: ArkConfig): Command;
@@ -1,268 +0,0 @@
1
- import chalk from 'chalk';
2
- import { Command } from 'commander';
3
- export function createCompletionCommand(_) {
4
- const completion = new Command('completion');
5
- completion.description('Generate shell completion scripts').action(() => {
6
- console.log(chalk.cyan('Shell completion for ARK CLI'));
7
- console.log('');
8
- console.log('Usage:');
9
- console.log(' ark completion bash Generate bash completion script');
10
- console.log(' ark completion zsh Generate zsh completion script');
11
- console.log('');
12
- console.log('To enable completion, add this to your shell profile:');
13
- console.log(chalk.grey(' # For bash:'));
14
- console.log(chalk.grey(' eval "$(ark completion bash)"'));
15
- console.log(chalk.grey(' # For zsh:'));
16
- console.log(chalk.grey(' eval "$(ark completion zsh)"'));
17
- });
18
- completion
19
- .command('bash')
20
- .description('Generate bash completion script')
21
- .action(() => {
22
- console.log(`
23
- _ark_completion() {
24
- local cur prev opts
25
- COMPREPLY=()
26
- cur="\${COMP_WORDS[COMP_CWORD]}"
27
- prev="\${COMP_WORDS[COMP_CWORD-1]}"
28
-
29
- case \${COMP_CWORD} in
30
- 1)
31
- opts="agents chat cluster completion config dashboard dev generate install models routes status targets teams tools uninstall help"
32
- COMPREPLY=( $(compgen -W "\${opts}" -- \${cur}) )
33
- return 0
34
- ;;
35
- 2)
36
- case \${prev} in
37
- cluster)
38
- opts="get-ip get-type"
39
- COMPREPLY=( $(compgen -W "\${opts}" -- \${cur}) )
40
- return 0
41
- ;;
42
- completion)
43
- opts="bash zsh"
44
- COMPREPLY=( $(compgen -W "\${opts}" -- \${cur}) )
45
- return 0
46
- ;;
47
- check)
48
- opts="status"
49
- COMPREPLY=( $(compgen -W "\${opts}" -- \${cur}) )
50
- return 0
51
- ;;
52
- targets)
53
- opts="list ls"
54
- COMPREPLY=( $(compgen -W "\${opts}" -- \${cur}) )
55
- return 0
56
- ;;
57
- agents)
58
- opts="list ls"
59
- COMPREPLY=( $(compgen -W "\${opts}" -- \${cur}) )
60
- return 0
61
- ;;
62
- models)
63
- opts="list ls create"
64
- COMPREPLY=( $(compgen -W "\${opts}" -- \${cur}) )
65
- return 0
66
- ;;
67
- teams)
68
- opts="list ls"
69
- COMPREPLY=( $(compgen -W "\${opts}" -- \${cur}) )
70
- return 0
71
- ;;
72
- tools)
73
- opts="list ls"
74
- COMPREPLY=( $(compgen -W "\${opts}" -- \${cur}) )
75
- return 0
76
- ;;
77
- dev)
78
- opts="tool"
79
- COMPREPLY=( $(compgen -W "\${opts}" -- \${cur}) )
80
- return 0
81
- ;;
82
- generate)
83
- opts="agent marketplace mcp-server project query team"
84
- COMPREPLY=( $(compgen -W "\${opts}" -- \${cur}) )
85
- return 0
86
- ;;
87
- chat)
88
- # Dynamically fetch available targets using ark targets list
89
- local targets
90
- targets=$(ark targets list 2>/dev/null)
91
- if [ -z "$targets" ]; then
92
- # Fallback to common targets if API is not available
93
- targets="agent/sample-agent agent/math agent/weather model/default"
94
- fi
95
- COMPREPLY=( $(compgen -W "\${targets}" -- \${cur}) )
96
- return 0
97
- ;;
98
- esac
99
- ;;
100
- 3)
101
- case \${COMP_WORDS[1]} in
102
- dev)
103
- case \${prev} in
104
- tool)
105
- opts="check init generate"
106
- COMPREPLY=( $(compgen -W "\${opts}" -- \${cur}) )
107
- return 0
108
- ;;
109
- esac
110
- ;;
111
- esac
112
- ;;
113
- 4)
114
- # Handle path completion for dev tool commands
115
- case \${COMP_WORDS[1]} in
116
- dev)
117
- if [[ \${COMP_WORDS[2]} == "tool" ]]; then
118
- case \${COMP_WORDS[3]} in
119
- check|init|generate)
120
- # Complete with directories
121
- COMPREPLY=( $(compgen -d -- \${cur}) )
122
- return 0
123
- ;;
124
- esac
125
- fi
126
- ;;
127
- esac
128
- ;;
129
- esac
130
- }
131
-
132
- complete -F _ark_completion ark
133
- `.trim());
134
- });
135
- completion
136
- .command('zsh')
137
- .description('Generate zsh completion script')
138
- .action(() => {
139
- // Shell script requires escaped $ characters
140
- /* eslint-disable no-useless-escape */
141
- console.log(`
142
- #compdef ark
143
-
144
- _ark() {
145
- local context state line
146
-
147
- _arguments -C \\
148
- '1:command:->command' \\
149
- '2:subcommand:->subcommand' \\
150
- '*::arg:->args'
151
-
152
- case $state in
153
- command)
154
- _values 'ark commands' \\
155
- 'agents[List available agents]' \\
156
- 'chat[Interactive chat with agents and models]' \\
157
- 'cluster[Cluster management commands]' \\
158
- 'completion[Generate shell completion scripts]' \\
159
- 'config[Configuration management]' \\
160
- 'dashboard[Open ARK dashboard]' \\
161
- 'dev[Development tools for ARK]' \\
162
- 'generate[Generate ARK resources]' \\
163
- 'install[Install ARK services]' \\
164
- 'models[List available models]' \\
165
- 'routes[List available routes]' \\
166
- 'status[Check system status]' \\
167
- 'targets[List available query targets]' \\
168
- 'teams[List available teams]' \\
169
- 'tools[List available tools]' \\
170
- 'uninstall[Uninstall ARK services]' \\
171
- 'help[Show help information]'
172
- ;;
173
- subcommand)
174
- case $words[2] in
175
- cluster)
176
- _values 'cluster commands' \\
177
- 'get-ip[Get cluster IP address]' \\
178
- 'get-type[Get cluster type]'
179
- ;;
180
- completion)
181
- _values 'completion shells' \\
182
- 'bash[Generate bash completion]' \\
183
- 'zsh[Generate zsh completion]'
184
- ;;
185
- check)
186
- _values 'check commands' \\
187
- 'status[Check system status]'
188
- ;;
189
- targets)
190
- _values 'targets commands' \\
191
- 'list[List all available targets]' \\
192
- 'ls[List all available targets]'
193
- ;;
194
- agents)
195
- _values 'agents commands' \\
196
- 'list[List all available agents]' \\
197
- 'ls[List all available agents]'
198
- ;;
199
- models)
200
- _values 'models commands' \\
201
- 'list[List all available models]' \\
202
- 'ls[List all available models]' \\
203
- 'create[Create a new model]'
204
- ;;
205
- teams)
206
- _values 'teams commands' \\
207
- 'list[List all available teams]' \\
208
- 'ls[List all available teams]'
209
- ;;
210
- tools)
211
- _values 'tools commands' \\
212
- 'list[List all available tools]' \\
213
- 'ls[List all available tools]'
214
- ;;
215
- dev)
216
- _values 'dev commands' \\
217
- 'tool[MCP tool development utilities]'
218
- ;;
219
- generate)
220
- _values 'generate types' \\
221
- 'agent[Generate a new agent]' \\
222
- 'marketplace[Generate marketplace content]' \\
223
- 'mcp-server[Generate MCP server]' \\
224
- 'project[Generate a new project]' \\
225
- 'query[Generate a query]' \\
226
- 'team[Generate a team]'
227
- ;;
228
- chat)
229
- # Get available targets dynamically
230
- local -a targets
231
- targets=($(ark targets list 2>/dev/null))
232
- if [ \${#targets[@]} -eq 0 ]; then
233
- targets=('agent/sample-agent' 'agent/math' 'agent/weather' 'model/default')
234
- fi
235
- _values 'available targets' \${targets[@]}
236
- ;;
237
- esac
238
- ;;
239
- args)
240
- case \$words[2] in
241
- dev)
242
- if [[ \$words[3] == "tool" ]]; then
243
- case \$words[4] in
244
- check|init|generate)
245
- # Complete with directories
246
- _files -/
247
- ;;
248
- *)
249
- _values 'tool commands' \\
250
- 'check[Check the status of an MCP tool project]' \\
251
- 'init[Initialize an MCP tool project]' \\
252
- 'generate[Generate project files from templates]' \\
253
- 'clean[Remove template-generated files]'
254
- ;;
255
- esac
256
- fi
257
- ;;
258
- esac
259
- ;;
260
- esac
261
- }
262
-
263
- _ark
264
- `.trim());
265
- /* eslint-enable no-useless-escape */
266
- });
267
- return completion;
268
- }
@@ -1 +0,0 @@
1
- export {};
@@ -1,34 +0,0 @@
1
- import { jest } from '@jest/globals';
2
- import { Command } from 'commander';
3
- const mockConsoleLog = jest.spyOn(console, 'log').mockImplementation(() => { });
4
- const { createCompletionCommand } = await import('./index.js');
5
- describe('completion command', () => {
6
- beforeEach(() => {
7
- jest.clearAllMocks();
8
- });
9
- it('creates command with correct structure', () => {
10
- const command = createCompletionCommand({});
11
- expect(command).toBeInstanceOf(Command);
12
- expect(command.name()).toBe('completion');
13
- });
14
- it('shows help when called without subcommand', async () => {
15
- const command = createCompletionCommand({});
16
- await command.parseAsync(['node', 'test']);
17
- // Check first call contains the title (strip ANSI color codes)
18
- expect(mockConsoleLog.mock.calls[0][0]).toContain('Shell completion for ARK CLI');
19
- // Check that bash completion instructions are shown
20
- expect(mockConsoleLog).toHaveBeenCalledWith(expect.stringContaining('ark completion bash'));
21
- });
22
- it('outputs bash completion script', async () => {
23
- const command = createCompletionCommand({});
24
- await command.parseAsync(['node', 'test', 'bash']);
25
- expect(mockConsoleLog).toHaveBeenCalledWith(expect.stringContaining('_ark_completion()'));
26
- expect(mockConsoleLog).toHaveBeenCalledWith(expect.stringContaining('COMPREPLY'));
27
- });
28
- it('outputs zsh completion script', async () => {
29
- const command = createCompletionCommand({});
30
- await command.parseAsync(['node', 'test', 'zsh']);
31
- expect(mockConsoleLog).toHaveBeenCalledWith(expect.stringContaining('#compdef ark'));
32
- expect(mockConsoleLog).toHaveBeenCalledWith(expect.stringContaining('_ark()'));
33
- });
34
- });
@@ -1,3 +0,0 @@
1
- import { Command } from 'commander';
2
- import { type ArkConfig } from '../../lib/config.js';
3
- export declare function createConfigCommand(_: ArkConfig): Command;
@@ -1,42 +0,0 @@
1
- import { Command } from 'commander';
2
- import chalk from 'chalk';
3
- import { loadConfig, getConfigPaths, formatConfig, } from '../../lib/config.js';
4
- import fs from 'fs';
5
- export function createConfigCommand(_) {
6
- const configCommand = new Command('config');
7
- configCommand.description('Show current configuration').action(() => {
8
- const config = loadConfig();
9
- const paths = getConfigPaths();
10
- console.log();
11
- // User config
12
- if (fs.existsSync(paths.user)) {
13
- console.log(chalk.green('✓'), chalk.white(paths.user));
14
- }
15
- else {
16
- console.log(chalk.red('✗'), chalk.white(paths.user), chalk.gray(`doesn't exist`));
17
- }
18
- // Project config
19
- if (fs.existsSync(paths.project)) {
20
- console.log(chalk.green('✓'), chalk.white(paths.project));
21
- }
22
- else {
23
- console.log(chalk.red('✗'), chalk.white(paths.project), chalk.gray(`doesn't exist`));
24
- }
25
- // Environment variables
26
- if (process.env.ARK_CHAT_STREAMING !== undefined) {
27
- console.log(chalk.green('✓'), chalk.white('ARK_CHAT_STREAMING'), chalk.gray(process.env.ARK_CHAT_STREAMING));
28
- }
29
- else {
30
- console.log(chalk.red('✗'), chalk.white('ARK_CHAT_STREAMING'), chalk.gray('not set'));
31
- }
32
- if (process.env.ARK_CHAT_OUTPUT_FORMAT !== undefined) {
33
- console.log(chalk.green('✓'), chalk.white('ARK_CHAT_OUTPUT_FORMAT'), chalk.gray(process.env.ARK_CHAT_OUTPUT_FORMAT));
34
- }
35
- else {
36
- console.log(chalk.red('✗'), chalk.white('ARK_CHAT_OUTPUT_FORMAT'), chalk.gray('not set'));
37
- }
38
- console.log();
39
- console.log(formatConfig(config));
40
- });
41
- return configCommand;
42
- }
@@ -1 +0,0 @@
1
- export {};
@@ -1,78 +0,0 @@
1
- import { jest } from '@jest/globals';
2
- import { Command } from 'commander';
3
- const mockLoadConfig = jest.fn();
4
- const mockGetConfigPaths = jest.fn();
5
- const mockFormatConfig = jest.fn();
6
- jest.unstable_mockModule('../../lib/config.js', () => ({
7
- loadConfig: mockLoadConfig,
8
- getConfigPaths: mockGetConfigPaths,
9
- formatConfig: mockFormatConfig,
10
- }));
11
- const mockExistsSync = jest.fn();
12
- jest.unstable_mockModule('fs', () => ({
13
- default: {
14
- existsSync: mockExistsSync,
15
- },
16
- existsSync: mockExistsSync,
17
- }));
18
- const mockConsoleLog = jest.spyOn(console, 'log').mockImplementation(() => { });
19
- const { createConfigCommand } = await import('./index.js');
20
- describe('config command', () => {
21
- beforeEach(() => {
22
- jest.clearAllMocks();
23
- // Reset environment variables
24
- delete process.env.ARK_CHAT_STREAMING;
25
- delete process.env.ARK_CHAT_OUTPUT_FORMAT;
26
- });
27
- it('creates command with correct structure', () => {
28
- const command = createConfigCommand({});
29
- expect(command).toBeInstanceOf(Command);
30
- expect(command.name()).toBe('config');
31
- });
32
- it('displays config paths and environment variables', async () => {
33
- const mockConfig = { defaultModel: 'test-model' };
34
- const mockPaths = {
35
- user: '/home/user/.arkrc.yaml',
36
- project: '/project/.arkrc.yaml',
37
- };
38
- mockLoadConfig.mockReturnValue(mockConfig);
39
- mockGetConfigPaths.mockReturnValue(mockPaths);
40
- mockFormatConfig.mockReturnValue('formatted config');
41
- mockExistsSync.mockReturnValue(true);
42
- const command = createConfigCommand({});
43
- await command.parseAsync(['node', 'test']);
44
- expect(mockLoadConfig).toHaveBeenCalled();
45
- expect(mockGetConfigPaths).toHaveBeenCalled();
46
- expect(mockFormatConfig).toHaveBeenCalledWith(mockConfig);
47
- expect(mockExistsSync).toHaveBeenCalledWith(mockPaths.user);
48
- expect(mockExistsSync).toHaveBeenCalledWith(mockPaths.project);
49
- });
50
- it('shows when config files do not exist', async () => {
51
- const mockPaths = {
52
- user: '/home/user/.arkrc.yaml',
53
- project: '/project/.arkrc.yaml',
54
- };
55
- mockLoadConfig.mockReturnValue({});
56
- mockGetConfigPaths.mockReturnValue(mockPaths);
57
- mockFormatConfig.mockReturnValue('');
58
- mockExistsSync.mockReturnValue(false);
59
- const command = createConfigCommand({});
60
- await command.parseAsync(['node', 'test']);
61
- expect(mockExistsSync).toHaveBeenCalledWith(mockPaths.user);
62
- expect(mockExistsSync).toHaveBeenCalledWith(mockPaths.project);
63
- // Should show that files don't exist
64
- expect(mockConsoleLog).toHaveBeenCalled();
65
- });
66
- it('displays environment variables when set', async () => {
67
- process.env.ARK_CHAT_STREAMING = 'true';
68
- process.env.ARK_CHAT_OUTPUT_FORMAT = 'json';
69
- mockLoadConfig.mockReturnValue({});
70
- mockGetConfigPaths.mockReturnValue({ user: '', project: '' });
71
- mockFormatConfig.mockReturnValue('');
72
- mockExistsSync.mockReturnValue(false);
73
- const command = createConfigCommand({});
74
- await command.parseAsync(['node', 'test']);
75
- // Should display the environment variables
76
- expect(mockConsoleLog).toHaveBeenCalled();
77
- });
78
- });
@@ -1,4 +0,0 @@
1
- import { Command } from 'commander';
2
- import type { ArkConfig } from '../../lib/config.js';
3
- export declare function openDashboard(): Promise<void>;
4
- export declare function createDashboardCommand(_: ArkConfig): Command;
@@ -1,39 +0,0 @@
1
- import chalk from 'chalk';
2
- import { Command } from 'commander';
3
- import open from 'open';
4
- import ora from 'ora';
5
- import { ArkServiceProxy } from '../../lib/arkServiceProxy.js';
6
- import { arkServices } from '../../arkServices.js';
7
- export async function openDashboard() {
8
- const spinner = ora('Connecting to dashboard').start();
9
- try {
10
- const dashboardService = arkServices['ark-dashboard'];
11
- const proxy = new ArkServiceProxy(dashboardService, 3274); // DASH on phone keypad
12
- const url = await proxy.start();
13
- spinner.succeed('Dashboard connected');
14
- console.log(`ARK dashboard running on: ${chalk.green(url)}`);
15
- console.log(chalk.gray('Press Ctrl+C to stop'));
16
- // Brief pause before opening browser
17
- await new Promise((resolve) => setTimeout(resolve, 1000));
18
- // Open browser
19
- await open(url);
20
- // Handle Ctrl+C gracefully
21
- process.on('SIGINT', () => {
22
- proxy.stop();
23
- process.exit(0);
24
- });
25
- // Keep process alive
26
- process.stdin.resume();
27
- }
28
- catch (error) {
29
- spinner.fail(error instanceof Error ? error.message : 'Failed to start dashboard');
30
- process.exit(1);
31
- }
32
- }
33
- export function createDashboardCommand(_) {
34
- const dashboardCommand = new Command('dashboard');
35
- dashboardCommand
36
- .description('Open the ARK dashboard in your browser')
37
- .action(openDashboard);
38
- return dashboardCommand;
39
- }
@@ -1,3 +0,0 @@
1
- import { Command } from 'commander';
2
- export declare function openDashboard(): Promise<void>;
3
- export declare function createDashboardCommand(): Command;
@@ -1,39 +0,0 @@
1
- import chalk from 'chalk';
2
- import { Command } from 'commander';
3
- import open from 'open';
4
- import ora from 'ora';
5
- import { ArkServiceProxy } from '../lib/arkServiceProxy.js';
6
- import { arkServices } from '../arkServices.js';
7
- export async function openDashboard() {
8
- const spinner = ora('Connecting to dashboard').start();
9
- try {
10
- const dashboardService = arkServices['ark-dashboard'];
11
- const proxy = new ArkServiceProxy(dashboardService, 3274); // DASH on phone keypad
12
- const url = await proxy.start();
13
- spinner.succeed('Dashboard connected');
14
- console.log(`ARK dashboard running on: ${chalk.green(url)}`);
15
- console.log(chalk.gray('Press Ctrl+C to stop'));
16
- // Brief pause before opening browser
17
- await new Promise((resolve) => setTimeout(resolve, 1000));
18
- // Open browser
19
- await open(url);
20
- // Handle Ctrl+C gracefully
21
- process.on('SIGINT', () => {
22
- proxy.stop();
23
- process.exit(0);
24
- });
25
- // Keep process alive
26
- process.stdin.resume();
27
- }
28
- catch (error) {
29
- spinner.fail(error instanceof Error ? error.message : 'Failed to start dashboard');
30
- process.exit(1);
31
- }
32
- }
33
- export function createDashboardCommand() {
34
- const dashboardCommand = new Command('dashboard');
35
- dashboardCommand
36
- .description('Open the ARK dashboard in your browser')
37
- .action(openDashboard);
38
- return dashboardCommand;
39
- }
@@ -1,3 +0,0 @@
1
- import { Command } from 'commander';
2
- import type { ArkConfig } from '../../lib/config.js';
3
- export declare function createDevCommand(_: ArkConfig): Command;
@@ -1,9 +0,0 @@
1
- import { Command } from 'commander';
2
- import { createToolCommand } from './tool/index.js';
3
- export function createDevCommand(_) {
4
- const devCommand = new Command('dev');
5
- devCommand.description('Development tools for ARK');
6
- // Add subcommands
7
- devCommand.addCommand(createToolCommand());
8
- return devCommand;
9
- }
@@ -1,2 +0,0 @@
1
- import { Command } from 'commander';
2
- export declare function createCheckCommand(): Command;