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,72 @@
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.registerMessageCommands = registerMessageCommands;
7
+ const AuthHelper_1 = require("../auth/AuthHelper");
8
+ const chalk_1 = __importDefault(require("chalk"));
9
+ function registerMessageCommands(program) {
10
+ const messages = program.command('messages').description('Message commands');
11
+ messages
12
+ .command('send')
13
+ .description('Send a message to a conversation')
14
+ .requiredOption('-n, --network <id>', 'Network ID')
15
+ .requiredOption('-c, --conversation <id>', 'Conversation ID')
16
+ .requiredOption('-m, --message <text>', 'Message content')
17
+ .option('-t, --to <userId>', 'Recipient (omit for broadcast)')
18
+ .action(async (options) => {
19
+ try {
20
+ const { client } = await AuthHelper_1.AuthHelper.ensureAuthenticated(options.network);
21
+ const response = await client.post(`/v1/conversations/${options.network}/${options.conversation}/messages`, {
22
+ content: options.message,
23
+ receiverId: options.to || null
24
+ });
25
+ if (response.success) {
26
+ console.log(chalk_1.default.green('✓ Message sent!'));
27
+ }
28
+ else {
29
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to send message');
30
+ }
31
+ }
32
+ catch (error) {
33
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
34
+ }
35
+ });
36
+ messages
37
+ .command('list')
38
+ .description('List messages in a conversation')
39
+ .requiredOption('-n, --network <id>', 'Network ID')
40
+ .requiredOption('-c, --conversation <id>', 'Conversation ID')
41
+ .option('-l, --limit <num>', 'Number of messages', '50')
42
+ .action(async (options) => {
43
+ try {
44
+ const { client } = await AuthHelper_1.AuthHelper.ensureAuthenticated(options.network);
45
+ const response = await client.get(`/v1/conversations/${options.network}/${options.conversation}/messages`, {
46
+ limit: options.limit
47
+ });
48
+ if (response.success && response.data) {
49
+ if (response.data.length === 0) {
50
+ console.log(chalk_1.default.yellow('No messages yet.'));
51
+ return;
52
+ }
53
+ console.log(chalk_1.default.green.bold(`\nMessages (${response.data.length}):\n`));
54
+ response.data.forEach((msg) => {
55
+ const time = msg.createdAt ? new Date(msg.createdAt._seconds * 1000 || msg.createdAt).toLocaleTimeString() : '';
56
+ const from = chalk_1.default.cyan(msg.senderId);
57
+ const to = msg.receiverId ? chalk_1.default.yellow(`→ ${msg.receiverId}`) : chalk_1.default.gray('→ all');
58
+ console.log(`${chalk_1.default.gray(`[${time}]`)} ${from} ${to}`);
59
+ console.log(` ${msg.content}`);
60
+ console.log();
61
+ });
62
+ }
63
+ else {
64
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to list messages');
65
+ }
66
+ }
67
+ catch (error) {
68
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
69
+ }
70
+ });
71
+ }
72
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"messages.js","sourceRoot":"","sources":["../../src/commands/messages.ts"],"names":[],"mappings":"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","sourcesContent":["import { Command } from 'commander';\nimport { AuthHelper } from '../auth/AuthHelper';\nimport chalk from 'chalk';\n\nexport function registerMessageCommands(program: Command): void {\n  const messages = program.command('messages').description('Message commands');\n\n  messages\n    .command('send')\n    .description('Send a message to a conversation')\n    .requiredOption('-n, --network <id>', 'Network ID')\n    .requiredOption('-c, --conversation <id>', 'Conversation ID')\n    .requiredOption('-m, --message <text>', 'Message content')\n    .option('-t, --to <userId>', 'Recipient (omit for broadcast)')\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}/messages`, {\n          content: options.message,\n          receiverId: options.to || null\n        });\n\n        if (response.success) {\n          console.log(chalk.green('✓ Message sent!'));\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to send message');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  messages\n    .command('list')\n    .description('List messages in a conversation')\n    .requiredOption('-n, --network <id>', 'Network ID')\n    .requiredOption('-c, --conversation <id>', 'Conversation ID')\n    .option('-l, --limit <num>', 'Number of messages', '50')\n    .action(async (options) => {\n      try {\n        const { client } = await AuthHelper.ensureAuthenticated(options.network);\n        \n        const response = await client.get<any[]>(`/v1/conversations/${options.network}/${options.conversation}/messages`, {\n          limit: options.limit\n        });\n\n        if (response.success && response.data) {\n          if (response.data.length === 0) {\n            console.log(chalk.yellow('No messages yet.'));\n            return;\n          }\n\n          console.log(chalk.green.bold(`\\nMessages (${response.data.length}):\\n`));\n          \n          response.data.forEach((msg: any) => {\n            const time = msg.createdAt ? new Date(msg.createdAt._seconds * 1000 || msg.createdAt).toLocaleTimeString() : '';\n            const from = chalk.cyan(msg.senderId);\n            const to = msg.receiverId ? chalk.yellow(`→ ${msg.receiverId}`) : chalk.gray('→ all');\n            \n            console.log(`${chalk.gray(`[${time}]`)} ${from} ${to}`);\n            console.log(`  ${msg.content}`);\n            console.log();\n          });\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to list messages');\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 registerNetworkCommands(program: Command): void;
@@ -0,0 +1,237 @@
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.registerNetworkCommands = registerNetworkCommands;
7
+ const AuthHelper_1 = require("../auth/AuthHelper");
8
+ const LimitsManager_1 = require("../limits/LimitsManager");
9
+ const chalk_1 = __importDefault(require("chalk"));
10
+ function registerNetworkCommands(program) {
11
+ const networks = program.command('networks').description('Network management commands');
12
+ networks
13
+ .command('list')
14
+ .description('List public networks')
15
+ .option('-f, --filter <type>', 'Filter: popular, new, unpopular')
16
+ .option('-s, --short', 'Show short format (no long descriptions)')
17
+ .action(async (options) => {
18
+ try {
19
+ const client = await AuthHelper_1.AuthHelper.getApiClient();
20
+ const response = await client.get('/v1/networks', {
21
+ filter: options.filter,
22
+ short: options.short ? 'true' : undefined
23
+ });
24
+ if (response.success && response.data) {
25
+ console.log(chalk_1.default.green.bold(`\nFound ${response.data.length} networks:\n`));
26
+ response.data.forEach((network) => {
27
+ console.log(chalk_1.default.cyan.bold(network.name || network.id));
28
+ console.log(chalk_1.default.gray(' ID:'), network.id);
29
+ console.log(chalk_1.default.gray(' Description:'), network.description);
30
+ console.log(chalk_1.default.gray(' Users:'), network.users);
31
+ console.log(chalk_1.default.gray(' Status:'), network.status);
32
+ console.log();
33
+ });
34
+ }
35
+ else {
36
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to list networks');
37
+ }
38
+ }
39
+ catch (error) {
40
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
41
+ }
42
+ });
43
+ networks
44
+ .command('create')
45
+ .description('Create a new network')
46
+ .requiredOption('-n, --name <name>', 'Network name')
47
+ .requiredOption('-d, --description <desc>', 'Short description')
48
+ .option('-l, --long-description <desc>', 'Long description (markdown)')
49
+ .option('--logo <url>', 'Logo URL')
50
+ .option('--private', 'Make network private')
51
+ .action(async (options) => {
52
+ try {
53
+ const { client } = await AuthHelper_1.AuthHelper.getFirstAuthenticatedClient();
54
+ const mineRes = await client.get('/v1/networks/mine');
55
+ const currentCount = mineRes.success && mineRes.data ? mineRes.data.length : 0;
56
+ const limitCheck = await LimitsManager_1.limitsManager.canCreateNetwork(currentCount);
57
+ if (!limitCheck.allowed) {
58
+ console.error(chalk_1.default.red('Limit:'), limitCheck.reason);
59
+ return;
60
+ }
61
+ const response = await client.post('/v1/networks', {
62
+ name: options.name,
63
+ description: options.description,
64
+ longDescription: options.longDescription || '',
65
+ logoUrl: options.logo || '',
66
+ isPublic: !options.private
67
+ });
68
+ if (response.success && response.data) {
69
+ const network = response.data;
70
+ console.log(chalk_1.default.green('✓ Network created successfully!'));
71
+ console.log(chalk_1.default.gray('ID:'), network.id);
72
+ }
73
+ else {
74
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to create network');
75
+ }
76
+ }
77
+ catch (error) {
78
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
79
+ }
80
+ });
81
+ networks
82
+ .command('mine')
83
+ .description('List your networks')
84
+ .option('-s, --short', 'Show short format')
85
+ .action(async (options) => {
86
+ try {
87
+ const { client } = await AuthHelper_1.AuthHelper.getFirstAuthenticatedClient();
88
+ const response = await client.get('/v1/networks/mine', {
89
+ short: options.short ? 'true' : undefined
90
+ });
91
+ if (response.success && response.data) {
92
+ if (response.data.length === 0) {
93
+ console.log(chalk_1.default.yellow('No networks found.'));
94
+ return;
95
+ }
96
+ console.log(chalk_1.default.green.bold(`\nYour networks (${response.data.length}):\n`));
97
+ response.data.forEach((network) => {
98
+ console.log(chalk_1.default.cyan.bold(network.name || network.id));
99
+ console.log(chalk_1.default.gray(' ID:'), network.id);
100
+ console.log(chalk_1.default.gray(' Description:'), network.description);
101
+ console.log();
102
+ });
103
+ }
104
+ else {
105
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to list networks');
106
+ }
107
+ }
108
+ catch (error) {
109
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
110
+ }
111
+ });
112
+ networks
113
+ .command('show')
114
+ .description('Show network details')
115
+ .argument('<networkId>', 'Network ID')
116
+ .action(async (networkId) => {
117
+ try {
118
+ const client = await AuthHelper_1.AuthHelper.getApiClient();
119
+ const response = await client.get(`/v1/networks/${networkId}`);
120
+ if (response.success && response.data) {
121
+ const network = response.data;
122
+ console.log(chalk_1.default.cyan.bold(`\n${network.name}\n`));
123
+ console.log(chalk_1.default.gray('ID:'), network.id);
124
+ console.log(chalk_1.default.gray('Description:'), network.description);
125
+ console.log(chalk_1.default.gray('Status:'), network.status);
126
+ console.log(chalk_1.default.gray('Public:'), network.isPublic ? 'Yes' : 'No');
127
+ console.log(chalk_1.default.gray('Users:'), network.users);
128
+ if (network.longDescription) {
129
+ console.log(chalk_1.default.gray('\nLong Description:'));
130
+ console.log(network.longDescription);
131
+ }
132
+ }
133
+ else {
134
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Network not found');
135
+ }
136
+ }
137
+ catch (error) {
138
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
139
+ }
140
+ });
141
+ networks
142
+ .command('members')
143
+ .description('List network members')
144
+ .argument('<networkId>', 'Network ID')
145
+ .action(async (networkId) => {
146
+ try {
147
+ const client = await AuthHelper_1.AuthHelper.getApiClient();
148
+ const response = await client.get(`/v1/networks/${networkId}/members`);
149
+ if (response.success && response.data) {
150
+ console.log(chalk_1.default.green.bold(`\nMembers (${response.data.length}):\n`));
151
+ response.data.forEach((member) => {
152
+ console.log(chalk_1.default.cyan(member.publicToken));
153
+ console.log(chalk_1.default.gray(' Role:'), member.role);
154
+ console.log(chalk_1.default.gray(' Description:'), member.shortDescription || '(none)');
155
+ console.log();
156
+ });
157
+ }
158
+ else {
159
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to list members');
160
+ }
161
+ }
162
+ catch (error) {
163
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
164
+ }
165
+ });
166
+ networks
167
+ .command('join')
168
+ .description('Join a network (auto-register if needed)')
169
+ .argument('<networkId>', 'Network ID')
170
+ .action(async (networkId) => {
171
+ try {
172
+ const { client: authClient } = await AuthHelper_1.AuthHelper.getFirstAuthenticatedClient();
173
+ const mineRes = await authClient.get('/v1/networks/mine');
174
+ const currentCount = mineRes.success && mineRes.data ? mineRes.data.length : 0;
175
+ const limitCheck = await LimitsManager_1.limitsManager.canJoinNetwork(currentCount);
176
+ if (!limitCheck.allowed) {
177
+ console.error(chalk_1.default.red('Limit:'), limitCheck.reason);
178
+ return;
179
+ }
180
+ const result = await AuthHelper_1.AuthHelper.ensureAuthenticated(networkId);
181
+ if (result.isNewUser) {
182
+ console.log(chalk_1.default.green('✓ Joined network successfully!'));
183
+ }
184
+ else {
185
+ console.log(chalk_1.default.green('✓ Already authenticated to network.'));
186
+ }
187
+ console.log(chalk_1.default.gray('Network:'), networkId);
188
+ console.log(chalk_1.default.gray('Public Token:'), result.credentials.publicToken);
189
+ }
190
+ catch (error) {
191
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
192
+ }
193
+ });
194
+ networks
195
+ .command('discover')
196
+ .description('Discover networks by strategy')
197
+ .option('-s, --strategy <type>', 'Strategy: popular, newest, unpopular, recommended', 'popular')
198
+ .option('-l, --limit <number>', 'Limit results', '20')
199
+ .option('-n, --network <id>', 'Target network (for recommended strategy)')
200
+ .action(async (options) => {
201
+ try {
202
+ const client = await AuthHelper_1.AuthHelper.getApiClient();
203
+ const response = await client.get('/v1/networks/discover', {
204
+ strategy: options.strategy,
205
+ limit: options.limit,
206
+ network: options.network
207
+ });
208
+ if (response.success && response.data) {
209
+ const data = response.data;
210
+ console.log(chalk_1.default.green.bold(`\nDiscovered ${data.totalFound} networks (${options.strategy} strategy):\n`));
211
+ data.networks.forEach((network) => {
212
+ console.log(chalk_1.default.cyan.bold(network.name || network.id));
213
+ console.log(chalk_1.default.gray(' ID:'), network.id);
214
+ console.log(chalk_1.default.gray(' Description:'), network.description);
215
+ console.log(chalk_1.default.gray(' Users:'), network.users);
216
+ console.log(chalk_1.default.gray(' Status:'), network.status);
217
+ console.log();
218
+ });
219
+ if (data.recommendedForYou && data.recommendedForYou.length > 0) {
220
+ console.log(chalk_1.default.yellow.bold('\nRecommended for you:\n'));
221
+ data.recommendedForYou.forEach((rec) => {
222
+ console.log(chalk_1.default.cyan(` ${rec.networkId}`));
223
+ console.log(chalk_1.default.gray(' Reason:'), rec.reason);
224
+ console.log();
225
+ });
226
+ }
227
+ }
228
+ else {
229
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to discover networks');
230
+ }
231
+ }
232
+ catch (error) {
233
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
234
+ }
235
+ });
236
+ }
237
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"networks.js","sourceRoot":"","sources":["../../src/commands/networks.ts"],"names":[],"mappings":"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","sourcesContent":["import { Command } from 'commander';\nimport { ApiClient } from '../api';\nimport { configManager } from '../config';\nimport { AuthHelper } from '../auth/AuthHelper';\nimport { limitsManager } from '../limits/LimitsManager';\nimport chalk from 'chalk';\n\nexport function registerNetworkCommands(program: Command): void {\n  const networks = program.command('networks').description('Network management commands');\n\n  networks\n    .command('list')\n    .description('List public networks')\n    .option('-f, --filter <type>', 'Filter: popular, new, unpopular')\n    .option('-s, --short', 'Show short format (no long descriptions)')\n    .action(async (options) => {\n      try {\n        const client = await AuthHelper.getApiClient();\n        const response = await client.get<any[]>('/v1/networks', {\n          filter: options.filter,\n          short: options.short ? 'true' : undefined\n        });\n\n        if (response.success && response.data) {\n          console.log(chalk.green.bold(`\\nFound ${response.data.length} networks:\\n`));\n          \n          response.data.forEach((network: any) => {\n            console.log(chalk.cyan.bold(network.name || network.id));\n            console.log(chalk.gray('  ID:'), network.id);\n            console.log(chalk.gray('  Description:'), network.description);\n            console.log(chalk.gray('  Users:'), network.users);\n            console.log(chalk.gray('  Status:'), network.status);\n            console.log();\n          });\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to list networks');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  networks\n    .command('create')\n    .description('Create a new network')\n    .requiredOption('-n, --name <name>', 'Network name')\n    .requiredOption('-d, --description <desc>', 'Short description')\n    .option('-l, --long-description <desc>', 'Long description (markdown)')\n    .option('--logo <url>', 'Logo URL')\n    .option('--private', 'Make network private')\n    .action(async (options) => {\n      try {\n        const { client } = await AuthHelper.getFirstAuthenticatedClient();\n\n        const mineRes = await client.get<any[]>('/v1/networks/mine');\n        const currentCount = mineRes.success && mineRes.data ? mineRes.data.length : 0;\n        const limitCheck = await limitsManager.canCreateNetwork(currentCount);\n        if (!limitCheck.allowed) {\n          console.error(chalk.red('Limit:'), limitCheck.reason);\n          return;\n        }\n\n        const response = await client.post('/v1/networks', {\n          name: options.name,\n          description: options.description,\n          longDescription: options.longDescription || '',\n          logoUrl: options.logo || '',\n          isPublic: !options.private\n        });\n\n        if (response.success && response.data) {\n          const network = response.data as any;\n          console.log(chalk.green('✓ Network created successfully!'));\n          console.log(chalk.gray('ID:'), network.id);\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to create network');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  networks\n    .command('mine')\n    .description('List your networks')\n    .option('-s, --short', 'Show short format')\n    .action(async (options) => {\n      try {\n        const { client } = await AuthHelper.getFirstAuthenticatedClient();\n\n        const response = await client.get<any[]>('/v1/networks/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('No networks found.'));\n            return;\n          }\n\n          console.log(chalk.green.bold(`\\nYour networks (${response.data.length}):\\n`));\n          \n          response.data.forEach((network: any) => {\n            console.log(chalk.cyan.bold(network.name || network.id));\n            console.log(chalk.gray('  ID:'), network.id);\n            console.log(chalk.gray('  Description:'), network.description);\n            console.log();\n          });\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to list networks');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  networks\n    .command('show')\n    .description('Show network details')\n    .argument('<networkId>', 'Network ID')\n    .action(async (networkId) => {\n      try {\n        const client = await AuthHelper.getApiClient();\n        const response = await client.get<any>(`/v1/networks/${networkId}`);\n\n        if (response.success && response.data) {\n          const network = response.data;\n          console.log(chalk.cyan.bold(`\\n${network.name}\\n`));\n          console.log(chalk.gray('ID:'), network.id);\n          console.log(chalk.gray('Description:'), network.description);\n          console.log(chalk.gray('Status:'), network.status);\n          console.log(chalk.gray('Public:'), network.isPublic ? 'Yes' : 'No');\n          console.log(chalk.gray('Users:'), network.users);\n          \n          if (network.longDescription) {\n            console.log(chalk.gray('\\nLong Description:'));\n            console.log(network.longDescription);\n          }\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Network not found');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  networks\n    .command('members')\n    .description('List network members')\n    .argument('<networkId>', 'Network ID')\n    .action(async (networkId) => {\n      try {\n        const client = await AuthHelper.getApiClient();\n        const response = await client.get<any[]>(`/v1/networks/${networkId}/members`);\n\n        if (response.success && response.data) {\n          console.log(chalk.green.bold(`\\nMembers (${response.data.length}):\\n`));\n          \n          response.data.forEach((member: any) => {\n            console.log(chalk.cyan(member.publicToken));\n            console.log(chalk.gray('  Role:'), member.role);\n            console.log(chalk.gray('  Description:'), member.shortDescription || '(none)');\n            console.log();\n          });\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to list members');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  networks\n    .command('join')\n    .description('Join a network (auto-register if needed)')\n    .argument('<networkId>', 'Network ID')\n    .action(async (networkId) => {\n      try {\n        const { client: authClient } = await AuthHelper.getFirstAuthenticatedClient();\n        const mineRes = await authClient.get<any[]>('/v1/networks/mine');\n        const currentCount = mineRes.success && mineRes.data ? mineRes.data.length : 0;\n        const limitCheck = await limitsManager.canJoinNetwork(currentCount);\n        if (!limitCheck.allowed) {\n          console.error(chalk.red('Limit:'), limitCheck.reason);\n          return;\n        }\n\n        const result = await AuthHelper.ensureAuthenticated(networkId);\n\n        if (result.isNewUser) {\n          console.log(chalk.green('✓ Joined network successfully!'));\n        } else {\n          console.log(chalk.green('✓ Already authenticated to network.'));\n        }\n        console.log(chalk.gray('Network:'), networkId);\n        console.log(chalk.gray('Public Token:'), result.credentials.publicToken);\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  networks\n    .command('discover')\n    .description('Discover networks by strategy')\n    .option('-s, --strategy <type>', 'Strategy: popular, newest, unpopular, recommended', 'popular')\n    .option('-l, --limit <number>', 'Limit results', '20')\n    .option('-n, --network <id>', 'Target network (for recommended strategy)')\n    .action(async (options) => {\n      try {\n        const client = await AuthHelper.getApiClient();\n        const response = await client.get<any>('/v1/networks/discover', {\n          strategy: options.strategy,\n          limit: options.limit,\n          network: options.network\n        });\n\n        if (response.success && response.data) {\n          const data = response.data;\n          console.log(chalk.green.bold(`\\nDiscovered ${data.totalFound} networks (${options.strategy} strategy):\\n`));\n\n          data.networks.forEach((network: any) => {\n            console.log(chalk.cyan.bold(network.name || network.id));\n            console.log(chalk.gray('  ID:'), network.id);\n            console.log(chalk.gray('  Description:'), network.description);\n            console.log(chalk.gray('  Users:'), network.users);\n            console.log(chalk.gray('  Status:'), network.status);\n            console.log();\n          });\n\n          if (data.recommendedForYou && data.recommendedForYou.length > 0) {\n            console.log(chalk.yellow.bold('\\nRecommended for you:\\n'));\n            data.recommendedForYou.forEach((rec: any) => {\n              console.log(chalk.cyan(`  ${rec.networkId}`));\n              console.log(chalk.gray('  Reason:'), rec.reason);\n              console.log();\n            });\n          }\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to discover networks');\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 registerProfileCommands(program: Command): void;
@@ -0,0 +1,204 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.registerProfileCommands = registerProfileCommands;
37
+ const AuthHelper_1 = require("../auth/AuthHelper");
38
+ const chalk = __importStar(require("chalk"));
39
+ function registerProfileCommands(program) {
40
+ const profile = program.command('profile').description('Profile management commands');
41
+ profile
42
+ .command('questions')
43
+ .description('Get profile questions for a network')
44
+ .requiredOption('-n, --network <id>', 'Network ID')
45
+ .action(async (options) => {
46
+ try {
47
+ const client = await AuthHelper_1.AuthHelper.getApiClient();
48
+ const response = await client.get(`/v1/networks/${options.network}/questions`);
49
+ if (response.success && response.data) {
50
+ if (response.data.length === 0) {
51
+ console.log(chalk.yellow('No profile questions for this network.'));
52
+ return;
53
+ }
54
+ console.log(chalk.green.bold('\nProfile Questions:\n'));
55
+ response.data.forEach((q, index) => {
56
+ console.log(chalk.cyan(`${index + 1}. ${q.question}`));
57
+ console.log(chalk.gray(` Required: ${q.required ? 'Yes' : 'No'}`));
58
+ console.log();
59
+ });
60
+ }
61
+ else {
62
+ console.error(chalk.red('Error:'), response.error?.message || 'Failed to get questions');
63
+ }
64
+ }
65
+ catch (error) {
66
+ console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
67
+ }
68
+ });
69
+ profile
70
+ .command('set')
71
+ .description('Set your profile for a network')
72
+ .requiredOption('-n, --network <id>', 'Network ID')
73
+ .option('-s, --short <desc>', 'Short description')
74
+ .option('-l, --long <desc>', 'Long description')
75
+ .option('-f, --long-file <file>', 'Read long description from file')
76
+ .action(async (options) => {
77
+ try {
78
+ const { client } = await AuthHelper_1.AuthHelper.ensureAuthenticated(options.network);
79
+ let longDescription = options.long;
80
+ if (options.longFile) {
81
+ const filePath = options.longFile;
82
+ longDescription = require('fs').readFileSync(filePath, 'utf-8');
83
+ }
84
+ const updateData = {};
85
+ if (options.short)
86
+ updateData.shortDescription = options.short;
87
+ if (longDescription)
88
+ updateData.longDescription = longDescription;
89
+ const response = await client.put(`/v1/networks/${options.network}/profile`, updateData);
90
+ if (response.success) {
91
+ console.log(chalk.green('✓ Profile updated successfully!'));
92
+ }
93
+ else {
94
+ console.error(chalk.red('Error:'), response.error?.message || 'Failed to update profile');
95
+ }
96
+ }
97
+ catch (error) {
98
+ console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
99
+ }
100
+ });
101
+ profile
102
+ .command('get')
103
+ .description('Get your profile for a network')
104
+ .requiredOption('-n, --network <id>', 'Network ID')
105
+ .action(async (options) => {
106
+ try {
107
+ const { client, credentials } = await AuthHelper_1.AuthHelper.ensureAuthenticated(options.network);
108
+ const response = await client.get(`/v1/networks/${options.network}/profile`);
109
+ if (response.success && response.data) {
110
+ const profile = response.data;
111
+ console.log(chalk.cyan.bold('\nYour Profile\n'));
112
+ console.log(chalk.gray('Public Token:'), credentials.publicToken);
113
+ console.log(chalk.gray('Role:'), profile.role || 'member');
114
+ console.log(chalk.gray('Short Description:'), profile.shortDescription || '(none)');
115
+ if (profile.longDescription) {
116
+ console.log(chalk.gray('\nLong Description:'));
117
+ console.log(profile.longDescription);
118
+ }
119
+ }
120
+ else {
121
+ console.error(chalk.red('Error:'), response.error?.message || 'Failed to get profile');
122
+ }
123
+ }
124
+ catch (error) {
125
+ console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
126
+ }
127
+ });
128
+ profile
129
+ .command('build')
130
+ .description('Build profile interactively')
131
+ .requiredOption('-n, --network <id>', 'Network ID')
132
+ .option('-i, --interactive', 'Interactive mode', true)
133
+ .action(async (options) => {
134
+ try {
135
+ const { client } = await AuthHelper_1.AuthHelper.ensureAuthenticated(options.network);
136
+ const response = await client.get(`/v1/networks/${options.network}/questions`);
137
+ if (!response.success || !response.data || response.data.length === 0) {
138
+ console.log(chalk.yellow('No profile questions for this network.'));
139
+ return;
140
+ }
141
+ const questions = response.data;
142
+ const answers = {};
143
+ console.log(chalk.green.bold('\nBuilding Your Profile\n'));
144
+ console.log(chalk.gray(`Found ${questions.length} profile questions\n`));
145
+ for (let i = 0; i < questions.length; i++) {
146
+ const q = questions[i];
147
+ console.log(chalk.cyan(`${i + 1}. ${q.question}`));
148
+ console.log(chalk.gray(' Required:'), q.required ? 'Yes' : 'No');
149
+ if (q.required) {
150
+ const answer = await askQuestion(q.question + ' ');
151
+ if (!answer.trim()) {
152
+ console.error(chalk.red('Required question missing answer. Please try again.'));
153
+ process.exit(1);
154
+ }
155
+ answers[q.id || `question_${i}`] = answer;
156
+ }
157
+ else {
158
+ const answer = await askQuestion(q.question + ' (optional): ');
159
+ if (answer.trim()) {
160
+ answers[q.id || `question_${i}`] = answer;
161
+ }
162
+ }
163
+ console.log();
164
+ }
165
+ console.log(chalk.green.bold('\nCompleting profile...\n'));
166
+ const completeResponse = await client.post(`/v1/networks/${options.network}/profile/complete`, {
167
+ answers
168
+ });
169
+ if (completeResponse.success && completeResponse.data) {
170
+ const data = completeResponse.data;
171
+ console.log(chalk.green('✓ Profile built successfully!\n'));
172
+ console.log(chalk.cyan('Completion:'), `${data.completionPercentage}%`);
173
+ if (data.recommendations && data.recommendations.conversationsToJoin && data.recommendations.conversationsToJoin.length > 0) {
174
+ console.log(chalk.yellow('\nRecommended conversations to join:'));
175
+ data.recommendations.conversationsToJoin.forEach((convId) => {
176
+ console.log(chalk.gray(' -'), convId);
177
+ });
178
+ }
179
+ if (data.recommendations && data.recommendations.networkStrengths && data.recommendations.networkStrengths.length > 0) {
180
+ console.log(chalk.yellow('\nYour network strengths:'));
181
+ data.recommendations.networkStrengths.forEach((strength) => {
182
+ console.log(chalk.gray(' -'), strength);
183
+ });
184
+ }
185
+ }
186
+ else {
187
+ console.error(chalk.red('Error:'), completeResponse.error?.message || 'Failed to complete profile');
188
+ }
189
+ }
190
+ catch (error) {
191
+ console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
192
+ }
193
+ });
194
+ }
195
+ async function askQuestion(prompt) {
196
+ return new Promise((resolve) => {
197
+ process.stdout.write(prompt);
198
+ process.stdin.setEncoding('utf-8');
199
+ process.stdin.once('data', (data) => {
200
+ resolve(data.toString().trim());
201
+ });
202
+ });
203
+ }
204
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"profile.js","sourceRoot":"","sources":["../../src/commands/profile.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA,0DAyKC;AA5KD,mDAAgD;AAChD,6CAA+B;AAE/B,SAAgB,uBAAuB,CAAC,OAAgB;IACtD,MAAM,OAAO,GAAG,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,WAAW,CAAC,6BAA6B,CAAC,CAAC;IAEtF,OAAO;SACJ,OAAO,CAAC,WAAW,CAAC;SACpB,WAAW,CAAC,qCAAqC,CAAC;SAClD,cAAc,CAAC,oBAAoB,EAAE,YAAY,CAAC;SAClD,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,YAAY,CAAC,CAAC;YAEtF,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,KAAK,CAAC,MAAM,CAAC,wCAAwC,CAAC,CAAC,CAAC;oBACpE,OAAO;gBACT,CAAC;gBAED,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC,CAAC;gBAExD,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAM,EAAE,KAAa,EAAE,EAAE;oBAC9C,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,KAAK,GAAG,CAAC,KAAK,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;oBACvD,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC;oBACrE,OAAO,CAAC,GAAG,EAAE,CAAC;gBAChB,CAAC,CAAC,CAAC;YACL,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,QAAQ,CAAC,KAAK,EAAE,OAAO,IAAI,yBAAyB,CAAC,CAAC;YAC3F,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,KAAK,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,OAAO;SACJ,OAAO,CAAC,KAAK,CAAC;SACd,WAAW,CAAC,gCAAgC,CAAC;SAC7C,cAAc,CAAC,oBAAoB,EAAE,YAAY,CAAC;SAClD,MAAM,CAAC,oBAAoB,EAAE,mBAAmB,CAAC;SACjD,MAAM,CAAC,mBAAmB,EAAE,kBAAkB,CAAC;SAC/C,MAAM,CAAC,wBAAwB,EAAE,iCAAiC,CAAC;SACnE,MAAM,CAAC,KAAK,EAAE,OAAY,EAAE,EAAE;QAC7B,IAAI,CAAC;YACH,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,uBAAU,CAAC,mBAAmB,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;YAEzE,IAAI,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;YACnC,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;gBACrB,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,CAAC;gBAClC,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,YAAY,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;YAClE,CAAC;YAED,MAAM,UAAU,GAAQ,EAAE,CAAC;YAC3B,IAAI,OAAO,CAAC,KAAK;gBAAE,UAAU,CAAC,gBAAgB,GAAG,OAAO,CAAC,KAAK,CAAC;YAC/D,IAAI,eAAe;gBAAE,UAAU,CAAC,eAAe,GAAG,eAAe,CAAC;YAElE,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAAC,gBAAgB,OAAO,CAAC,OAAO,UAAU,EAAE,UAAU,CAAC,CAAC;YAEzF,IAAI,QAAQ,CAAC,OAAO,EAAE,CAAC;gBACrB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,iCAAiC,CAAC,CAAC,CAAC;YAC9D,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,QAAQ,CAAC,KAAK,EAAE,OAAO,IAAI,0BAA0B,CAAC,CAAC;YAC5F,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,KAAK,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,OAAO;SACJ,OAAO,CAAC,KAAK,CAAC;SACd,WAAW,CAAC,gCAAgC,CAAC;SAC7C,cAAc,CAAC,oBAAoB,EAAE,YAAY,CAAC;SAClD,MAAM,CAAC,KAAK,EAAE,OAAY,EAAE,EAAE;QAC7B,IAAI,CAAC;YACH,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,GAAG,MAAM,uBAAU,CAAC,mBAAmB,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;YAEtF,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAAM,gBAAgB,OAAO,CAAC,OAAO,UAAU,CAAC,CAAC;YAElF,IAAI,QAAQ,CAAC,OAAO,IAAI,QAAQ,CAAC,IAAI,EAAE,CAAC;gBACtC,MAAM,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC;gBAC9B,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC;gBACjD,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC,EAAE,WAAW,CAAC,WAAW,CAAC,CAAC;gBAClE,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,OAAO,CAAC,IAAI,IAAI,QAAQ,CAAC,CAAC;gBAC1D,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,oBAAoB,CAAC,EAAE,OAAO,CAAC,gBAAgB,IAAI,QAAQ,CAAC,CAAC;gBAErF,IAAI,OAAO,CAAC,eAAe,EAAE,CAAC;oBAC5B,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC;oBAC/C,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC;gBACvC,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,QAAQ,CAAC,KAAK,EAAE,OAAO,IAAI,uBAAuB,CAAC,CAAC;YACzF,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,KAAK,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,OAAO;SACJ,OAAO,CAAC,OAAO,CAAC;SAChB,WAAW,CAAC,6BAA6B,CAAC;SAC1C,cAAc,CAAC,oBAAoB,EAAE,YAAY,CAAC;SAClD,MAAM,CAAC,mBAAmB,EAAE,kBAAkB,EAAE,IAAI,CAAC;SACrD,MAAM,CAAC,KAAK,EAAE,OAAY,EAAE,EAAE;QAC7B,IAAI,CAAC;YACH,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,uBAAU,CAAC,mBAAmB,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;YACzE,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,GAAG,CAAQ,gBAAgB,OAAO,CAAC,OAAO,YAAY,CAAC,CAAC;YAEtF,IAAI,CAAC,QAAQ,CAAC,OAAO,IAAI,CAAC,QAAQ,CAAC,IAAI,IAAI,QAAQ,CAAC,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACtE,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,wCAAwC,CAAC,CAAC,CAAC;gBACpE,OAAO;YACT,CAAC;YAED,MAAM,SAAS,GAAG,QAAQ,CAAC,IAAI,CAAC;YAChC,MAAM,OAAO,GAA2B,EAAE,CAAC;YAE3C,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC,CAAC;YAC3D,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,SAAS,CAAC,MAAM,sBAAsB,CAAC,CAAC,CAAC;YAEzE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;gBAC1C,MAAM,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC;gBACvB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;gBACnD,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;gBAEnE,IAAI,CAAC,CAAC,QAAQ,EAAE,CAAC;oBACf,MAAM,MAAM,GAAG,MAAM,WAAW,CAAC,CAAC,CAAC,QAAQ,GAAG,GAAG,CAAC,CAAC;oBACnD,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,CAAC;wBACnB,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,qDAAqD,CAAC,CAAC,CAAC;wBAChF,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;oBAClB,CAAC;oBACD,OAAO,CAAC,CAAC,CAAC,EAAE,IAAI,YAAY,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC;gBAC5C,CAAC;qBAAM,CAAC;oBACN,MAAM,MAAM,GAAG,MAAM,WAAW,CAAC,CAAC,CAAC,QAAQ,GAAG,eAAe,CAAC,CAAC;oBAC/D,IAAI,MAAM,CAAC,IAAI,EAAE,EAAE,CAAC;wBAClB,OAAO,CAAC,CAAC,CAAC,EAAE,IAAI,YAAY,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC;oBAC5C,CAAC;gBACH,CAAC;gBAED,OAAO,CAAC,GAAG,EAAE,CAAC;YAChB,CAAC;YAED,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC,CAAC;YAE3D,MAAM,gBAAgB,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,gBAAgB,OAAO,CAAC,OAAO,mBAAmB,EAAE;gBAC7F,OAAO;aACR,CAAC,CAAC;YAEH,IAAI,gBAAgB,CAAC,OAAO,IAAI,gBAAgB,CAAC,IAAI,EAAE,CAAC;gBACtD,MAAM,IAAI,GAAG,gBAAgB,CAAC,IAAW,CAAC;gBAC1C,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,iCAAiC,CAAC,CAAC,CAAC;gBAC5D,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE,GAAG,IAAI,CAAC,oBAAoB,GAAG,CAAC,CAAC;gBAExE,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,eAAe,CAAC,mBAAmB,IAAI,IAAI,CAAC,eAAe,CAAC,mBAAmB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBAC5H,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,sCAAsC,CAAC,CAAC,CAAC;oBAClE,IAAI,CAAC,eAAe,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC,MAAc,EAAE,EAAE;wBAClE,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC,CAAC;oBACzC,CAAC,CAAC,CAAC;gBACL,CAAC;gBAED,IAAI,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,eAAe,CAAC,gBAAgB,IAAI,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBACtH,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,CAAC,2BAA2B,CAAC,CAAC,CAAC;oBACvD,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,QAAgB,EAAE,EAAE;wBACjE,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,QAAQ,CAAC,CAAC;oBAC3C,CAAC,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,gBAAgB,CAAC,KAAK,EAAE,OAAO,IAAI,4BAA4B,CAAC,CAAC;YACtG,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,KAAK,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;AAED,KAAK,UAAU,WAAW,CAAC,MAAc;IACvC,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;QAC7B,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAC7B,OAAO,CAAC,KAAK,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;QACnC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE;YAClC,OAAO,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC","sourcesContent":["import { Command } from 'commander';\nimport { AuthHelper } from '../auth/AuthHelper';\nimport * as chalk from 'chalk';\n\nexport function registerProfileCommands(program: Command): void {\n  const profile = program.command('profile').description('Profile management commands');\n\n  profile\n    .command('questions')\n    .description('Get profile questions for a network')\n    .requiredOption('-n, --network <id>', 'Network ID')\n    .action(async (options) => {\n      try {\n        const client = await AuthHelper.getApiClient();\n        const response = await client.get<any[]>(`/v1/networks/${options.network}/questions`);\n\n        if (response.success && response.data) {\n          if (response.data.length === 0) {\n            console.log(chalk.yellow('No profile questions for this network.'));\n            return;\n          }\n\n          console.log(chalk.green.bold('\\nProfile Questions:\\n'));\n\n          response.data.forEach((q: any, index: number) => {\n            console.log(chalk.cyan(`${index + 1}. ${q.question}`));\n            console.log(chalk.gray(`   Required: ${q.required ? 'Yes' : 'No'}`));\n            console.log();\n          });\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to get questions');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  profile\n    .command('set')\n    .description('Set your profile for a network')\n    .requiredOption('-n, --network <id>', 'Network ID')\n    .option('-s, --short <desc>', 'Short description')\n    .option('-l, --long <desc>', 'Long description')\n    .option('-f, --long-file <file>', 'Read long description from file')\n    .action(async (options: any) => {\n      try {\n        const { client } = await AuthHelper.ensureAuthenticated(options.network);\n\n        let longDescription = options.long;\n        if (options.longFile) {\n          const filePath = options.longFile;\n          longDescription = require('fs').readFileSync(filePath, 'utf-8');\n        }\n\n        const updateData: any = {};\n        if (options.short) updateData.shortDescription = options.short;\n        if (longDescription) updateData.longDescription = longDescription;\n\n        const response = await client.put(`/v1/networks/${options.network}/profile`, updateData);\n\n        if (response.success) {\n          console.log(chalk.green('✓ Profile updated successfully!'));\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  profile\n    .command('get')\n    .description('Get your profile for a network')\n    .requiredOption('-n, --network <id>', 'Network ID')\n    .action(async (options: any) => {\n      try {\n        const { client, credentials } = await AuthHelper.ensureAuthenticated(options.network);\n\n        const response = await client.get<any>(`/v1/networks/${options.network}/profile`);\n\n        if (response.success && response.data) {\n          const profile = response.data;\n          console.log(chalk.cyan.bold('\\nYour Profile\\n'));\n          console.log(chalk.gray('Public Token:'), credentials.publicToken);\n          console.log(chalk.gray('Role:'), profile.role || 'member');\n           console.log(chalk.gray('Short Description:'), profile.shortDescription || '(none)');\n\n          if (profile.longDescription) {\n            console.log(chalk.gray('\\nLong Description:'));\n            console.log(profile.longDescription);\n          }\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  profile\n    .command('build')\n    .description('Build profile interactively')\n    .requiredOption('-n, --network <id>', 'Network ID')\n    .option('-i, --interactive', 'Interactive mode', true)\n    .action(async (options: any) => {\n      try {\n        const { client } = await AuthHelper.ensureAuthenticated(options.network);\n        const response = await client.get<any[]>(`/v1/networks/${options.network}/questions`);\n\n        if (!response.success || !response.data || response.data.length === 0) {\n          console.log(chalk.yellow('No profile questions for this network.'));\n          return;\n        }\n\n        const questions = response.data;\n        const answers: Record<string, string> = {};\n\n        console.log(chalk.green.bold('\\nBuilding Your Profile\\n'));\n        console.log(chalk.gray(`Found ${questions.length} profile questions\\n`));\n\n        for (let i = 0; i < questions.length; i++) {\n          const q = questions[i];\n          console.log(chalk.cyan(`${i + 1}. ${q.question}`));\n          console.log(chalk.gray('   Required:'), q.required ? 'Yes' : 'No');\n\n          if (q.required) {\n            const answer = await askQuestion(q.question + ' ');\n            if (!answer.trim()) {\n              console.error(chalk.red('Required question missing answer. Please try again.'));\n              process.exit(1);\n            }\n            answers[q.id || `question_${i}`] = answer;\n          } else {\n            const answer = await askQuestion(q.question + ' (optional): ');\n            if (answer.trim()) {\n              answers[q.id || `question_${i}`] = answer;\n            }\n          }\n\n          console.log();\n        }\n\n        console.log(chalk.green.bold('\\nCompleting profile...\\n'));\n\n        const completeResponse = await client.post(`/v1/networks/${options.network}/profile/complete`, {\n          answers\n        });\n\n        if (completeResponse.success && completeResponse.data) {\n          const data = completeResponse.data as any;\n          console.log(chalk.green('✓ Profile built successfully!\\n'));\n          console.log(chalk.cyan('Completion:'), `${data.completionPercentage}%`);\n\n          if (data.recommendations && data.recommendations.conversationsToJoin && data.recommendations.conversationsToJoin.length > 0) {\n            console.log(chalk.yellow('\\nRecommended conversations to join:'));\n            data.recommendations.conversationsToJoin.forEach((convId: string) => {\n              console.log(chalk.gray('  -'), convId);\n            });\n          }\n\n          if (data.recommendations && data.recommendations.networkStrengths && data.recommendations.networkStrengths.length > 0) {\n            console.log(chalk.yellow('\\nYour network strengths:'));\n            data.recommendations.networkStrengths.forEach((strength: string) => {\n              console.log(chalk.gray('  -'), strength);\n            });\n          }\n        } else {\n          console.error(chalk.red('Error:'), completeResponse.error?.message || 'Failed to complete profile');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n}\n\nasync function askQuestion(prompt: string): Promise<string> {\n  return new Promise((resolve) => {\n    process.stdout.write(prompt);\n    process.stdin.setEncoding('utf-8');\n    process.stdin.once('data', (data) => {\n      resolve(data.toString().trim());\n    });\n  });\n}\n"]}