plazbot-cli 0.2.26 → 0.3.2

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 (178) hide show
  1. package/CLAUDE.md +34 -5
  2. package/README.md +21 -0
  3. package/dist/cli.js +32 -20
  4. package/dist/commands/agent/ai-config.js +98 -50
  5. package/dist/commands/agent/chat.js +80 -74
  6. package/dist/commands/agent/copy.js +23 -21
  7. package/dist/commands/agent/create.js +42 -72
  8. package/dist/commands/agent/delete.js +29 -30
  9. package/dist/commands/agent/enable-widget.js +30 -26
  10. package/dist/commands/agent/export.js +90 -77
  11. package/dist/commands/agent/files.js +68 -60
  12. package/dist/commands/agent/get.js +101 -87
  13. package/dist/commands/agent/index.js +53 -39
  14. package/dist/commands/agent/list.js +26 -24
  15. package/dist/commands/agent/monitor.js +91 -86
  16. package/dist/commands/agent/on-message.js +40 -37
  17. package/dist/commands/agent/set.js +62 -59
  18. package/dist/commands/agent/templates.js +109 -108
  19. package/dist/commands/agent/tools.js +64 -65
  20. package/dist/commands/agent/update.js +28 -27
  21. package/dist/commands/agent/validate.js +127 -0
  22. package/dist/commands/agent/wizard.js +152 -159
  23. package/dist/commands/auth/index.js +7 -10
  24. package/dist/commands/auth/login.js +50 -37
  25. package/dist/commands/auth/logout.js +16 -14
  26. package/dist/commands/auth/status.js +19 -16
  27. package/dist/commands/portal/add-agent.js +26 -24
  28. package/dist/commands/portal/add-link.js +21 -17
  29. package/dist/commands/portal/clear-links.js +17 -15
  30. package/dist/commands/portal/create.js +25 -21
  31. package/dist/commands/portal/delete.js +31 -30
  32. package/dist/commands/portal/get.js +33 -31
  33. package/dist/commands/portal/index.js +30 -22
  34. package/dist/commands/portal/list.js +34 -30
  35. package/dist/commands/portal/update.js +41 -33
  36. package/dist/commands/whatsapp/broadcast.js +40 -37
  37. package/dist/commands/whatsapp/channels.js +40 -34
  38. package/dist/commands/whatsapp/chat.js +33 -32
  39. package/dist/commands/whatsapp/connect.js +53 -52
  40. package/dist/commands/whatsapp/delete-webhook.js +19 -17
  41. package/dist/commands/whatsapp/index.js +35 -25
  42. package/dist/commands/whatsapp/register-webhook.js +21 -19
  43. package/dist/commands/whatsapp/send-template.js +39 -31
  44. package/dist/commands/whatsapp/send.js +27 -23
  45. package/dist/commands/whatsapp/widget.js +35 -31
  46. package/dist/commands/workers/deploy.js +49 -44
  47. package/dist/commands/workers/index.js +28 -18
  48. package/dist/commands/workers/list.js +43 -35
  49. package/dist/commands/workers/logs.js +38 -32
  50. package/dist/commands/workers/remove.js +38 -37
  51. package/dist/commands/workers/secret.js +63 -58
  52. package/dist/commands/workers/test.js +44 -36
  53. package/dist/schemas/agent.config.schema.json +569 -0
  54. package/dist/studio/api/sseClient.js +97 -0
  55. package/dist/studio/api/studioApi.js +25 -0
  56. package/dist/studio/api/types.js +16 -0
  57. package/dist/studio/components/AgentPanel.js +35 -0
  58. package/dist/studio/components/App.js +214 -0
  59. package/dist/studio/components/ChatLog.js +59 -0
  60. package/dist/studio/components/Footer.js +11 -0
  61. package/dist/studio/components/Header.js +8 -0
  62. package/dist/studio/components/Input.js +15 -0
  63. package/dist/studio/components/Message.js +56 -0
  64. package/dist/studio/components/Suggestions.js +11 -0
  65. package/dist/studio/components/ToolCall.js +33 -0
  66. package/dist/studio/components/WhatsappConnectCard.js +57 -0
  67. package/dist/studio/index.js +42 -0
  68. package/dist/studio/render/json.js +16 -0
  69. package/dist/studio/render/markdown.js +86 -0
  70. package/dist/studio/render/steps.js +58 -0
  71. package/dist/studio/runOneShot.js +96 -0
  72. package/dist/studio/runRepl.js +52 -0
  73. package/dist/studio/slash/handlers.js +199 -0
  74. package/dist/studio/slash/parser.js +46 -0
  75. package/dist/studio/slash/registry.js +16 -0
  76. package/dist/studio/state/store.js +181 -0
  77. package/dist/studio/whatsapp/api.js +63 -0
  78. package/dist/studio/whatsapp/polling.js +77 -0
  79. package/dist/studio/whatsapp/types.js +31 -0
  80. package/dist/types/agent.js +1 -2
  81. package/dist/types/auth.js +1 -2
  82. package/dist/types/common.js +1 -2
  83. package/dist/types/message.js +1 -2
  84. package/dist/types/portal.js +1 -2
  85. package/dist/types/workers.js +1 -2
  86. package/dist/utils/agent-errors.js +46 -0
  87. package/dist/utils/api.js +8 -9
  88. package/dist/utils/banner.js +33 -34
  89. package/dist/utils/credentials.js +12 -20
  90. package/dist/utils/help.js +44 -0
  91. package/dist/utils/logger.js +13 -19
  92. package/dist/utils/ui.js +35 -49
  93. package/package.json +22 -10
  94. package/src/cli.ts +24 -8
  95. package/src/commands/agent/ai-config.ts +89 -34
  96. package/src/commands/agent/chat.ts +49 -37
  97. package/src/commands/agent/copy.ts +19 -13
  98. package/src/commands/agent/create.ts +32 -22
  99. package/src/commands/agent/delete.ts +24 -18
  100. package/src/commands/agent/enable-widget.ts +31 -23
  101. package/src/commands/agent/export.ts +72 -51
  102. package/src/commands/agent/files.ts +51 -39
  103. package/src/commands/agent/get.ts +86 -66
  104. package/src/commands/agent/index.ts +36 -18
  105. package/src/commands/agent/list.ts +22 -16
  106. package/src/commands/agent/monitor.ts +67 -56
  107. package/src/commands/agent/on-message.ts +36 -27
  108. package/src/commands/agent/set.ts +47 -37
  109. package/src/commands/agent/templates.ts +90 -82
  110. package/src/commands/agent/tools.ts +53 -47
  111. package/src/commands/agent/update.ts +28 -20
  112. package/src/commands/agent/validate.ts +135 -0
  113. package/src/commands/agent/wizard.ts +114 -114
  114. package/src/commands/auth/index.ts +3 -3
  115. package/src/commands/auth/login.ts +44 -29
  116. package/src/commands/auth/logout.ts +16 -10
  117. package/src/commands/auth/status.ts +14 -8
  118. package/src/commands/portal/add-agent.ts +23 -17
  119. package/src/commands/portal/add-link.ts +17 -9
  120. package/src/commands/portal/clear-links.ts +13 -7
  121. package/src/commands/portal/create.ts +20 -12
  122. package/src/commands/portal/delete.ts +28 -20
  123. package/src/commands/portal/get.ts +25 -19
  124. package/src/commands/portal/index.ts +22 -10
  125. package/src/commands/portal/list.ts +27 -19
  126. package/src/commands/portal/update.ts +38 -26
  127. package/src/commands/whatsapp/broadcast.ts +28 -18
  128. package/src/commands/whatsapp/channels.ts +31 -20
  129. package/src/commands/whatsapp/chat.ts +20 -12
  130. package/src/commands/whatsapp/connect.ts +39 -31
  131. package/src/commands/whatsapp/delete-webhook.ts +15 -9
  132. package/src/commands/whatsapp/index.ts +24 -10
  133. package/src/commands/whatsapp/register-webhook.ts +16 -10
  134. package/src/commands/whatsapp/send-template.ts +33 -21
  135. package/src/commands/whatsapp/send.ts +23 -15
  136. package/src/commands/whatsapp/widget.ts +25 -17
  137. package/src/commands/workers/deploy.ts +34 -22
  138. package/src/commands/workers/index.ts +21 -7
  139. package/src/commands/workers/list.ts +31 -19
  140. package/src/commands/workers/logs.ts +30 -20
  141. package/src/commands/workers/remove.ts +30 -22
  142. package/src/commands/workers/secret.ts +46 -34
  143. package/src/commands/workers/test.ts +34 -22
  144. package/src/schemas/agent.config.schema.json +569 -0
  145. package/src/studio/api/sseClient.ts +91 -0
  146. package/src/studio/api/studioApi.ts +27 -0
  147. package/src/studio/api/types.ts +96 -0
  148. package/src/studio/components/App.tsx +266 -0
  149. package/src/studio/components/ChatLog.tsx +95 -0
  150. package/src/studio/components/Footer.tsx +38 -0
  151. package/src/studio/components/Header.tsx +39 -0
  152. package/src/studio/components/Input.tsx +32 -0
  153. package/src/studio/components/Message.tsx +87 -0
  154. package/src/studio/components/Suggestions.tsx +26 -0
  155. package/src/studio/components/ToolCall.tsx +58 -0
  156. package/src/studio/components/WhatsappConnectCard.tsx +139 -0
  157. package/src/studio/index.ts +58 -0
  158. package/src/studio/render/markdown.ts +93 -0
  159. package/src/studio/render/steps.ts +57 -0
  160. package/src/studio/runOneShot.ts +114 -0
  161. package/src/studio/runRepl.tsx +76 -0
  162. package/src/studio/slash/handlers.ts +226 -0
  163. package/src/studio/slash/parser.ts +41 -0
  164. package/src/studio/slash/registry.ts +54 -0
  165. package/src/studio/state/store.ts +273 -0
  166. package/src/studio/whatsapp/api.ts +96 -0
  167. package/src/studio/whatsapp/polling.ts +93 -0
  168. package/src/studio/whatsapp/types.ts +80 -0
  169. package/src/types/agent.ts +1 -1
  170. package/src/types/auth.ts +4 -3
  171. package/src/types/portal.ts +1 -1
  172. package/src/types/workers.ts +1 -1
  173. package/src/utils/agent-errors.ts +67 -0
  174. package/src/utils/api.ts +6 -0
  175. package/src/utils/banner.ts +14 -9
  176. package/src/utils/credentials.ts +6 -5
  177. package/src/utils/help.ts +51 -0
  178. package/tsconfig.json +9 -6
