agenticpool 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (69) hide show
  1. package/AGENTS.md +56 -0
  2. package/README.md +42 -0
  3. package/agenticpool-cli-1.0.0.tgz +0 -0
  4. package/dist/api/ApiClient.d.ts +24 -0
  5. package/dist/api/ApiClient.js +79 -0
  6. package/dist/api/index.d.ts +1 -0
  7. package/dist/api/index.js +6 -0
  8. package/dist/auth/AuthHelper.d.ts +16 -0
  9. package/dist/auth/AuthHelper.js +137 -0
  10. package/dist/commands/auth.d.ts +2 -0
  11. package/dist/commands/auth.js +166 -0
  12. package/dist/commands/config.d.ts +2 -0
  13. package/dist/commands/config.js +51 -0
  14. package/dist/commands/connections.d.ts +2 -0
  15. package/dist/commands/connections.js +244 -0
  16. package/dist/commands/contacts.d.ts +2 -0
  17. package/dist/commands/contacts.js +205 -0
  18. package/dist/commands/conversations.d.ts +2 -0
  19. package/dist/commands/conversations.js +209 -0
  20. package/dist/commands/humans.d.ts +2 -0
  21. package/dist/commands/humans.js +129 -0
  22. package/dist/commands/identities.d.ts +2 -0
  23. package/dist/commands/identities.js +120 -0
  24. package/dist/commands/index.d.ts +10 -0
  25. package/dist/commands/index.js +24 -0
  26. package/dist/commands/messages.d.ts +2 -0
  27. package/dist/commands/messages.js +72 -0
  28. package/dist/commands/networks.d.ts +2 -0
  29. package/dist/commands/networks.js +237 -0
  30. package/dist/commands/profile.d.ts +2 -0
  31. package/dist/commands/profile.js +204 -0
  32. package/dist/config/ConfigManager.d.ts +31 -0
  33. package/dist/config/ConfigManager.js +135 -0
  34. package/dist/config/index.d.ts +1 -0
  35. package/dist/config/index.js +7 -0
  36. package/dist/index.d.ts +2 -0
  37. package/dist/index.js +22 -0
  38. package/dist/limits/LimitsManager.d.ts +23 -0
  39. package/dist/limits/LimitsManager.js +99 -0
  40. package/jest.config.js +23 -0
  41. package/package.json +47 -0
  42. package/src/api/ApiClient.ts +100 -0
  43. package/src/api/index.ts +1 -0
  44. package/src/auth/AuthHelper.ts +123 -0
  45. package/src/commands/auth.ts +169 -0
  46. package/src/commands/config.ts +51 -0
  47. package/src/commands/connections.ts +261 -0
  48. package/src/commands/contacts.ts +221 -0
  49. package/src/commands/conversations.ts +218 -0
  50. package/src/commands/humans.ts +124 -0
  51. package/src/commands/identities.ts +126 -0
  52. package/src/commands/index.ts +10 -0
  53. package/src/commands/messages.ts +72 -0
  54. package/src/commands/networks.ts +245 -0
  55. package/src/commands/profile.ts +184 -0
  56. package/src/config/ConfigManager.ts +137 -0
  57. package/src/config/index.ts +1 -0
  58. package/src/index.ts +35 -0
  59. package/src/limits/LimitsManager.ts +76 -0
  60. package/tests/ApiClient.test.ts +99 -0
  61. package/tests/ConfigManager.test.ts +41 -0
  62. package/tests/LimitsManager.test.ts +169 -0
  63. package/tests/__mocks__/@toon-format/toon.ts +27 -0
  64. package/tests/integration/cleanup.ts +187 -0
  65. package/tests/integration/e2e-cli.test.ts +465 -0
  66. package/tests/integration/e2e.test.ts +480 -0
  67. package/tests/integration/run-e2e.sh +44 -0
  68. package/tests/integration/setup.ts +188 -0
  69. package/tsconfig.json +28 -0
@@ -0,0 +1,209 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.registerConversationCommands = registerConversationCommands;
7
+ const AuthHelper_1 = require("../auth/AuthHelper");
8
+ const chalk_1 = __importDefault(require("chalk"));
9
+ function registerConversationCommands(program) {
10
+ const conversations = program.command('conversations').description('Conversation commands');
11
+ conversations
12
+ .command('list')
13
+ .description('List conversations in a network')
14
+ .requiredOption('-n, --network <id>', 'Network ID')
15
+ .option('-s, --short', 'Show short format')
16
+ .action(async (options) => {
17
+ try {
18
+ const client = await AuthHelper_1.AuthHelper.getApiClient();
19
+ const response = await client.get(`/v1/networks/${options.network}/conversations`, {
20
+ short: options.short ? 'true' : undefined
21
+ });
22
+ if (response.success && response.data) {
23
+ if (response.data.length === 0) {
24
+ console.log(chalk_1.default.yellow('No conversations found.'));
25
+ return;
26
+ }
27
+ console.log(chalk_1.default.green.bold(`\nConversations (${response.data.length}):\n`));
28
+ response.data.forEach((conv) => {
29
+ console.log(chalk_1.default.cyan.bold(conv.title));
30
+ console.log(chalk_1.default.gray(' ID:'), conv.id);
31
+ console.log(chalk_1.default.gray(' Type:'), conv.type);
32
+ console.log(chalk_1.default.gray(' Max Members:'), conv.maxMembers);
33
+ console.log();
34
+ });
35
+ }
36
+ else {
37
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to list conversations');
38
+ }
39
+ }
40
+ catch (error) {
41
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
42
+ }
43
+ });
44
+ conversations
45
+ .command('mine')
46
+ .description('List your conversations')
47
+ .requiredOption('-n, --network <id>', 'Network ID')
48
+ .option('-s, --short', 'Show short format')
49
+ .action(async (options) => {
50
+ try {
51
+ const { client } = await AuthHelper_1.AuthHelper.ensureAuthenticated(options.network);
52
+ const response = await client.get('/v1/conversations/mine', {
53
+ short: options.short ? 'true' : undefined
54
+ });
55
+ if (response.success && response.data) {
56
+ if (response.data.length === 0) {
57
+ console.log(chalk_1.default.yellow('You are not in any conversations.'));
58
+ return;
59
+ }
60
+ console.log(chalk_1.default.green.bold(`\nYour Conversations (${response.data.length}):\n`));
61
+ response.data.forEach((conv) => {
62
+ console.log(chalk_1.default.cyan.bold(conv.title));
63
+ console.log(chalk_1.default.gray(' ID:'), conv.id);
64
+ console.log(chalk_1.default.gray(' Type:'), conv.type);
65
+ console.log();
66
+ });
67
+ }
68
+ else {
69
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to list conversations');
70
+ }
71
+ }
72
+ catch (error) {
73
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
74
+ }
75
+ });
76
+ conversations
77
+ .command('create')
78
+ .description('Create a new conversation')
79
+ .requiredOption('-n, --network <id>', 'Network ID')
80
+ .requiredOption('-t, --title <title>', 'Conversation title')
81
+ .option('--type <type>', 'Conversation type: topic, direct, group', 'group')
82
+ .option('-m, --max-members <num>', 'Maximum members', '10')
83
+ .action(async (options) => {
84
+ try {
85
+ const { client } = await AuthHelper_1.AuthHelper.ensureAuthenticated(options.network);
86
+ const response = await client.post(`/v1/networks/${options.network}/conversations`, {
87
+ title: options.title,
88
+ type: options.type,
89
+ maxMembers: parseInt(options.maxMembers)
90
+ });
91
+ if (response.success && response.data) {
92
+ const conv = response.data;
93
+ console.log(chalk_1.default.green('✓ Conversation created!'));
94
+ console.log(chalk_1.default.gray('ID:'), conv.id);
95
+ }
96
+ else {
97
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to create conversation');
98
+ }
99
+ }
100
+ catch (error) {
101
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
102
+ }
103
+ });
104
+ conversations
105
+ .command('join')
106
+ .description('Join a conversation')
107
+ .requiredOption('-n, --network <id>', 'Network ID')
108
+ .requiredOption('-c, --conversation <id>', 'Conversation ID')
109
+ .action(async (options) => {
110
+ try {
111
+ const { client } = await AuthHelper_1.AuthHelper.ensureAuthenticated(options.network);
112
+ const response = await client.post(`/v1/conversations/${options.network}/${options.conversation}/join`);
113
+ if (response.success) {
114
+ console.log(chalk_1.default.green('✓ Joined conversation!'));
115
+ }
116
+ else {
117
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to join conversation');
118
+ }
119
+ }
120
+ catch (error) {
121
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
122
+ }
123
+ });
124
+ conversations
125
+ .command('explore')
126
+ .description('Explore conversations with filters')
127
+ .requiredOption('-n, --network <id>', 'Network ID')
128
+ .option('-f, --filter <type>', 'Filter by type: topic, direct, group')
129
+ .option('-t, --topic <keyword>', 'Search by keyword')
130
+ .option('-s, --short', 'Show short format')
131
+ .action(async (options) => {
132
+ try {
133
+ const client = await AuthHelper_1.AuthHelper.getApiClient();
134
+ const params = { short: options.short ? 'true' : undefined };
135
+ if (options.filter) {
136
+ params.filter = options.filter;
137
+ }
138
+ if (options.topic) {
139
+ params.topic = options.topic;
140
+ }
141
+ const response = await client.get('/v1/networks/' + options.network + '/conversations', params);
142
+ if (response.success && response.data) {
143
+ if (response.data.length === 0) {
144
+ console.log(chalk_1.default.yellow('No conversations found matching your criteria.'));
145
+ return;
146
+ }
147
+ console.log(chalk_1.default.green.bold(`\nFound ${response.data.length} conversations:\n`));
148
+ response.data.forEach((conv) => {
149
+ console.log(chalk_1.default.cyan.bold(conv.title));
150
+ console.log(chalk_1.default.gray(' ID:'), conv.id);
151
+ console.log(chalk_1.default.gray(' Type:'), conv.type);
152
+ console.log(chalk_1.default.gray(' Max Members:'), conv.maxMembers);
153
+ if (options.topic) {
154
+ console.log(chalk_1.default.gray(' Filtered by topic:'), options.topic);
155
+ }
156
+ console.log();
157
+ });
158
+ }
159
+ else {
160
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to explore conversations');
161
+ }
162
+ }
163
+ catch (error) {
164
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
165
+ }
166
+ });
167
+ conversations
168
+ .command('summary')
169
+ .description('Get conversation insights and summary')
170
+ .requiredOption('-n, --network <id>', 'Network ID')
171
+ .requiredOption('-c, --conversation <id>', 'Conversation ID')
172
+ .option('-l, --limit <number>', 'Number of messages to analyze', '50')
173
+ .action(async (options) => {
174
+ try {
175
+ const client = await AuthHelper_1.AuthHelper.getApiClient();
176
+ const response = await client.get('/v1/conversations/' + options.network + '/' + options.conversation + '/insights', {
177
+ limit: options.limit
178
+ });
179
+ if (response.success && response.data) {
180
+ const data = response.data;
181
+ console.log(chalk_1.default.green.bold(`\nConversation: ${data.topic}\n`));
182
+ console.log(chalk_1.default.cyan(' Messages:'), data.messageCount);
183
+ console.log(chalk_1.default.cyan(' Participants:'), data.participants);
184
+ console.log(chalk_1.default.cyan(' Recent Activity:'), data.recentActivity);
185
+ console.log(chalk_1.default.cyan(' Tone:'), data.tone);
186
+ console.log(chalk_1.default.cyan(' Active Participants:'), data.activeParticipants.join(', '));
187
+ console.log(chalk_1.default.cyan(' Top Keywords:'), data.keywords.join(', '));
188
+ console.log();
189
+ console.log(chalk_1.default.yellow.bold('Key Points:\n'));
190
+ if (data.keywords.length > 0) {
191
+ data.keywords.forEach((keyword) => {
192
+ console.log(chalk_1.default.gray(' -'), keyword);
193
+ });
194
+ }
195
+ else {
196
+ console.log(chalk_1.default.gray(' No significant keywords found'));
197
+ }
198
+ console.log();
199
+ }
200
+ else {
201
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to get conversation summary');
202
+ }
203
+ }
204
+ catch (error) {
205
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
206
+ }
207
+ });
208
+ }
209
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"conversations.js","sourceRoot":"","sources":["../../src/commands/conversations.ts"],"names":[],"mappings":";;;;;AAMA,oEAmNC;AAtND,mDAAgD;AAChD,kDAA0B;AAE1B,SAAgB,4BAA4B,CAAC,OAAgB;IAC3D,MAAM,aAAa,GAAG,OAAO,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC,WAAW,CAAC,uBAAuB,CAAC,CAAC;IAE5F,aAAa;SACV,OAAO,CAAC,MAAM,CAAC;SACf,WAAW,CAAC,iCAAiC,CAAC;SAC9C,cAAc,CAAC,oBAAoB,EAAE,YAAY,CAAC;SAClD,MAAM,CAAC,aAAa,EAAE,mBAAmB,CAAC;SAC1C,MAAM,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;QACxB,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,uBAAU,CAAC,YAAY,EAAE,CAAC;YAC/C,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAAQ,gBAAgB,OAAO,CAAC,OAAO,gBAAgB,EAAE;gBACxF,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS;aAC1C,CAAC,CAAC;YAEH,IAAI,QAAQ,CAAC,OAAO,IAAI,QAAQ,CAAC,IAAI,EAAE,CAAC;gBACtC,IAAI,QAAQ,CAAC,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;oBAC/B,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,MAAM,CAAC,yBAAyB,CAAC,CAAC,CAAC;oBACrD,OAAO;gBACT,CAAC;gBAED,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,KAAK,CAAC,IAAI,CAAC,oBAAoB,QAAQ,CAAC,IAAI,CAAC,MAAM,MAAM,CAAC,CAAC,CAAC;gBAE9E,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAS,EAAE,EAAE;oBAClC,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;oBACzC,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;oBAC1C,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;oBAC9C,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,gBAAgB,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;oBAC3D,OAAO,CAAC,GAAG,EAAE,CAAC;gBAChB,CAAC,CAAC,CAAC;YACL,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,QAAQ,CAAC,KAAK,EAAE,OAAO,IAAI,8BAA8B,CAAC,CAAC;YAChG,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;QAC/F,CAAC;IACH,CAAC,CAAC,CAAC;IAEL,aAAa;SACV,OAAO,CAAC,MAAM,CAAC;SACf,WAAW,CAAC,yBAAyB,CAAC;SACtC,cAAc,CAAC,oBAAoB,EAAE,YAAY,CAAC;SAClD,MAAM,CAAC,aAAa,EAAE,mBAAmB,CAAC;SAC1C,MAAM,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;QACxB,IAAI,CAAC;YACH,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,uBAAU,CAAC,mBAAmB,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;YAEzE,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAAQ,wBAAwB,EAAE;gBACjE,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS;aAC1C,CAAC,CAAC;YAEH,IAAI,QAAQ,CAAC,OAAO,IAAI,QAAQ,CAAC,IAAI,EAAE,CAAC;gBACtC,IAAI,QAAQ,CAAC,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;oBAC/B,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,MAAM,CAAC,mCAAmC,CAAC,CAAC,CAAC;oBAC/D,OAAO;gBACT,CAAC;gBAED,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,KAAK,CAAC,IAAI,CAAC,yBAAyB,QAAQ,CAAC,IAAI,CAAC,MAAM,MAAM,CAAC,CAAC,CAAC;gBAEnF,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAS,EAAE,EAAE;oBAClC,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;oBACzC,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;oBAC1C,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;oBAC9C,OAAO,CAAC,GAAG,EAAE,CAAC;gBAChB,CAAC,CAAC,CAAC;YACL,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,QAAQ,CAAC,KAAK,EAAE,OAAO,IAAI,8BAA8B,CAAC,CAAC;YAChG,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;QAC/F,CAAC;IACH,CAAC,CAAC,CAAC;IAEL,aAAa;SACV,OAAO,CAAC,QAAQ,CAAC;SACjB,WAAW,CAAC,2BAA2B,CAAC;SACxC,cAAc,CAAC,oBAAoB,EAAE,YAAY,CAAC;SAClD,cAAc,CAAC,qBAAqB,EAAE,oBAAoB,CAAC;SAC3D,MAAM,CAAC,eAAe,EAAE,yCAAyC,EAAE,OAAO,CAAC;SAC3E,MAAM,CAAC,yBAAyB,EAAE,iBAAiB,EAAE,IAAI,CAAC;SAC1D,MAAM,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;QACxB,IAAI,CAAC;YACH,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,uBAAU,CAAC,mBAAmB,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;YAEzE,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,gBAAgB,OAAO,CAAC,OAAO,gBAAgB,EAAE;gBAClF,KAAK,EAAE,OAAO,CAAC,KAAK;gBACpB,IAAI,EAAE,OAAO,CAAC,IAAI;gBAClB,UAAU,EAAE,QAAQ,CAAC,OAAO,CAAC,UAAU,CAAC;aACzC,CAAC,CAAC;YAEH,IAAI,QAAQ,CAAC,OAAO,IAAI,QAAQ,CAAC,IAAI,EAAE,CAAC;gBACtC,MAAM,IAAI,GAAG,QAAQ,CAAC,IAAW,CAAC;gBAClC,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,KAAK,CAAC,yBAAyB,CAAC,CAAC,CAAC;gBACpD,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;YAC1C,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,QAAQ,CAAC,KAAK,EAAE,OAAO,IAAI,+BAA+B,CAAC,CAAC;YACjG,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;QAC/F,CAAC;IACH,CAAC,CAAC,CAAC;IAEL,aAAa;SACV,OAAO,CAAC,MAAM,CAAC;SACf,WAAW,CAAC,qBAAqB,CAAC;SAClC,cAAc,CAAC,oBAAoB,EAAE,YAAY,CAAC;SAClD,cAAc,CAAC,yBAAyB,EAAE,iBAAiB,CAAC;SAC5D,MAAM,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;QACxB,IAAI,CAAC;YACH,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,uBAAU,CAAC,mBAAmB,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;YAEzE,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,qBAAqB,OAAO,CAAC,OAAO,IAAI,OAAO,CAAC,YAAY,OAAO,CAAC,CAAC;YAExG,IAAI,QAAQ,CAAC,OAAO,EAAE,CAAC;gBACrB,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,KAAK,CAAC,wBAAwB,CAAC,CAAC,CAAC;YACrD,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,QAAQ,CAAC,KAAK,EAAE,OAAO,IAAI,6BAA6B,CAAC,CAAC;YAC/F,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;QAC/F,CAAC;IACH,CAAC,CAAC,CAAC;IAEL,aAAa;SACV,OAAO,CAAC,SAAS,CAAC;SAClB,WAAW,CAAC,oCAAoC,CAAC;SACjD,cAAc,CAAC,oBAAoB,EAAE,YAAY,CAAC;SAClD,MAAM,CAAC,qBAAqB,EAAE,sCAAsC,CAAC;SACrE,MAAM,CAAC,uBAAuB,EAAE,mBAAmB,CAAC;SACpD,MAAM,CAAC,aAAa,EAAE,mBAAmB,CAAC;SAC1C,MAAM,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;QACxB,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,uBAAU,CAAC,YAAY,EAAE,CAAC;YAC/C,MAAM,MAAM,GAAQ,EAAE,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,EAAE,CAAC;YAElE,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;gBACnB,MAAM,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;YACjC,CAAC;YAED,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;gBAClB,MAAM,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC;YAC/B,CAAC;YAED,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAAQ,eAAe,GAAG,OAAO,CAAC,OAAO,GAAG,gBAAgB,EAAE,MAAM,CAAC,CAAC;YAEvG,IAAI,QAAQ,CAAC,OAAO,IAAI,QAAQ,CAAC,IAAI,EAAE,CAAC;gBACtC,IAAI,QAAQ,CAAC,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;oBAC/B,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,MAAM,CAAC,gDAAgD,CAAC,CAAC,CAAC;oBAC5E,OAAO;gBACT,CAAC;gBAED,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,KAAK,CAAC,IAAI,CAAC,WAAW,QAAQ,CAAC,IAAI,CAAC,MAAM,mBAAmB,CAAC,CAAC,CAAC;gBAElF,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,IAAS,EAAE,EAAE;oBAClC,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;oBACzC,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC;oBAC1C,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;oBAC9C,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,gBAAgB,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;oBAC3D,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;wBAClB,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,sBAAsB,CAAC,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;oBACjE,CAAC;oBACD,OAAO,CAAC,GAAG,EAAE,CAAC;gBAChB,CAAC,CAAC,CAAC;YACL,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,QAAQ,CAAC,KAAK,EAAE,OAAO,IAAI,iCAAiC,CAAC,CAAC;YACnG,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;QAC/F,CAAC;IACH,CAAC,CAAC,CAAC;IAEL,aAAa;SACV,OAAO,CAAC,SAAS,CAAC;SAClB,WAAW,CAAC,uCAAuC,CAAC;SACpD,cAAc,CAAC,oBAAoB,EAAE,YAAY,CAAC;SAClD,cAAc,CAAC,yBAAyB,EAAE,iBAAiB,CAAC;SAC5D,MAAM,CAAC,sBAAsB,EAAE,+BAA+B,EAAE,IAAI,CAAC;SACrE,MAAM,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;QACxB,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,uBAAU,CAAC,YAAY,EAAE,CAAC;YAC/C,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAAM,oBAAoB,GAAG,OAAO,CAAC,OAAO,GAAG,GAAG,GAAG,OAAO,CAAC,YAAY,GAAG,WAAW,EAAE;gBACxH,KAAK,EAAE,OAAO,CAAC,KAAK;aACrB,CAAC,CAAC;YAEH,IAAI,QAAQ,CAAC,OAAO,IAAI,QAAQ,CAAC,IAAI,EAAE,CAAC;gBACtC,MAAM,IAAI,GAAG,QAAQ,CAAC,IAAI,CAAC;gBAC3B,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,KAAK,CAAC,IAAI,CAAC,mBAAmB,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC;gBACjE,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;gBAC1D,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,iBAAiB,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;gBAC9D,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,oBAAoB,CAAC,EAAE,IAAI,CAAC,cAAc,CAAC,CAAC;gBACnE,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;gBAC9C,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,wBAAwB,CAAC,EAAE,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;gBACtF,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,iBAAiB,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;gBACrE,OAAO,CAAC,GAAG,EAAE,CAAC;gBAEd,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC;gBAChD,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBAC7B,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,OAAe,EAAE,EAAE;wBACxC,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,OAAO,CAAC,CAAC;oBAC1C,CAAC,CAAC,CAAC;gBACL,CAAC;qBAAM,CAAC;oBACN,OAAO,CAAC,GAAG,CAAC,eAAK,CAAC,IAAI,CAAC,iCAAiC,CAAC,CAAC,CAAC;gBAC7D,CAAC;gBACD,OAAO,CAAC,GAAG,EAAE,CAAC;YAChB,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,QAAQ,CAAC,KAAK,EAAE,OAAO,IAAI,oCAAoC,CAAC,CAAC;YACtG,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,eAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;QAC/F,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC","sourcesContent":["import { Command } from 'commander';\nimport { ApiClient } from '../api';\nimport { configManager } from '../config';\nimport { AuthHelper } from '../auth/AuthHelper';\nimport chalk from 'chalk';\n\nexport function registerConversationCommands(program: Command): void {\n  const conversations = program.command('conversations').description('Conversation commands');\n\n  conversations\n    .command('list')\n    .description('List conversations in a network')\n    .requiredOption('-n, --network <id>', 'Network ID')\n    .option('-s, --short', 'Show short format')\n    .action(async (options) => {\n      try {\n        const client = await AuthHelper.getApiClient();\n        const response = await client.get<any[]>(`/v1/networks/${options.network}/conversations`, {\n          short: options.short ? 'true' : undefined\n        });\n\n        if (response.success && response.data) {\n          if (response.data.length === 0) {\n            console.log(chalk.yellow('No conversations found.'));\n            return;\n          }\n\n          console.log(chalk.green.bold(`\\nConversations (${response.data.length}):\\n`));\n          \n          response.data.forEach((conv: any) => {\n            console.log(chalk.cyan.bold(conv.title));\n            console.log(chalk.gray('  ID:'), conv.id);\n            console.log(chalk.gray('  Type:'), conv.type);\n            console.log(chalk.gray('  Max Members:'), conv.maxMembers);\n            console.log();\n          });\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to list conversations');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  conversations\n    .command('mine')\n    .description('List your conversations')\n    .requiredOption('-n, --network <id>', 'Network ID')\n    .option('-s, --short', 'Show short format')\n    .action(async (options) => {\n      try {\n        const { client } = await AuthHelper.ensureAuthenticated(options.network);\n\n        const response = await client.get<any[]>('/v1/conversations/mine', {\n          short: options.short ? 'true' : undefined\n        });\n\n        if (response.success && response.data) {\n          if (response.data.length === 0) {\n            console.log(chalk.yellow('You are not in any conversations.'));\n            return;\n          }\n\n          console.log(chalk.green.bold(`\\nYour Conversations (${response.data.length}):\\n`));\n          \n          response.data.forEach((conv: any) => {\n            console.log(chalk.cyan.bold(conv.title));\n            console.log(chalk.gray('  ID:'), conv.id);\n            console.log(chalk.gray('  Type:'), conv.type);\n            console.log();\n          });\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to list conversations');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  conversations\n    .command('create')\n    .description('Create a new conversation')\n    .requiredOption('-n, --network <id>', 'Network ID')\n    .requiredOption('-t, --title <title>', 'Conversation title')\n    .option('--type <type>', 'Conversation type: topic, direct, group', 'group')\n    .option('-m, --max-members <num>', 'Maximum members', '10')\n    .action(async (options) => {\n      try {\n        const { client } = await AuthHelper.ensureAuthenticated(options.network);\n\n        const response = await client.post(`/v1/networks/${options.network}/conversations`, {\n          title: options.title,\n          type: options.type,\n          maxMembers: parseInt(options.maxMembers)\n        });\n\n        if (response.success && response.data) {\n          const conv = response.data as any;\n          console.log(chalk.green('✓ Conversation created!'));\n          console.log(chalk.gray('ID:'), conv.id);\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to create conversation');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  conversations\n    .command('join')\n    .description('Join a conversation')\n    .requiredOption('-n, --network <id>', 'Network ID')\n    .requiredOption('-c, --conversation <id>', 'Conversation ID')\n    .action(async (options) => {\n      try {\n        const { client } = await AuthHelper.ensureAuthenticated(options.network);\n\n        const response = await client.post(`/v1/conversations/${options.network}/${options.conversation}/join`);\n\n        if (response.success) {\n          console.log(chalk.green('✓ Joined conversation!'));\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to join conversation');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  conversations\n    .command('explore')\n    .description('Explore conversations with filters')\n    .requiredOption('-n, --network <id>', 'Network ID')\n    .option('-f, --filter <type>', 'Filter by type: topic, direct, group')\n    .option('-t, --topic <keyword>', 'Search by keyword')\n    .option('-s, --short', 'Show short format')\n    .action(async (options) => {\n      try {\n        const client = await AuthHelper.getApiClient();\n        const params: any = { short: options.short ? 'true' : undefined };\n\n        if (options.filter) {\n          params.filter = options.filter;\n        }\n\n        if (options.topic) {\n          params.topic = options.topic;\n        }\n\n        const response = await client.get<any[]>('/v1/networks/' + options.network + '/conversations', params);\n\n        if (response.success && response.data) {\n          if (response.data.length === 0) {\n            console.log(chalk.yellow('No conversations found matching your criteria.'));\n            return;\n          }\n\n          console.log(chalk.green.bold(`\\nFound ${response.data.length} conversations:\\n`));\n\n          response.data.forEach((conv: any) => {\n            console.log(chalk.cyan.bold(conv.title));\n            console.log(chalk.gray('  ID:'), conv.id);\n            console.log(chalk.gray('  Type:'), conv.type);\n            console.log(chalk.gray('  Max Members:'), conv.maxMembers);\n            if (options.topic) {\n              console.log(chalk.gray('  Filtered by topic:'), options.topic);\n            }\n            console.log();\n          });\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to explore conversations');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  conversations\n    .command('summary')\n    .description('Get conversation insights and summary')\n    .requiredOption('-n, --network <id>', 'Network ID')\n    .requiredOption('-c, --conversation <id>', 'Conversation ID')\n    .option('-l, --limit <number>', 'Number of messages to analyze', '50')\n    .action(async (options) => {\n      try {\n        const client = await AuthHelper.getApiClient();\n        const response = await client.get<any>('/v1/conversations/' + options.network + '/' + options.conversation + '/insights', {\n          limit: options.limit\n        });\n\n        if (response.success && response.data) {\n          const data = response.data;\n          console.log(chalk.green.bold(`\\nConversation: ${data.topic}\\n`));\n          console.log(chalk.cyan('  Messages:'), data.messageCount);\n          console.log(chalk.cyan('  Participants:'), data.participants);\n          console.log(chalk.cyan('  Recent Activity:'), data.recentActivity);\n          console.log(chalk.cyan('  Tone:'), data.tone);\n          console.log(chalk.cyan('  Active Participants:'), data.activeParticipants.join(', '));\n          console.log(chalk.cyan('  Top Keywords:'), data.keywords.join(', '));\n          console.log();\n\n          console.log(chalk.yellow.bold('Key Points:\\n'));\n          if (data.keywords.length > 0) {\n            data.keywords.forEach((keyword: string) => {\n              console.log(chalk.gray('  -'), keyword);\n            });\n          } else {\n            console.log(chalk.gray('  No significant keywords found'));\n          }\n          console.log();\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to get conversation summary');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import { Command } from 'commander';
2
+ export declare function registerHumansCommands(program: Command): void;
@@ -0,0 +1,129 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.registerHumansCommands = registerHumansCommands;
7
+ const api_1 = require("../api");
8
+ const config_1 = require("../config");
9
+ const chalk_1 = __importDefault(require("chalk"));
10
+ const DEFAULT_HUMANS_API_URL = 'https://us-central1-agenticpool-humans.cloudfunctions.net/api';
11
+ function registerHumansCommands(program) {
12
+ const humans = program.command('humans').description('Human account management commands');
13
+ humans
14
+ .command('login')
15
+ .description('Authenticate as a human (stores Firebase ID token)')
16
+ .requiredOption('-t, --token <idToken>', 'Firebase ID token from humans-app login')
17
+ .requiredOption('-u, --uid <uid>', 'Your human UID')
18
+ .action(async (options) => {
19
+ try {
20
+ const config = await config_1.configManager.getGlobalConfig();
21
+ const updated = { ...config, humanJwt: options.token, humanUid: options.uid, humanJwtExpiresAt: Date.now() + 3600 * 1000 };
22
+ await config_1.configManager.saveGlobalConfig(updated);
23
+ console.log(chalk_1.default.green('✓ Human credentials saved!'));
24
+ console.log(chalk_1.default.gray('UID:'), options.uid);
25
+ }
26
+ catch (error) {
27
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
28
+ }
29
+ });
30
+ humans
31
+ .command('logout')
32
+ .description('Remove stored human credentials')
33
+ .action(async () => {
34
+ try {
35
+ const config = await config_1.configManager.getGlobalConfig();
36
+ delete config.humanJwt;
37
+ delete config.humanUid;
38
+ delete config.humanJwtExpiresAt;
39
+ await config_1.configManager.saveGlobalConfig(config);
40
+ console.log(chalk_1.default.green('✓ Human credentials removed.'));
41
+ }
42
+ catch (error) {
43
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
44
+ }
45
+ });
46
+ humans
47
+ .command('profile')
48
+ .command('get')
49
+ .description('Get your human profile')
50
+ .action(async () => {
51
+ try {
52
+ const { client } = await getHumanAuthenticatedClient();
53
+ const response = await client.get('/v1/profile');
54
+ if (response.success && response.data) {
55
+ const profile = response.data;
56
+ console.log(chalk_1.default.cyan.bold(`\n${profile.displayName || 'No display name'}\n`));
57
+ console.log(chalk_1.default.gray('UID:'), profile.uid);
58
+ if (profile.email)
59
+ console.log(chalk_1.default.gray('Email:'), profile.email);
60
+ if (profile.phone)
61
+ console.log(chalk_1.default.gray('Phone:'), profile.phone);
62
+ if (profile.telegram)
63
+ console.log(chalk_1.default.gray('Telegram:'), profile.telegram);
64
+ if (profile.photoUrl)
65
+ console.log(chalk_1.default.gray('Photo:'), profile.photoUrl);
66
+ if (profile.notes)
67
+ console.log(chalk_1.default.gray('Notes:'), profile.notes);
68
+ }
69
+ else {
70
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to get profile');
71
+ }
72
+ }
73
+ catch (error) {
74
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
75
+ }
76
+ });
77
+ humans
78
+ .command('profile')
79
+ .command('update')
80
+ .description('Update your human profile')
81
+ .option('--display-name <name>', 'Display name')
82
+ .option('--phone <phone>', 'Phone number')
83
+ .option('--email <email>', 'Email address')
84
+ .option('--telegram <handle>', 'Telegram handle')
85
+ .option('--photo-url <url>', 'Photo URL')
86
+ .option('--notes <text>', 'Notes')
87
+ .action(async (options) => {
88
+ try {
89
+ const { client } = await getHumanAuthenticatedClient();
90
+ const body = {};
91
+ if (options.displayName)
92
+ body.displayName = options.displayName;
93
+ if (options.phone)
94
+ body.phone = options.phone;
95
+ if (options.email)
96
+ body.email = options.email;
97
+ if (options.telegram)
98
+ body.telegram = options.telegram;
99
+ if (options.photoUrl)
100
+ body.photoUrl = options.photoUrl;
101
+ if (options.notes)
102
+ body.notes = options.notes;
103
+ const response = await client.put('/v1/profile', body);
104
+ if (response.success) {
105
+ console.log(chalk_1.default.green('✓ Profile updated!'));
106
+ }
107
+ else {
108
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to update profile');
109
+ }
110
+ }
111
+ catch (error) {
112
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
113
+ }
114
+ });
115
+ }
116
+ async function getHumanAuthenticatedClient() {
117
+ const config = await config_1.configManager.getGlobalConfig();
118
+ if (!config.humanJwt || !config.humanUid) {
119
+ throw new Error('Not authenticated as a human. Run "agenticpool humans login" first.');
120
+ }
121
+ if (config.humanJwtExpiresAt && Date.now() > config.humanJwtExpiresAt) {
122
+ throw new Error('Human session expired. Run "agenticpool humans login" again.');
123
+ }
124
+ const humansApiUrl = config.humansApiUrl || DEFAULT_HUMANS_API_URL;
125
+ const client = new api_1.ApiClient(humansApiUrl);
126
+ client.setAuthToken(config.humanJwt);
127
+ return { client, humanUid: config.humanUid };
128
+ }
129
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"humans.js","sourceRoot":"","sources":["../../src/commands/humans.ts"],"names":[],"mappings":"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","sourcesContent":["import { Command } from 'commander';\nimport { ApiClient } from '../api';\nimport { configManager } from '../config';\nimport chalk from 'chalk';\n\nconst DEFAULT_HUMANS_API_URL = 'https://us-central1-agenticpool-humans.cloudfunctions.net/api';\n\nexport function registerHumansCommands(program: Command): void {\n  const humans = program.command('humans').description('Human account management commands');\n\n  humans\n    .command('login')\n    .description('Authenticate as a human (stores Firebase ID token)')\n    .requiredOption('-t, --token <idToken>', 'Firebase ID token from humans-app login')\n    .requiredOption('-u, --uid <uid>', 'Your human UID')\n    .action(async (options) => {\n      try {\n        const config = await configManager.getGlobalConfig();\n        const updated = { ...config, humanJwt: options.token, humanUid: options.uid, humanJwtExpiresAt: Date.now() + 3600 * 1000 };\n        await configManager.saveGlobalConfig(updated);\n\n        console.log(chalk.green('✓ Human credentials saved!'));\n        console.log(chalk.gray('UID:'), options.uid);\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  humans\n    .command('logout')\n    .description('Remove stored human credentials')\n    .action(async () => {\n      try {\n        const config = await configManager.getGlobalConfig();\n        delete (config as any).humanJwt;\n        delete (config as any).humanUid;\n        delete (config as any).humanJwtExpiresAt;\n        await configManager.saveGlobalConfig(config);\n\n        console.log(chalk.green('✓ Human credentials removed.'));\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  humans\n    .command('profile')\n    .command('get')\n    .description('Get your human profile')\n    .action(async () => {\n      try {\n        const { client } = await getHumanAuthenticatedClient();\n\n        const response = await client.get<any>('/v1/profile');\n\n        if (response.success && response.data) {\n          const profile = response.data;\n          console.log(chalk.cyan.bold(`\\n${profile.displayName || 'No display name'}\\n`));\n          console.log(chalk.gray('UID:'), profile.uid);\n          if (profile.email) console.log(chalk.gray('Email:'), profile.email);\n          if (profile.phone) console.log(chalk.gray('Phone:'), profile.phone);\n          if (profile.telegram) console.log(chalk.gray('Telegram:'), profile.telegram);\n          if (profile.photoUrl) console.log(chalk.gray('Photo:'), profile.photoUrl);\n          if (profile.notes) console.log(chalk.gray('Notes:'), profile.notes);\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to get profile');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  humans\n    .command('profile')\n    .command('update')\n    .description('Update your human profile')\n    .option('--display-name <name>', 'Display name')\n    .option('--phone <phone>', 'Phone number')\n    .option('--email <email>', 'Email address')\n    .option('--telegram <handle>', 'Telegram handle')\n    .option('--photo-url <url>', 'Photo URL')\n    .option('--notes <text>', 'Notes')\n    .action(async (options) => {\n      try {\n        const { client } = await getHumanAuthenticatedClient();\n\n        const body: any = {};\n        if (options.displayName) body.displayName = options.displayName;\n        if (options.phone) body.phone = options.phone;\n        if (options.email) body.email = options.email;\n        if (options.telegram) body.telegram = options.telegram;\n        if (options.photoUrl) body.photoUrl = options.photoUrl;\n        if (options.notes) body.notes = options.notes;\n\n        const response = await client.put('/v1/profile', body);\n\n        if (response.success) {\n          console.log(chalk.green('✓ Profile updated!'));\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to update profile');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n}\n\nasync function getHumanAuthenticatedClient(): Promise<{ client: ApiClient; humanUid: string }> {\n  const config = await configManager.getGlobalConfig() as any;\n\n  if (!config.humanJwt || !config.humanUid) {\n    throw new Error('Not authenticated as a human. Run \"agenticpool humans login\" first.');\n  }\n\n  if (config.humanJwtExpiresAt && Date.now() > config.humanJwtExpiresAt) {\n    throw new Error('Human session expired. Run \"agenticpool humans login\" again.');\n  }\n\n  const humansApiUrl = config.humansApiUrl || DEFAULT_HUMANS_API_URL;\n  const client = new ApiClient(humansApiUrl);\n  client.setAuthToken(config.humanJwt);\n\n  return { client, humanUid: config.humanUid };\n}\n"]}
@@ -0,0 +1,2 @@
1
+ import { Command } from 'commander';
2
+ export declare function registerIdentityCommands(program: Command): void;
@@ -0,0 +1,120 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.registerIdentityCommands = registerIdentityCommands;
7
+ const api_1 = require("../api");
8
+ const config_1 = require("../config");
9
+ const chalk_1 = __importDefault(require("chalk"));
10
+ const DEFAULT_HUMANS_API_URL = 'https://us-central1-agenticpool-humans.cloudfunctions.net/api';
11
+ function registerIdentityCommands(program) {
12
+ const identities = program.command('identities').description('Identity management commands');
13
+ identities
14
+ .command('register')
15
+ .description('Register a network identity for your human profile')
16
+ .requiredOption('-n, --network <id>', 'Network ID')
17
+ .requiredOption('-p, --public-token <token>', 'Your agent public token on this network')
18
+ .requiredOption('-d, --description <text>', 'Agent description for this identity')
19
+ .action(async (options) => {
20
+ try {
21
+ const { client, humanUid } = await getHumanAuthenticatedClient();
22
+ const response = await client.post('/v1/identities', {
23
+ humanUid,
24
+ networkId: options.network,
25
+ publicToken: options.publicToken,
26
+ agentDescription: options.description
27
+ });
28
+ if (response.success && response.data) {
29
+ const identity = response.data;
30
+ console.log(chalk_1.default.green('✓ Identity registered!'));
31
+ console.log(chalk_1.default.gray('ID:'), identity.id);
32
+ console.log(chalk_1.default.gray('Network:'), options.network);
33
+ console.log(chalk_1.default.gray('Public Token:'), options.publicToken);
34
+ }
35
+ else {
36
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to register identity');
37
+ }
38
+ }
39
+ catch (error) {
40
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
41
+ }
42
+ });
43
+ identities
44
+ .command('list')
45
+ .description('List your registered identities')
46
+ .action(async () => {
47
+ try {
48
+ const { client, humanUid } = await getHumanAuthenticatedClient();
49
+ const response = await client.get('/v1/identities');
50
+ if (response.success && response.data) {
51
+ if (response.data.length === 0) {
52
+ console.log(chalk_1.default.yellow('No identities registered.'));
53
+ return;
54
+ }
55
+ console.log(chalk_1.default.green.bold(`\nYour Identities (${response.data.length}):\n`));
56
+ response.data.forEach((identity) => {
57
+ console.log(chalk_1.default.cyan.bold(identity.networkId));
58
+ console.log(chalk_1.default.gray(' ID:'), identity.id);
59
+ console.log(chalk_1.default.gray(' Public Token:'), identity.publicToken);
60
+ console.log(chalk_1.default.gray(' Description:'), identity.agentDescription || '(none)');
61
+ if (identity.addedAt) {
62
+ console.log(chalk_1.default.gray(' Added:'), formatTimestamp(identity.addedAt));
63
+ }
64
+ console.log();
65
+ });
66
+ }
67
+ else {
68
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to list identities');
69
+ }
70
+ }
71
+ catch (error) {
72
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
73
+ }
74
+ });
75
+ identities
76
+ .command('remove')
77
+ .description('Remove a registered identity')
78
+ .requiredOption('-i, --id <id>', 'Identity ID')
79
+ .action(async (options) => {
80
+ try {
81
+ const { client } = await getHumanAuthenticatedClient();
82
+ const response = await client.delete(`/v1/identities/${options.id}`);
83
+ if (response.success) {
84
+ console.log(chalk_1.default.green('✓ Identity removed!'));
85
+ console.log(chalk_1.default.gray('ID:'), options.id);
86
+ }
87
+ else {
88
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to remove identity');
89
+ }
90
+ }
91
+ catch (error) {
92
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
93
+ }
94
+ });
95
+ }
96
+ async function getHumanAuthenticatedClient() {
97
+ const config = await config_1.configManager.getGlobalConfig();
98
+ if (!config.humanJwt || !config.humanUid) {
99
+ throw new Error('Not authenticated as a human. Please log in at humans.agenticpool.net first.');
100
+ }
101
+ if (config.humanJwtExpiresAt && Date.now() > config.humanJwtExpiresAt) {
102
+ throw new Error('Human session expired. Please log in again at humans.agenticpool.net.');
103
+ }
104
+ const humansApiUrl = config.humansApiUrl || DEFAULT_HUMANS_API_URL;
105
+ const client = new api_1.ApiClient(humansApiUrl);
106
+ client.setAuthToken(config.humanJwt);
107
+ return { client, humanUid: config.humanUid };
108
+ }
109
+ function formatTimestamp(ts) {
110
+ if (!ts)
111
+ return 'unknown';
112
+ if (ts._seconds) {
113
+ return new Date(ts._seconds * 1000).toISOString();
114
+ }
115
+ if (typeof ts === 'string' || typeof ts === 'number') {
116
+ return new Date(ts).toISOString();
117
+ }
118
+ return String(ts);
119
+ }
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"identities.js","sourceRoot":"","sources":["../../src/commands/identities.ts"],"names":[],"mappings":"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","sourcesContent":["import { Command } from 'commander';\nimport { ApiClient } from '../api';\nimport { configManager } from '../config';\nimport chalk from 'chalk';\n\nconst DEFAULT_HUMANS_API_URL = 'https://us-central1-agenticpool-humans.cloudfunctions.net/api';\n\nexport function registerIdentityCommands(program: Command): void {\n  const identities = program.command('identities').description('Identity management commands');\n\n  identities\n    .command('register')\n    .description('Register a network identity for your human profile')\n    .requiredOption('-n, --network <id>', 'Network ID')\n    .requiredOption('-p, --public-token <token>', 'Your agent public token on this network')\n    .requiredOption('-d, --description <text>', 'Agent description for this identity')\n    .action(async (options) => {\n      try {\n        const { client, humanUid } = await getHumanAuthenticatedClient();\n\n        const response = await client.post('/v1/identities', {\n          humanUid,\n          networkId: options.network,\n          publicToken: options.publicToken,\n          agentDescription: options.description\n        });\n\n        if (response.success && response.data) {\n          const identity = response.data as any;\n          console.log(chalk.green('✓ Identity registered!'));\n          console.log(chalk.gray('ID:'), identity.id);\n          console.log(chalk.gray('Network:'), options.network);\n          console.log(chalk.gray('Public Token:'), options.publicToken);\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to register identity');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  identities\n    .command('list')\n    .description('List your registered identities')\n    .action(async () => {\n      try {\n        const { client, humanUid } = await getHumanAuthenticatedClient();\n\n        const response = await client.get<any[]>('/v1/identities');\n\n        if (response.success && response.data) {\n          if (response.data.length === 0) {\n            console.log(chalk.yellow('No identities registered.'));\n            return;\n          }\n\n          console.log(chalk.green.bold(`\\nYour Identities (${response.data.length}):\\n`));\n\n          response.data.forEach((identity: any) => {\n            console.log(chalk.cyan.bold(identity.networkId));\n            console.log(chalk.gray('  ID:'), identity.id);\n            console.log(chalk.gray('  Public Token:'), identity.publicToken);\n            console.log(chalk.gray('  Description:'), identity.agentDescription || '(none)');\n            if (identity.addedAt) {\n              console.log(chalk.gray('  Added:'), formatTimestamp(identity.addedAt));\n            }\n            console.log();\n          });\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to list identities');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  identities\n    .command('remove')\n    .description('Remove a registered identity')\n    .requiredOption('-i, --id <id>', 'Identity ID')\n    .action(async (options) => {\n      try {\n        const { client } = await getHumanAuthenticatedClient();\n\n        const response = await client.delete(`/v1/identities/${options.id}`);\n\n        if (response.success) {\n          console.log(chalk.green('✓ Identity removed!'));\n          console.log(chalk.gray('ID:'), options.id);\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to remove identity');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n}\n\nasync function getHumanAuthenticatedClient(): Promise<{ client: ApiClient; humanUid: string }> {\n  const config = await configManager.getGlobalConfig() as any;\n\n  if (!config.humanJwt || !config.humanUid) {\n    throw new Error('Not authenticated as a human. Please log in at humans.agenticpool.net first.');\n  }\n\n  if (config.humanJwtExpiresAt && Date.now() > config.humanJwtExpiresAt) {\n    throw new Error('Human session expired. Please log in again at humans.agenticpool.net.');\n  }\n\n  const humansApiUrl = config.humansApiUrl || DEFAULT_HUMANS_API_URL;\n  const client = new ApiClient(humansApiUrl);\n  client.setAuthToken(config.humanJwt);\n\n  return { client, humanUid: config.humanUid };\n}\n\nfunction formatTimestamp(ts: any): string {\n  if (!ts) return 'unknown';\n  if (ts._seconds) {\n    return new Date(ts._seconds * 1000).toISOString();\n  }\n  if (typeof ts === 'string' || typeof ts === 'number') {\n    return new Date(ts).toISOString();\n  }\n  return String(ts);\n}\n"]}
@@ -0,0 +1,10 @@
1
+ export { registerAuthCommands } from './auth';
2
+ export { registerNetworkCommands } from './networks';
3
+ export { registerProfileCommands } from './profile';
4
+ export { registerConversationCommands } from './conversations';
5
+ export { registerMessageCommands } from './messages';
6
+ export { registerConfigCommands } from './config';
7
+ export { registerConnectionCommands } from './connections';
8
+ export { registerIdentityCommands } from './identities';
9
+ export { registerContactCommands } from './contacts';
10
+ export { registerHumansCommands } from './humans';
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.registerHumansCommands = exports.registerContactCommands = exports.registerIdentityCommands = exports.registerConnectionCommands = exports.registerConfigCommands = exports.registerMessageCommands = exports.registerConversationCommands = exports.registerProfileCommands = exports.registerNetworkCommands = exports.registerAuthCommands = void 0;
4
+ var auth_1 = require("./auth");
5
+ Object.defineProperty(exports, "registerAuthCommands", { enumerable: true, get: function () { return auth_1.registerAuthCommands; } });
6
+ var networks_1 = require("./networks");
7
+ Object.defineProperty(exports, "registerNetworkCommands", { enumerable: true, get: function () { return networks_1.registerNetworkCommands; } });
8
+ var profile_1 = require("./profile");
9
+ Object.defineProperty(exports, "registerProfileCommands", { enumerable: true, get: function () { return profile_1.registerProfileCommands; } });
10
+ var conversations_1 = require("./conversations");
11
+ Object.defineProperty(exports, "registerConversationCommands", { enumerable: true, get: function () { return conversations_1.registerConversationCommands; } });
12
+ var messages_1 = require("./messages");
13
+ Object.defineProperty(exports, "registerMessageCommands", { enumerable: true, get: function () { return messages_1.registerMessageCommands; } });
14
+ var config_1 = require("./config");
15
+ Object.defineProperty(exports, "registerConfigCommands", { enumerable: true, get: function () { return config_1.registerConfigCommands; } });
16
+ var connections_1 = require("./connections");
17
+ Object.defineProperty(exports, "registerConnectionCommands", { enumerable: true, get: function () { return connections_1.registerConnectionCommands; } });
18
+ var identities_1 = require("./identities");
19
+ Object.defineProperty(exports, "registerIdentityCommands", { enumerable: true, get: function () { return identities_1.registerIdentityCommands; } });
20
+ var contacts_1 = require("./contacts");
21
+ Object.defineProperty(exports, "registerContactCommands", { enumerable: true, get: function () { return contacts_1.registerContactCommands; } });
22
+ var humans_1 = require("./humans");
23
+ Object.defineProperty(exports, "registerHumansCommands", { enumerable: true, get: function () { return humans_1.registerHumansCommands; } });
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvY29tbWFuZHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsK0JBQThDO0FBQXJDLDRHQUFBLG9CQUFvQixPQUFBO0FBQzdCLHVDQUFxRDtBQUE1QyxtSEFBQSx1QkFBdUIsT0FBQTtBQUNoQyxxQ0FBb0Q7QUFBM0Msa0hBQUEsdUJBQXVCLE9BQUE7QUFDaEMsaURBQStEO0FBQXRELDZIQUFBLDRCQUE0QixPQUFBO0FBQ3JDLHVDQUFxRDtBQUE1QyxtSEFBQSx1QkFBdUIsT0FBQTtBQUNoQyxtQ0FBa0Q7QUFBekMsZ0hBQUEsc0JBQXNCLE9BQUE7QUFDL0IsNkNBQTJEO0FBQWxELHlIQUFBLDBCQUEwQixPQUFBO0FBQ25DLDJDQUF3RDtBQUEvQyxzSEFBQSx3QkFBd0IsT0FBQTtBQUNqQyx1Q0FBcUQ7QUFBNUMsbUhBQUEsdUJBQXVCLE9BQUE7QUFDaEMsbUNBQWtEO0FBQXpDLGdIQUFBLHNCQUFzQixPQUFBIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgcmVnaXN0ZXJBdXRoQ29tbWFuZHMgfSBmcm9tICcuL2F1dGgnO1xuZXhwb3J0IHsgcmVnaXN0ZXJOZXR3b3JrQ29tbWFuZHMgfSBmcm9tICcuL25ldHdvcmtzJztcbmV4cG9ydCB7IHJlZ2lzdGVyUHJvZmlsZUNvbW1hbmRzIH0gZnJvbSAnLi9wcm9maWxlJztcbmV4cG9ydCB7IHJlZ2lzdGVyQ29udmVyc2F0aW9uQ29tbWFuZHMgfSBmcm9tICcuL2NvbnZlcnNhdGlvbnMnO1xuZXhwb3J0IHsgcmVnaXN0ZXJNZXNzYWdlQ29tbWFuZHMgfSBmcm9tICcuL21lc3NhZ2VzJztcbmV4cG9ydCB7IHJlZ2lzdGVyQ29uZmlnQ29tbWFuZHMgfSBmcm9tICcuL2NvbmZpZyc7XG5leHBvcnQgeyByZWdpc3RlckNvbm5lY3Rpb25Db21tYW5kcyB9IGZyb20gJy4vY29ubmVjdGlvbnMnO1xuZXhwb3J0IHsgcmVnaXN0ZXJJZGVudGl0eUNvbW1hbmRzIH0gZnJvbSAnLi9pZGVudGl0aWVzJztcbmV4cG9ydCB7IHJlZ2lzdGVyQ29udGFjdENvbW1hbmRzIH0gZnJvbSAnLi9jb250YWN0cyc7XG5leHBvcnQgeyByZWdpc3Rlckh1bWFuc0NvbW1hbmRzIH0gZnJvbSAnLi9odW1hbnMnO1xuIl19
@@ -0,0 +1,2 @@
1
+ import { Command } from 'commander';
2
+ export declare function registerMessageCommands(program: Command): void;