@@ -1,17 +1,19 @@
1
1
  import { Command } from 'commander';
2
2
  import { Agent } from 'plazbot';
3
- import { getStoredCredentials } from '../../utils/credentials';
4
- import { logger } from '../../utils/logger';
5
- import { AgentCommandOptions } from '../../types/agent';
3
+ import { getStoredCredentials } from '../../utils/credentials.js';
4
+ import { logger } from '../../utils/logger.js';
5
+ import { addExamples } from '../../utils/help.js';
6
+ import { describeAgentLoadError } from '../../utils/agent-errors.js';
7
+ import { AgentCommandOptions } from '../../types/agent.js';
6
8
  import chalk from 'chalk';
7
9
 
8
10
  export const getCommand = new Command('get')
9
- .description('Obtiene información detallada de un agente específico')
10
- .argument('<agentId>', 'ID del agente a consultar')
11
- .option('-w, --workspace <id>', 'Workspace ID (sobreescribe config local)')
12
- .option('-z, --zone <zone>', 'Zona LA o EU (sobreescribe config local)')
13
- .option('--raw', 'Mostrar el JSON completo sin formatear', false)
14
- .option('--dev', 'Usar ambiente de desarrollo', false)
11
+ .description('Get detailed information about a specific agent')
12
+ .argument('<agentId>', 'Agent ID to fetch')
13
+ .option('-w, --workspace <id>', 'Workspace ID (overrides local config)')
14
+ .option('-z, --zone <zone>', 'Zone LA or EU (overrides local config)')
15
+ .option('--raw', 'Show full unformatted JSON', false)
16
+ .option('--dev', 'Use development environment', false)
15
17
  .action(async (agentId: string, options: AgentCommandOptions & { raw: boolean; workspace?: string; zone?: string }) => {
16
18
  try {
17
19
  const credentials = await getStoredCredentials();
@@ -20,7 +22,7 @@ export const getCommand = new Command('get')
20
22
  const effectiveZone = (options.zone?.toUpperCase() === 'EU' ? 'EU' : options.zone?.toUpperCase() === 'LA' ? 'LA' : credentials.zone) as 'LA' | 'EU';
21
23
 
22
24
  if (options.workspace || options.zone) {
23
- console.log(chalk.hex('#FFA726')(`\n Modo soporte: workspace=${effectiveWorkspace} zona=${effectiveZone}`));
25
+ console.log(chalk.hex('#FFA726')(`\n Support mode: workspace=${effectiveWorkspace} zone=${effectiveZone}`));
24
26
  }
25
27
 
26
28
  const agent = new Agent({
@@ -53,23 +55,23 @@ export const getCommand = new Command('get')
53
55
 
54
56
  console.log();
55
57
  console.log(chalk.hex('#4CAF50')(' ┌' + '─'.repeat(58) + '┐'));
56
- console.log(chalk.hex('#4CAF50')(' │') + chalk.bold(` ${agentData.name || 'Agente'}`).padEnd(68) + chalk.hex('#4CAF50')('│'));
58
+ console.log(chalk.hex('#4CAF50')(' │') + chalk.bold(` ${agentData.name || 'Agent'}`).padEnd(68) + chalk.hex('#4CAF50')('│'));
57
59
  console.log(chalk.hex('#4CAF50')(' │') + chalk.gray(` ${agentId}`).padEnd(68) + chalk.hex('#4CAF50')('│'));
58
60
  console.log(chalk.hex('#4CAF50')(' └' + '─'.repeat(58) + '┘'));
59
61
 
60
62
  // Informacion basica
61
- sectionHeader('Informacion Basica');
63
+ sectionHeader('Basic Information');
62
64
  label('ID', agentData.id);
63
- label('Nombre', agentData.name);
64
- label('Descripcion', agentData.description);
65
- label('Estado', agentData.enable ? chalk.hex('#66BB6A')('Activo') : chalk.hex('#EF5350')('Inactivo'));
66
- label('Zona', agentData.zone);
65
+ label('Name', agentData.name);
66
+ label('Description', agentData.description);
67
+ label('Status', agentData.enable ? chalk.hex('#66BB6A')('Active') : chalk.hex('#EF5350')('Inactive'));
68
+ label('Zone', agentData.zone);
67
69
  label('Buffer', agentData.buffer);
68
70
  label('Color', agentData.color);
69
- label('Pregunta inicial', agentData.question);
70
- label('Zona horaria', agentData.timezone);
71
- label('Mostrar en chat', agentData.showInChat ? 'Si' : 'No');
72
- label('Tool Calling', agentData.useToolCalling ? 'Activado' : 'Desactivado');
71
+ label('Initial question', agentData.question);
72
+ label('Timezone', agentData.timezone);
73
+ label('Show in chat', agentData.showInChat ? 'Yes' : 'No');
74
+ label('Tool Calling', agentData.useToolCalling ? 'Enabled' : 'Disabled');
73
75
 
74
76
  // Tags
75
77
  if (agentData.tags && agentData.tags.length > 0) {
@@ -87,7 +89,7 @@ export const getCommand = new Command('get')
87
89
 
88
90
  // Ejemplos
89
91
  if (agentData.examples && agentData.examples.length > 0) {
90
- sectionHeader('Ejemplos');
92
+ sectionHeader('Examples');
91
93
  agentData.examples.forEach((example: any) => {
92
94
  console.log(chalk.white(` - ${example.value || example}`));
93
95
  });
@@ -95,64 +97,64 @@ export const getCommand = new Command('get')
95
97
 
96
98
  // Instrucciones
97
99
  if (agentData.instructions) {
98
- sectionHeader('Instrucciones');
100
+ sectionHeader('Instructions');
99
101
  const inst = agentData.instructions;
100
- label('Tono', inst.tone);
101
- label('Estilo', inst.style);
102
- label('Personalidad', inst.personality);
103
- label('Objetivo', inst.objective);
104
- label('Idioma', inst.language);
105
- label('Emojis', inst.emojis ? 'Si' : 'No');
106
- label('Formato preferido', inst.preferredFormat);
107
- label('Max palabras', inst.maxWords);
102
+ label('Tone', inst.tone);
103
+ label('Style', inst.style);
104
+ label('Personality', inst.personality);
105
+ label('Objective', inst.objective);
106
+ label('Language', inst.language);
107
+ label('Emojis', inst.emojis ? 'Yes' : 'No');
108
+ label('Preferred format', inst.preferredFormat);
109
+ label('Max words', inst.maxWords);
108
110
  if (inst.avoidTopics && inst.avoidTopics.length > 0) {
109
- label('Temas a evitar', inst.avoidTopics.join(', '));
111
+ label('Topics to avoid', inst.avoidTopics.join(', '));
110
112
  }
111
- label('Solo responder si sabe', inst.respondOnlyIfKnows ? 'Si' : 'No');
112
- label('Saludo', inst.greeting);
113
+ label('Only respond if known', inst.respondOnlyIfKnows ? 'Yes' : 'No');
114
+ label('Greeting', inst.greeting);
113
115
  }
114
116
 
115
117
  // Persona
116
118
  if (agentData.person) {
117
119
  sectionHeader('Persona');
118
120
  const p = agentData.person;
119
- label('Nombre', p.name);
120
- label('Rol', p.role);
121
- label('Primera persona', p.speaksInFirstPerson ? 'Si' : 'No');
122
- label('Es humano', p.isHuman ? 'Si' : 'No');
121
+ label('Name', p.name);
122
+ label('Role', p.role);
123
+ label('First person', p.speaksInFirstPerson ? 'Yes' : 'No');
124
+ label('Is human', p.isHuman ? 'Yes' : 'No');
123
125
  }
124
126
 
125
127
  // Fallbacks
126
128
  if (agentData.fallbacks) {
127
129
  sectionHeader('Fallbacks');
128
130
  const fb = agentData.fallbacks;
129
- label('Sin respuesta', fb.noAnswer);
130
- label('Error de servicio', fb.serviceError);
131
- label('No entiende', fb.doNotUnderstand);
131
+ label('No answer', fb.noAnswer);
132
+ label('Service error', fb.serviceError);
133
+ label('Does not understand', fb.doNotUnderstand);
132
134
  }
133
135
 
134
136
  // Reglas
135
137
  if (agentData.rules) {
136
- sectionHeader('Reglas');
138
+ sectionHeader('Rules');
137
139
  const r = agentData.rules;
138
- label('No mencionar precios', r.doNotMentionPrices ? 'Si' : 'No');
139
- label('No diagnosticar', r.doNotDiagnose ? 'Si' : 'No');
140
+ label('Do not mention prices', r.doNotMentionPrices ? 'Yes' : 'No');
141
+ label('Do not diagnose', r.doNotDiagnose ? 'Yes' : 'No');
140
142
  if (r.doNotRespondOutsideHours) {
141
- label('Fuera de horario', r.doNotRespondOutsideHours);
143
+ label('Out of hours', r.doNotRespondOutsideHours);
142
144
  }
143
145
  }
144
146
 
145
147
  // Servicios
146
148
  if (agentData.services && agentData.services.length > 0) {
147
- sectionHeader(`Servicios (${agentData.services.length})`);
149
+ sectionHeader(`Services (${agentData.services.length})`);
148
150
  agentData.services.forEach((svc: any, i: number) => {
149
- console.log(chalk.hex('#2196F3')(` ${i + 1}. ${svc.intent || svc.reference || 'Servicio'}`));
150
- label(' Referencia', svc.reference);
151
- label(' Habilitado', svc.enabled ? 'Si' : 'No');
152
- label(' Metodo', svc.method);
151
+ console.log(chalk.hex('#2196F3')(` ${i + 1}. ${svc.intent || svc.reference || 'Service'}`));
152
+ label(' Reference', svc.reference);
153
+ label(' Enabled', svc.enabled ? 'Yes' : 'No');
154
+ label(' Method', svc.method);
153
155
  label(' Endpoint', svc.endpoint);
154
156
  if (svc.requiredFields && svc.requiredFields.length > 0) {
155
- console.log(chalk.gray(' Campos:'));
157
+ console.log(chalk.gray(' Fields:'));
156
158
  svc.requiredFields.forEach((f: any) => {
157
159
  console.log(chalk.white(` - ${f.name} (${f.type}): ${f.description || ''}`));
158
160
  });
@@ -162,17 +164,17 @@ export const getCommand = new Command('get')
162
164
 
163
165
  // Acciones
164
166
  if (agentData.actions && agentData.actions.length > 0) {
165
- sectionHeader(`Acciones (${agentData.actions.length})`);
167
+ sectionHeader(`Actions (${agentData.actions.length})`);
166
168
  agentData.actions.forEach((act: any, i: number) => {
167
- console.log(chalk.hex('#FFA726')(` ${i + 1}. ${act.intent || act.reference || 'Accion'}`));
168
- label(' Referencia', act.reference);
169
- label(' Habilitado', act.enabled ? 'Si' : 'No');
169
+ console.log(chalk.hex('#FFA726')(` ${i + 1}. ${act.intent || act.reference || 'Action'}`));
170
+ label(' Reference', act.reference);
171
+ label(' Enabled', act.enabled ? 'Yes' : 'No');
170
172
  if (act.tags && act.tags.length > 0) {
171
173
  label(' Tags', act.tags.join(', '));
172
174
  }
173
- label(' Respuesta', act.responseMessage);
175
+ label(' Response', act.responseMessage);
174
176
  if (act.action && act.action.length > 0) {
175
- console.log(chalk.gray(' Sub-acciones:'));
177
+ console.log(chalk.gray(' Sub-actions:'));
176
178
  act.action.forEach((sa: any) => {
177
179
  console.log(chalk.white(` - ${sa.type}: ${sa.value || ''}`));
178
180
  });
@@ -182,32 +184,50 @@ export const getCommand = new Command('get')
182
184
 
183
185
  // Canales
184
186
  if (agentData.channels && agentData.channels.length > 0) {
185
- sectionHeader(`Canales (${agentData.channels.length})`);
187
+ sectionHeader(`Channels (${agentData.channels.length})`);
186
188
  agentData.channels.forEach((ch: any) => {
187
- console.log(chalk.white(` ${chalk.hex('#22d3ee')(ch.channel || 'canal')}: ${ch.key || ''}`));
189
+ console.log(chalk.white(` ${chalk.hex('#22d3ee')(ch.channel || 'channel')}: ${ch.key || ''}`));
188
190
  });
189
191
  }
190
192
 
191
193
  // AI Config
192
194
  if (agentData.customAIConfig && agentData.aiProviders && agentData.aiProviders.length > 0) {
193
- sectionHeader('Modelo IA');
195
+ sectionHeader('AI Model');
194
196
  agentData.aiProviders.forEach((ai: any) => {
195
- label('Proveedor', ai.provider);
196
- label('Modelo', ai.model);
197
+ label('Provider', ai.provider);
198
+ label('Model', ai.model);
197
199
  });
198
200
  }
199
201
 
200
202
  console.log();
201
- console.log(chalk.gray(' Usa --raw para ver el JSON completo'));
203
+ console.log(chalk.gray(' Use --raw to see the full JSON'));
202
204
  console.log();
203
205
 
204
206
  if (options.dev) {
205
- logger.warning('Ambiente: desarrollo');
207
+ logger.warning('Environment: development');
206
208
  }
207
209
 
208
210
  } catch (error) {
209
- const message = error instanceof Error ? error.message : 'Error desconocido al obtener el agente';
210
- logger.error(message);
211
+ const credentials = await getStoredCredentials().catch(() => null);
212
+ if (credentials) {
213
+ logger.error(describeAgentLoadError(error, agentId, credentials, {
214
+ dev: options.dev,
215
+ workspaceOverride: options.workspace,
216
+ zoneOverride: options.zone,
217
+ }));
218
+ } else {
219
+ const message = error instanceof Error ? error.message : 'Unknown error while fetching the agent';
220
+ logger.error(message);
221
+ }
211
222
  process.exit(1);
212
223
  }
213
- });
224
+ });
225
+
226
+ addExamples(getCommand, [
227
+ { description: 'Show the agent in a human-friendly layout',
228
+ command: 'plazbot agent get agt_AbcDef123' },
229
+ { description: 'Dump the full raw JSON (useful for piping to jq)',
230
+ command: 'plazbot agent get agt_AbcDef123 --raw' },
231
+ { description: 'Inspect an agent from another workspace (support mode)',
232
+ command: 'plazbot agent get agt_AbcDef123 -w wok_Other123 -z LA' },
233
+ ]);
@@ -1,23 +1,25 @@
1
1
  import { Command } from 'commander';
2
- import { listCommand } from './list';
3
- import { getCommand } from './get';
4
- import { deleteCommand } from './delete';
5
- import { createCommand } from './create';
6
- import { updateCommand } from './update';
7
- import { enableCommand } from './enable-widget';
8
- import { chatCommand } from './chat';
9
- import { messageCommand } from './on-message';
10
- import { toolsCommand } from './tools';
11
- import { aiConfigCommand } from './ai-config';
12
- import { templatesCommand } from './templates';
13
- import { copyCommand } from './copy';
14
- import { filesCommand } from './files';
15
- import { setCommand } from './set';
16
- import { monitorCommand } from './monitor';
17
- import { exportCommand, crossCopyCommand } from './export';
2
+ import { addExamples } from '../../utils/help.js';
3
+ import { listCommand } from './list.js';
4
+ import { getCommand } from './get.js';
5
+ import { deleteCommand } from './delete.js';
6
+ import { createCommand } from './create.js';
7
+ import { updateCommand } from './update.js';
8
+ import { enableCommand } from './enable-widget.js';
9
+ import { chatCommand } from './chat.js';
10
+ import { messageCommand } from './on-message.js';
11
+ import { toolsCommand } from './tools.js';
12
+ import { aiConfigCommand } from './ai-config.js';
13
+ import { templatesCommand } from './templates.js';
14
+ import { copyCommand } from './copy.js';
15
+ import { filesCommand } from './files.js';
16
+ import { setCommand } from './set.js';
17
+ import { monitorCommand } from './monitor.js';
18
+ import { exportCommand, crossCopyCommand } from './export.js';
19
+ import { validateCommand } from './validate.js';
18
20
 
19
21
  export const agentCommands = new Command('agent')
20
- .description('Comandos relacionados con agentes de IA')
22
+ .description('Commands related to AI agents')
21
23
  .addCommand(listCommand)
22
24
  .addCommand(getCommand)
23
25
  .addCommand(deleteCommand)
@@ -34,4 +36,20 @@ export const agentCommands = new Command('agent')
34
36
  .addCommand(setCommand)
35
37
  .addCommand(monitorCommand)
36
38
  .addCommand(exportCommand)
37
- .addCommand(crossCopyCommand);
39
+ .addCommand(crossCopyCommand)
40
+ .addCommand(validateCommand);
41
+
42
+ addExamples(agentCommands, [
43
+ { description: 'List agents in the active workspace',
44
+ command: 'plazbot agent list' },
45
+ { description: 'Chat interactively with an agent',
46
+ command: 'plazbot agent chat agt_AbcDef123' },
47
+ { description: 'Create an agent from a JSON template',
48
+ command: 'plazbot agent create ./agent.json' },
49
+ { description: 'Export an agent and copy it to another workspace',
50
+ command: 'plazbot agent cross-copy agt_AbcDef123 --from-workspace wok_Source --to-workspace wok_Target' },
51
+ { description: 'Monitor activity of an agent in real time',
52
+ command: 'plazbot agent monitor agt_AbcDef123' },
53
+ { description: 'Validate a local agent JSON file against the schema',
54
+ command: 'plazbot agent validate ./agent.json' },
55
+ ]);
@@ -1,12 +1,13 @@
1
1
  import { Command } from 'commander';
2
2
  import { Agent } from 'plazbot';
3
- import { getStoredCredentials } from '../../utils/credentials';
4
- import { logger } from '../../utils/logger';
5
- import { ListAgentsOptions } from '../../types/agent';
3
+ import { getStoredCredentials } from '../../utils/credentials.js';
4
+ import { logger } from '../../utils/logger.js';
5
+ import { addExamples } from '../../utils/help.js';
6
+ import { ListAgentsOptions } from '../../types/agent.js';
6
7
 
7
8
  export const listCommand = new Command('list')
8
- .description('Lista todos los agentes del workspace')
9
- .option('--dev', 'Usar ambiente de desarrollo', false)
9
+ .description('List all agents in the workspace')
10
+ .option('--dev', 'Use development environment (localhost:5090)', false)
10
11
  .action(async (options: ListAgentsOptions) => {
11
12
  try {
12
13
  // Obtener credenciales guardadas
@@ -24,29 +25,34 @@ export const listCommand = new Command('list')
24
25
  const agents = await agent.getAgents();
25
26
 
26
27
  if (agents.length === 0) {
27
- logger.info('No se encontraron agentes en este workspace');
28
+ logger.info('No agents found in this workspace');
28
29
  return;
29
30
  }
30
31
 
31
- logger.info('\nLista de Agentes:');
32
+ logger.info('\nAgents:');
32
33
  logger.doubleDivider();
33
-
34
+
34
35
  agents.forEach((a: any, index: number) => {
35
36
  logger.info(`${index + 1}. ID: ${a.id}`);
36
- logger.info(` Nombre: ${a.name}`);
37
- logger.info(` Estado: ${a.enable ? 'Activo' : 'Inactivo'}`);
38
- logger.info(` Descripción: ${a.description}`);
39
- logger.info(` Creado: ${a.createdAt ? new Date(a.createdAt).toLocaleString() : 'N/A'}`);
37
+ logger.info(` Name: ${a.name}`);
38
+ logger.info(` Status: ${a.enable ? 'Active' : 'Inactive'}`);
39
+ logger.info(` Description: ${a.description}`);
40
+ logger.info(` Created: ${a.createdAt ? new Date(a.createdAt).toLocaleString() : 'N/A'}`);
40
41
  logger.divider();
41
42
  });
42
43
 
43
44
  if (options.dev) {
44
- logger.warning('Ambiente: desarrollo');
45
+ logger.warning('Environment: development');
45
46
  }
46
-
47
+
47
48
  } catch (error) {
48
- const message = error instanceof Error ? error.message : 'Error desconocido al listar agentes';
49
+ const message = error instanceof Error ? error.message : 'Unknown error while listing agents';
49
50
  logger.error(message);
50
51
  process.exit(1);
51
52
  }
52
- });
53
+ });
54
+
55
+ addExamples(listCommand, [
56
+ { description: 'List every agent in the active workspace', command: 'plazbot agent list' },
57
+ { description: 'List against a local backend (dev mode)', command: 'plazbot agent list --dev' },
58
+ ]);