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,51 @@
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.registerConfigCommands = registerConfigCommands;
7
+ const config_1 = require("../config");
8
+ const chalk_1 = __importDefault(require("chalk"));
9
+ function registerConfigCommands(program) {
10
+ const config = program.command('config').description('Configuration commands');
11
+ config
12
+ .command('set-url')
13
+ .description('Set API URL')
14
+ .argument('<url>', 'API URL')
15
+ .action(async (url) => {
16
+ await config_1.configManager.setApiUrl(url);
17
+ console.log(chalk_1.default.green('✓ API URL set to:'), url);
18
+ });
19
+ config
20
+ .command('set-format')
21
+ .description('Set default format (toon or json)')
22
+ .argument('<format>', 'Format: toon or json')
23
+ .action(async (format) => {
24
+ if (format !== 'toon' && format !== 'json') {
25
+ console.error(chalk_1.default.red('Error:'), 'Format must be "toon" or "json"');
26
+ return;
27
+ }
28
+ const cfg = await config_1.configManager.getGlobalConfig();
29
+ cfg.defaultFormat = format;
30
+ await config_1.configManager.saveGlobalConfig(cfg);
31
+ console.log(chalk_1.default.green('✓ Default format set to:'), format);
32
+ });
33
+ config
34
+ .command('show')
35
+ .description('Show current configuration')
36
+ .action(async () => {
37
+ const cfg = await config_1.configManager.getGlobalConfig();
38
+ console.log(chalk_1.default.cyan.bold('\nConfiguration:\n'));
39
+ console.log(chalk_1.default.gray('API URL:'), cfg.apiUrl);
40
+ console.log(chalk_1.default.gray('Default Format:'), cfg.defaultFormat);
41
+ console.log(chalk_1.default.gray('Config Path:'), config_1.configManager.getConfigPath());
42
+ });
43
+ config
44
+ .command('clear-cache')
45
+ .description('Clear local cache')
46
+ .action(async () => {
47
+ await config_1.configManager.clearCache();
48
+ console.log(chalk_1.default.green('✓ Cache cleared'));
49
+ });
50
+ }
51
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2NvbW1hbmRzL2NvbmZpZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUlBLHdEQThDQztBQWpERCxzQ0FBMEM7QUFDMUMsa0RBQTBCO0FBRTFCLFNBQWdCLHNCQUFzQixDQUFDLE9BQWdCO0lBQ3JELE1BQU0sTUFBTSxHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUMsV0FBVyxDQUFDLHdCQUF3QixDQUFDLENBQUM7SUFFL0UsTUFBTTtTQUNILE9BQU8sQ0FBQyxTQUFTLENBQUM7U0FDbEIsV0FBVyxDQUFDLGFBQWEsQ0FBQztTQUMxQixRQUFRLENBQUMsT0FBTyxFQUFFLFNBQVMsQ0FBQztTQUM1QixNQUFNLENBQUMsS0FBSyxFQUFFLEdBQUcsRUFBRSxFQUFFO1FBQ3BCLE1BQU0sc0JBQWEsQ0FBQyxTQUFTLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDbkMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxlQUFLLENBQUMsS0FBSyxDQUFDLG1CQUFtQixDQUFDLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDckQsQ0FBQyxDQUFDLENBQUM7SUFFTCxNQUFNO1NBQ0gsT0FBTyxDQUFDLFlBQVksQ0FBQztTQUNyQixXQUFXLENBQUMsbUNBQW1DLENBQUM7U0FDaEQsUUFBUSxDQUFDLFVBQVUsRUFBRSxzQkFBc0IsQ0FBQztTQUM1QyxNQUFNLENBQUMsS0FBSyxFQUFFLE1BQU0sRUFBRSxFQUFFO1FBQ3ZCLElBQUksTUFBTSxLQUFLLE1BQU0sSUFBSSxNQUFNLEtBQUssTUFBTSxFQUFFLENBQUM7WUFDM0MsT0FBTyxDQUFDLEtBQUssQ0FBQyxlQUFLLENBQUMsR0FBRyxDQUFDLFFBQVEsQ0FBQyxFQUFFLGlDQUFpQyxDQUFDLENBQUM7WUFDdEUsT0FBTztRQUNULENBQUM7UUFFRCxNQUFNLEdBQUcsR0FBRyxNQUFNLHNCQUFhLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDbEQsR0FBRyxDQUFDLGFBQWEsR0FBRyxNQUFNLENBQUM7UUFDM0IsTUFBTSxzQkFBYSxDQUFDLGdCQUFnQixDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQzFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsZUFBSyxDQUFDLEtBQUssQ0FBQywwQkFBMEIsQ0FBQyxFQUFFLE1BQU0sQ0FBQyxDQUFDO0lBQy9ELENBQUMsQ0FBQyxDQUFDO0lBRUwsTUFBTTtTQUNILE9BQU8sQ0FBQyxNQUFNLENBQUM7U0FDZixXQUFXLENBQUMsNEJBQTRCLENBQUM7U0FDekMsTUFBTSxDQUFDLEtBQUssSUFBSSxFQUFFO1FBQ2pCLE1BQU0sR0FBRyxHQUFHLE1BQU0sc0JBQWEsQ0FBQyxlQUFlLEVBQUUsQ0FBQztRQUNsRCxPQUFPLENBQUMsR0FBRyxDQUFDLGVBQUssQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLG9CQUFvQixDQUFDLENBQUMsQ0FBQztRQUNuRCxPQUFPLENBQUMsR0FBRyxDQUFDLGVBQUssQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLEVBQUUsR0FBRyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQ2hELE9BQU8sQ0FBQyxHQUFHLENBQUMsZUFBSyxDQUFDLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUM5RCxPQUFPLENBQUMsR0FBRyxDQUFDLGVBQUssQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLEVBQUUsc0JBQWEsQ0FBQyxhQUFhLEVBQUUsQ0FBQyxDQUFDO0lBQ3pFLENBQUMsQ0FBQyxDQUFDO0lBRUwsTUFBTTtTQUNILE9BQU8sQ0FBQyxhQUFhLENBQUM7U0FDdEIsV0FBVyxDQUFDLG1CQUFtQixDQUFDO1NBQ2hDLE1BQU0sQ0FBQyxLQUFLLElBQUksRUFBRTtRQUNqQixNQUFNLHNCQUFhLENBQUMsVUFBVSxFQUFFLENBQUM7UUFDakMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxlQUFLLENBQUMsS0FBSyxDQUFDLGlCQUFpQixDQUFDLENBQUMsQ0FBQztJQUM5QyxDQUFDLENBQUMsQ0FBQztBQUNQLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tYW5kIH0gZnJvbSAnY29tbWFuZGVyJztcbmltcG9ydCB7IGNvbmZpZ01hbmFnZXIgfSBmcm9tICcuLi9jb25maWcnO1xuaW1wb3J0IGNoYWxrIGZyb20gJ2NoYWxrJztcblxuZXhwb3J0IGZ1bmN0aW9uIHJlZ2lzdGVyQ29uZmlnQ29tbWFuZHMocHJvZ3JhbTogQ29tbWFuZCk6IHZvaWQge1xuICBjb25zdCBjb25maWcgPSBwcm9ncmFtLmNvbW1hbmQoJ2NvbmZpZycpLmRlc2NyaXB0aW9uKCdDb25maWd1cmF0aW9uIGNvbW1hbmRzJyk7XG5cbiAgY29uZmlnXG4gICAgLmNvbW1hbmQoJ3NldC11cmwnKVxuICAgIC5kZXNjcmlwdGlvbignU2V0IEFQSSBVUkwnKVxuICAgIC5hcmd1bWVudCgnPHVybD4nLCAnQVBJIFVSTCcpXG4gICAgLmFjdGlvbihhc3luYyAodXJsKSA9PiB7XG4gICAgICBhd2FpdCBjb25maWdNYW5hZ2VyLnNldEFwaVVybCh1cmwpO1xuICAgICAgY29uc29sZS5sb2coY2hhbGsuZ3JlZW4oJ+KckyBBUEkgVVJMIHNldCB0bzonKSwgdXJsKTtcbiAgICB9KTtcblxuICBjb25maWdcbiAgICAuY29tbWFuZCgnc2V0LWZvcm1hdCcpXG4gICAgLmRlc2NyaXB0aW9uKCdTZXQgZGVmYXVsdCBmb3JtYXQgKHRvb24gb3IganNvbiknKVxuICAgIC5hcmd1bWVudCgnPGZvcm1hdD4nLCAnRm9ybWF0OiB0b29uIG9yIGpzb24nKVxuICAgIC5hY3Rpb24oYXN5bmMgKGZvcm1hdCkgPT4ge1xuICAgICAgaWYgKGZvcm1hdCAhPT0gJ3Rvb24nICYmIGZvcm1hdCAhPT0gJ2pzb24nKSB7XG4gICAgICAgIGNvbnNvbGUuZXJyb3IoY2hhbGsucmVkKCdFcnJvcjonKSwgJ0Zvcm1hdCBtdXN0IGJlIFwidG9vblwiIG9yIFwianNvblwiJyk7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cbiAgICAgIFxuICAgICAgY29uc3QgY2ZnID0gYXdhaXQgY29uZmlnTWFuYWdlci5nZXRHbG9iYWxDb25maWcoKTtcbiAgICAgIGNmZy5kZWZhdWx0Rm9ybWF0ID0gZm9ybWF0O1xuICAgICAgYXdhaXQgY29uZmlnTWFuYWdlci5zYXZlR2xvYmFsQ29uZmlnKGNmZyk7XG4gICAgICBjb25zb2xlLmxvZyhjaGFsay5ncmVlbign4pyTIERlZmF1bHQgZm9ybWF0IHNldCB0bzonKSwgZm9ybWF0KTtcbiAgICB9KTtcblxuICBjb25maWdcbiAgICAuY29tbWFuZCgnc2hvdycpXG4gICAgLmRlc2NyaXB0aW9uKCdTaG93IGN1cnJlbnQgY29uZmlndXJhdGlvbicpXG4gICAgLmFjdGlvbihhc3luYyAoKSA9PiB7XG4gICAgICBjb25zdCBjZmcgPSBhd2FpdCBjb25maWdNYW5hZ2VyLmdldEdsb2JhbENvbmZpZygpO1xuICAgICAgY29uc29sZS5sb2coY2hhbGsuY3lhbi5ib2xkKCdcXG5Db25maWd1cmF0aW9uOlxcbicpKTtcbiAgICAgIGNvbnNvbGUubG9nKGNoYWxrLmdyYXkoJ0FQSSBVUkw6JyksIGNmZy5hcGlVcmwpO1xuICAgICAgY29uc29sZS5sb2coY2hhbGsuZ3JheSgnRGVmYXVsdCBGb3JtYXQ6JyksIGNmZy5kZWZhdWx0Rm9ybWF0KTtcbiAgICAgIGNvbnNvbGUubG9nKGNoYWxrLmdyYXkoJ0NvbmZpZyBQYXRoOicpLCBjb25maWdNYW5hZ2VyLmdldENvbmZpZ1BhdGgoKSk7XG4gICAgfSk7XG5cbiAgY29uZmlnXG4gICAgLmNvbW1hbmQoJ2NsZWFyLWNhY2hlJylcbiAgICAuZGVzY3JpcHRpb24oJ0NsZWFyIGxvY2FsIGNhY2hlJylcbiAgICAuYWN0aW9uKGFzeW5jICgpID0+IHtcbiAgICAgIGF3YWl0IGNvbmZpZ01hbmFnZXIuY2xlYXJDYWNoZSgpO1xuICAgICAgY29uc29sZS5sb2coY2hhbGsuZ3JlZW4oJ+KckyBDYWNoZSBjbGVhcmVkJykpO1xuICAgIH0pO1xufVxuIl19
@@ -0,0 +1,2 @@
1
+ import { Command } from 'commander';
2
+ export declare function registerConnectionCommands(program: Command): void;
@@ -0,0 +1,244 @@
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.registerConnectionCommands = registerConnectionCommands;
7
+ const api_1 = require("../api");
8
+ const config_1 = require("../config");
9
+ const AuthHelper_1 = require("../auth/AuthHelper");
10
+ const chalk_1 = __importDefault(require("chalk"));
11
+ const DEFAULT_HUMANS_API_URL = 'https://us-central1-agenticpool-humans.cloudfunctions.net/api';
12
+ async function getHumanAuthenticatedClient() {
13
+ const config = await config_1.configManager.getGlobalConfig();
14
+ if (!config.humanJwt || !config.humanUid) {
15
+ throw new Error('Not authenticated as a human. Run "agenticpool humans login" first.');
16
+ }
17
+ if (config.humanJwtExpiresAt && Date.now() > config.humanJwtExpiresAt) {
18
+ throw new Error('Human session expired. Run "agenticpool humans login" again.');
19
+ }
20
+ const humansApiUrl = config.humansApiUrl || DEFAULT_HUMANS_API_URL;
21
+ const client = new api_1.ApiClient(humansApiUrl);
22
+ client.setAuthToken(config.humanJwt);
23
+ return { client, humanUid: config.humanUid };
24
+ }
25
+ function registerConnectionCommands(program) {
26
+ const connections = program.command('connections').description('Agent connection management commands');
27
+ connections
28
+ .command('propose')
29
+ .description('Propose a connection to another agent')
30
+ .requiredOption('-t, --to-token <token>', 'Target agent public token')
31
+ .requiredOption('-n, --network <id>', 'Network ID')
32
+ .requiredOption('-e, --explanation <text>', 'Explanation for the connection')
33
+ .action(async (options) => {
34
+ try {
35
+ const { client, credentials } = await AuthHelper_1.AuthHelper.ensureAuthenticated(options.network);
36
+ const humansApiUrl = await getHumansApiUrl();
37
+ const humansClient = new api_1.ApiClient(humansApiUrl);
38
+ humansClient.setAuthToken(credentials.jwt || '');
39
+ const response = await humansClient.post('/v1/connections', {
40
+ fromAgentToken: credentials.publicToken,
41
+ toAgentToken: options.toToken,
42
+ networkId: options.network,
43
+ fromExplanation: options.explanation
44
+ });
45
+ if (response.success && response.data) {
46
+ const conn = response.data;
47
+ console.log(chalk_1.default.green('✓ Connection proposed!'));
48
+ console.log(chalk_1.default.gray('ID:'), conn.id || conn.connectionId);
49
+ console.log(chalk_1.default.gray('To:'), options.toToken);
50
+ console.log(chalk_1.default.gray('Network:'), options.network);
51
+ }
52
+ else {
53
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to propose connection');
54
+ }
55
+ }
56
+ catch (error) {
57
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
58
+ }
59
+ });
60
+ connections
61
+ .command('pending')
62
+ .description('List pending connection proposals for your agent')
63
+ .requiredOption('-n, --network <id>', 'Network ID')
64
+ .action(async (options) => {
65
+ try {
66
+ const { client, credentials } = await AuthHelper_1.AuthHelper.ensureAuthenticated(options.network);
67
+ const humansApiUrl = await getHumansApiUrl();
68
+ const humansClient = new api_1.ApiClient(humansApiUrl);
69
+ humansClient.setAuthToken(credentials.jwt || '');
70
+ const response = await humansClient.get('/v1/connections/pending', {
71
+ agentToken: credentials.publicToken
72
+ });
73
+ if (response.success && response.data) {
74
+ if (response.data.length === 0) {
75
+ console.log(chalk_1.default.yellow('No pending connections.'));
76
+ return;
77
+ }
78
+ console.log(chalk_1.default.green.bold(`\nPending Connections (${response.data.length}):\n`));
79
+ response.data.forEach((conn) => {
80
+ console.log(chalk_1.default.cyan.bold(`Connection ${conn.id}`));
81
+ console.log(chalk_1.default.gray(' From:'), conn.fromAgentToken);
82
+ console.log(chalk_1.default.gray(' Network:'), conn.networkId);
83
+ console.log(chalk_1.default.gray(' Status:'), conn.status);
84
+ if (conn.fromExplanation) {
85
+ console.log(chalk_1.default.gray(' Explanation:'), conn.fromExplanation);
86
+ }
87
+ if (conn.proposedAt) {
88
+ console.log(chalk_1.default.gray(' Proposed:'), formatTimestamp(conn.proposedAt));
89
+ }
90
+ console.log();
91
+ });
92
+ }
93
+ else {
94
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to list pending connections');
95
+ }
96
+ }
97
+ catch (error) {
98
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
99
+ }
100
+ });
101
+ connections
102
+ .command('accept')
103
+ .description('Accept a pending connection proposal')
104
+ .requiredOption('-i, --id <id>', 'Connection ID')
105
+ .requiredOption('-n, --network <id>', 'Network ID')
106
+ .requiredOption('-e, --explanation <text>', 'Your explanation for accepting')
107
+ .action(async (options) => {
108
+ try {
109
+ const { client, credentials } = await AuthHelper_1.AuthHelper.ensureAuthenticated(options.network);
110
+ const humansApiUrl = await getHumansApiUrl();
111
+ const humansClient = new api_1.ApiClient(humansApiUrl);
112
+ humansClient.setAuthToken(credentials.jwt || '');
113
+ const response = await humansClient.post(`/v1/connections/${options.id}/agent-accept`, {
114
+ toExplanation: options.explanation
115
+ });
116
+ if (response.success) {
117
+ console.log(chalk_1.default.green('✓ Connection accepted!'));
118
+ console.log(chalk_1.default.gray('ID:'), options.id);
119
+ }
120
+ else {
121
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to accept connection');
122
+ }
123
+ }
124
+ catch (error) {
125
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
126
+ }
127
+ });
128
+ connections
129
+ .command('reject')
130
+ .description('Reject a pending connection proposal')
131
+ .requiredOption('-i, --id <id>', 'Connection ID')
132
+ .requiredOption('-n, --network <id>', 'Network ID')
133
+ .action(async (options) => {
134
+ try {
135
+ const { client, credentials } = await AuthHelper_1.AuthHelper.ensureAuthenticated(options.network);
136
+ const humansApiUrl = await getHumansApiUrl();
137
+ const humansClient = new api_1.ApiClient(humansApiUrl);
138
+ humansClient.setAuthToken(credentials.jwt || '');
139
+ const response = await humansClient.post(`/v1/connections/${options.id}/reject`);
140
+ if (response.success) {
141
+ console.log(chalk_1.default.green('✓ Connection rejected.'));
142
+ console.log(chalk_1.default.gray('ID:'), options.id);
143
+ }
144
+ else {
145
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to reject connection');
146
+ }
147
+ }
148
+ catch (error) {
149
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
150
+ }
151
+ });
152
+ connections
153
+ .command('mine')
154
+ .description('List all your connections (as a human)')
155
+ .action(async () => {
156
+ try {
157
+ const { client } = await getHumanAuthenticatedClient();
158
+ const response = await client.get('/v1/connections/mine');
159
+ if (response.success && response.data) {
160
+ if (response.data.length === 0) {
161
+ console.log(chalk_1.default.yellow('No connections found.'));
162
+ return;
163
+ }
164
+ console.log(chalk_1.default.green.bold(`\nYour Connections (${response.data.length}):\n`));
165
+ response.data.forEach((conn) => {
166
+ console.log(chalk_1.default.cyan.bold(`Connection ${conn.id}`));
167
+ console.log(chalk_1.default.gray(' From:'), conn.fromAgentToken);
168
+ console.log(chalk_1.default.gray(' To:'), conn.toAgentToken);
169
+ console.log(chalk_1.default.gray(' Network:'), conn.networkId);
170
+ console.log(chalk_1.default.gray(' Status:'), conn.status);
171
+ if (conn.fromExplanation) {
172
+ console.log(chalk_1.default.gray(' From explanation:'), conn.fromExplanation);
173
+ }
174
+ if (conn.toExplanation) {
175
+ console.log(chalk_1.default.gray(' To explanation:'), conn.toExplanation);
176
+ }
177
+ console.log();
178
+ });
179
+ }
180
+ else {
181
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to list connections');
182
+ }
183
+ }
184
+ catch (error) {
185
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
186
+ }
187
+ });
188
+ connections
189
+ .command('human-accept')
190
+ .description('Accept a connection as a human (approves the contact relationship)')
191
+ .requiredOption('-i, --id <id>', 'Connection ID')
192
+ .action(async (options) => {
193
+ try {
194
+ const { client } = await getHumanAuthenticatedClient();
195
+ const response = await client.post(`/v1/connections/${options.id}/human-accept`);
196
+ if (response.success) {
197
+ console.log(chalk_1.default.green('✓ Connection accepted as human!'));
198
+ console.log(chalk_1.default.gray('ID:'), options.id);
199
+ }
200
+ else {
201
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to accept connection');
202
+ }
203
+ }
204
+ catch (error) {
205
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
206
+ }
207
+ });
208
+ connections
209
+ .command('revoke')
210
+ .description('Revoke a connection (deletes bidirectional contacts if connected)')
211
+ .requiredOption('-i, --id <id>', 'Connection ID')
212
+ .action(async (options) => {
213
+ try {
214
+ const { client } = await getHumanAuthenticatedClient();
215
+ const response = await client.post(`/v1/connections/${options.id}/revoke`);
216
+ if (response.success) {
217
+ console.log(chalk_1.default.green('✓ Connection revoked.'));
218
+ console.log(chalk_1.default.gray('ID:'), options.id);
219
+ }
220
+ else {
221
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to revoke connection');
222
+ }
223
+ }
224
+ catch (error) {
225
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
226
+ }
227
+ });
228
+ }
229
+ async function getHumansApiUrl() {
230
+ const config = await config_1.configManager.getGlobalConfig();
231
+ return config.humansApiUrl || DEFAULT_HUMANS_API_URL;
232
+ }
233
+ function formatTimestamp(ts) {
234
+ if (!ts)
235
+ return 'unknown';
236
+ if (ts._seconds) {
237
+ return new Date(ts._seconds * 1000).toISOString();
238
+ }
239
+ if (typeof ts === 'string' || typeof ts === 'number') {
240
+ return new Date(ts).toISOString();
241
+ }
242
+ return String(ts);
243
+ }
244
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"connections.js","sourceRoot":"","sources":["../../src/commands/connections.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 chalk from 'chalk';\n\nconst DEFAULT_HUMANS_API_URL = 'https://us-central1-agenticpool-humans.cloudfunctions.net/api';\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\nexport function registerConnectionCommands(program: Command): void {\n  const connections = program.command('connections').description('Agent connection management commands');\n\n  connections\n    .command('propose')\n    .description('Propose a connection to another agent')\n    .requiredOption('-t, --to-token <token>', 'Target agent public token')\n    .requiredOption('-n, --network <id>', 'Network ID')\n    .requiredOption('-e, --explanation <text>', 'Explanation for the connection')\n    .action(async (options) => {\n      try {\n        const { client, credentials } = await AuthHelper.ensureAuthenticated(options.network);\n\n        const humansApiUrl = await getHumansApiUrl();\n        const humansClient = new ApiClient(humansApiUrl);\n        humansClient.setAuthToken(credentials.jwt || '');\n\n        const response = await humansClient.post('/v1/connections', {\n          fromAgentToken: credentials.publicToken,\n          toAgentToken: options.toToken,\n          networkId: options.network,\n          fromExplanation: options.explanation\n        });\n\n        if (response.success && response.data) {\n          const conn = response.data as any;\n          console.log(chalk.green('✓ Connection proposed!'));\n          console.log(chalk.gray('ID:'), conn.id || conn.connectionId);\n          console.log(chalk.gray('To:'), options.toToken);\n          console.log(chalk.gray('Network:'), options.network);\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to propose connection');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  connections\n    .command('pending')\n    .description('List pending connection proposals for your agent')\n    .requiredOption('-n, --network <id>', 'Network ID')\n    .action(async (options) => {\n      try {\n        const { client, credentials } = await AuthHelper.ensureAuthenticated(options.network);\n\n        const humansApiUrl = await getHumansApiUrl();\n        const humansClient = new ApiClient(humansApiUrl);\n        humansClient.setAuthToken(credentials.jwt || '');\n\n        const response = await humansClient.get<any[]>('/v1/connections/pending', {\n          agentToken: credentials.publicToken\n        });\n\n        if (response.success && response.data) {\n          if (response.data.length === 0) {\n            console.log(chalk.yellow('No pending connections.'));\n            return;\n          }\n\n          console.log(chalk.green.bold(`\\nPending Connections (${response.data.length}):\\n`));\n\n          response.data.forEach((conn: any) => {\n            console.log(chalk.cyan.bold(`Connection ${conn.id}`));\n            console.log(chalk.gray('  From:'), conn.fromAgentToken);\n            console.log(chalk.gray('  Network:'), conn.networkId);\n            console.log(chalk.gray('  Status:'), conn.status);\n            if (conn.fromExplanation) {\n              console.log(chalk.gray('  Explanation:'), conn.fromExplanation);\n            }\n            if (conn.proposedAt) {\n              console.log(chalk.gray('  Proposed:'), formatTimestamp(conn.proposedAt));\n            }\n            console.log();\n          });\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to list pending connections');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  connections\n    .command('accept')\n    .description('Accept a pending connection proposal')\n    .requiredOption('-i, --id <id>', 'Connection ID')\n    .requiredOption('-n, --network <id>', 'Network ID')\n    .requiredOption('-e, --explanation <text>', 'Your explanation for accepting')\n    .action(async (options) => {\n      try {\n        const { client, credentials } = await AuthHelper.ensureAuthenticated(options.network);\n\n        const humansApiUrl = await getHumansApiUrl();\n        const humansClient = new ApiClient(humansApiUrl);\n        humansClient.setAuthToken(credentials.jwt || '');\n\n        const response = await humansClient.post(`/v1/connections/${options.id}/agent-accept`, {\n          toExplanation: options.explanation\n        });\n\n        if (response.success) {\n          console.log(chalk.green('✓ Connection accepted!'));\n          console.log(chalk.gray('ID:'), options.id);\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to accept connection');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  connections\n    .command('reject')\n    .description('Reject a pending connection proposal')\n    .requiredOption('-i, --id <id>', 'Connection ID')\n    .requiredOption('-n, --network <id>', 'Network ID')\n    .action(async (options) => {\n      try {\n        const { client, credentials } = await AuthHelper.ensureAuthenticated(options.network);\n\n        const humansApiUrl = await getHumansApiUrl();\n        const humansClient = new ApiClient(humansApiUrl);\n        humansClient.setAuthToken(credentials.jwt || '');\n\n        const response = await humansClient.post(`/v1/connections/${options.id}/reject`);\n\n        if (response.success) {\n          console.log(chalk.green('✓ Connection rejected.'));\n          console.log(chalk.gray('ID:'), options.id);\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to reject connection');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  connections\n    .command('mine')\n    .description('List all your connections (as a human)')\n    .action(async () => {\n      try {\n        const { client } = await getHumanAuthenticatedClient();\n\n        const response = await client.get<any[]>('/v1/connections/mine');\n\n        if (response.success && response.data) {\n          if (response.data.length === 0) {\n            console.log(chalk.yellow('No connections found.'));\n            return;\n          }\n\n          console.log(chalk.green.bold(`\\nYour Connections (${response.data.length}):\\n`));\n\n          response.data.forEach((conn: any) => {\n            console.log(chalk.cyan.bold(`Connection ${conn.id}`));\n            console.log(chalk.gray('  From:'), conn.fromAgentToken);\n            console.log(chalk.gray('  To:'), conn.toAgentToken);\n            console.log(chalk.gray('  Network:'), conn.networkId);\n            console.log(chalk.gray('  Status:'), conn.status);\n            if (conn.fromExplanation) {\n              console.log(chalk.gray('  From explanation:'), conn.fromExplanation);\n            }\n            if (conn.toExplanation) {\n              console.log(chalk.gray('  To explanation:'), conn.toExplanation);\n            }\n            console.log();\n          });\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to list connections');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  connections\n    .command('human-accept')\n    .description('Accept a connection as a human (approves the contact relationship)')\n    .requiredOption('-i, --id <id>', 'Connection ID')\n    .action(async (options) => {\n      try {\n        const { client } = await getHumanAuthenticatedClient();\n\n        const response = await client.post(`/v1/connections/${options.id}/human-accept`);\n\n        if (response.success) {\n          console.log(chalk.green('✓ Connection accepted as human!'));\n          console.log(chalk.gray('ID:'), options.id);\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to accept connection');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  connections\n    .command('revoke')\n    .description('Revoke a connection (deletes bidirectional contacts if connected)')\n    .requiredOption('-i, --id <id>', 'Connection ID')\n    .action(async (options) => {\n      try {\n        const { client } = await getHumanAuthenticatedClient();\n\n        const response = await client.post(`/v1/connections/${options.id}/revoke`);\n\n        if (response.success) {\n          console.log(chalk.green('✓ Connection revoked.'));\n          console.log(chalk.gray('ID:'), options.id);\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to revoke connection');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n}\n\nasync function getHumansApiUrl(): Promise<string> {\n  const config = await configManager.getGlobalConfig();\n  return (config as any).humansApiUrl || DEFAULT_HUMANS_API_URL;\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,2 @@
1
+ import { Command } from 'commander';
2
+ export declare function registerContactCommands(program: Command): void;
@@ -0,0 +1,205 @@
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.registerContactCommands = registerContactCommands;
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 registerContactCommands(program) {
12
+ const contacts = program.command('contacts').description('Contact management commands');
13
+ contacts
14
+ .command('list')
15
+ .description('List your contacts')
16
+ .action(async () => {
17
+ try {
18
+ const { client } = await getHumanAuthenticatedClient();
19
+ const response = await client.get('/v1/contacts');
20
+ if (response.success && response.data) {
21
+ if (response.data.length === 0) {
22
+ console.log(chalk_1.default.yellow('No contacts yet.'));
23
+ return;
24
+ }
25
+ console.log(chalk_1.default.green.bold(`\nYour Contacts (${response.data.length}):\n`));
26
+ response.data.forEach((contact) => {
27
+ console.log(chalk_1.default.cyan.bold(contact.contactDisplayName || contact.contactUid));
28
+ console.log(chalk_1.default.gray(' UID:'), contact.contactUid);
29
+ if (contact.contactEmail) {
30
+ console.log(chalk_1.default.gray(' Email:'), contact.contactEmail);
31
+ }
32
+ if (contact.contactPhone) {
33
+ console.log(chalk_1.default.gray(' Phone:'), contact.contactPhone);
34
+ }
35
+ if (contact.contactTelegram) {
36
+ console.log(chalk_1.default.gray(' Telegram:'), contact.contactTelegram);
37
+ }
38
+ if (contact.linkedIdentities && contact.linkedIdentities.length > 0) {
39
+ console.log(chalk_1.default.gray(' Networks:'));
40
+ contact.linkedIdentities.forEach((id) => {
41
+ console.log(chalk_1.default.gray(' -'), `${id.networkId} (${id.publicToken})`);
42
+ if (id.agentDescription) {
43
+ console.log(chalk_1.default.gray(' '), id.agentDescription);
44
+ }
45
+ });
46
+ }
47
+ console.log(chalk_1.default.gray(' Status:'), contact.status);
48
+ console.log();
49
+ });
50
+ }
51
+ else {
52
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to list contacts');
53
+ }
54
+ }
55
+ catch (error) {
56
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
57
+ }
58
+ });
59
+ contacts
60
+ .command('show')
61
+ .description('Show full details of a contact')
62
+ .requiredOption('-u, --uid <uid>', 'Contact user UID')
63
+ .action(async (options) => {
64
+ try {
65
+ const { client } = await getHumanAuthenticatedClient();
66
+ const response = await client.get(`/v1/contacts/${options.uid}`);
67
+ if (response.success && response.data) {
68
+ const contact = response.data;
69
+ console.log(chalk_1.default.cyan.bold(`\n${contact.contactDisplayName || contact.contactUid}\n`));
70
+ console.log(chalk_1.default.gray('UID:'), contact.contactUid);
71
+ if (contact.contactEmail) {
72
+ console.log(chalk_1.default.gray('Email:'), contact.contactEmail);
73
+ }
74
+ if (contact.contactPhone) {
75
+ console.log(chalk_1.default.gray('Phone:'), contact.contactPhone);
76
+ }
77
+ if (contact.contactTelegram) {
78
+ console.log(chalk_1.default.gray('Telegram:'), contact.contactTelegram);
79
+ }
80
+ if (contact.contactPhotoUrl) {
81
+ console.log(chalk_1.default.gray('Photo:'), contact.contactPhotoUrl);
82
+ }
83
+ if (contact.notes) {
84
+ console.log(chalk_1.default.gray('\nNotes:'), contact.notes);
85
+ }
86
+ console.log(chalk_1.default.gray('Status:'), contact.status);
87
+ if (contact.connectionId) {
88
+ console.log(chalk_1.default.gray('Connection:'), contact.connectionId);
89
+ }
90
+ if (contact.linkedIdentities && contact.linkedIdentities.length > 0) {
91
+ console.log(chalk_1.default.yellow.bold('\nLinked Identities:\n'));
92
+ contact.linkedIdentities.forEach((id) => {
93
+ console.log(chalk_1.default.cyan(` ${id.networkId}`));
94
+ console.log(chalk_1.default.gray(' Token:'), id.publicToken);
95
+ if (id.agentDescription) {
96
+ console.log(chalk_1.default.gray(' Description:'), id.agentDescription);
97
+ }
98
+ console.log();
99
+ });
100
+ }
101
+ if (contact.createdAt) {
102
+ console.log(chalk_1.default.gray('Added:'), formatTimestamp(contact.createdAt));
103
+ }
104
+ }
105
+ else {
106
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Contact not found');
107
+ }
108
+ }
109
+ catch (error) {
110
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
111
+ }
112
+ });
113
+ contacts
114
+ .command('update')
115
+ .description('Update contact notes')
116
+ .requiredOption('-u, --uid <uid>', 'Contact user UID')
117
+ .requiredOption('-n, --notes <text>', 'Notes about this contact')
118
+ .action(async (options) => {
119
+ try {
120
+ const { client } = await getHumanAuthenticatedClient();
121
+ const response = await client.put(`/v1/contacts/${options.uid}`, {
122
+ notes: options.notes
123
+ });
124
+ if (response.success) {
125
+ console.log(chalk_1.default.green('✓ Contact updated!'));
126
+ console.log(chalk_1.default.gray('UID:'), options.uid);
127
+ }
128
+ else {
129
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to update contact');
130
+ }
131
+ }
132
+ catch (error) {
133
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
134
+ }
135
+ });
136
+ contacts
137
+ .command('block')
138
+ .description('Block a contact (removes bidirectional contacts)')
139
+ .requiredOption('-u, --uid <uid>', 'Contact user UID')
140
+ .action(async (options) => {
141
+ try {
142
+ const { client } = await getHumanAuthenticatedClient();
143
+ const response = await client.delete(`/v1/contacts/${options.uid}`);
144
+ if (response.success) {
145
+ console.log(chalk_1.default.green('✓ Contact blocked and removed.'));
146
+ console.log(chalk_1.default.gray('UID:'), options.uid);
147
+ }
148
+ else {
149
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to block contact');
150
+ }
151
+ }
152
+ catch (error) {
153
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
154
+ }
155
+ });
156
+ contacts
157
+ .command('link-identity')
158
+ .description('Link a network identity to a contact')
159
+ .requiredOption('-u, --uid <uid>', 'Contact user UID')
160
+ .requiredOption('-i, --identity-id <id>', 'Identity ID to link')
161
+ .action(async (options) => {
162
+ try {
163
+ const { client } = await getHumanAuthenticatedClient();
164
+ const response = await client.post(`/v1/contacts/${options.uid}/link-identity`, {
165
+ identityId: options.identityId
166
+ });
167
+ if (response.success) {
168
+ console.log(chalk_1.default.green('✓ Identity linked to contact!'));
169
+ console.log(chalk_1.default.gray('Contact UID:'), options.uid);
170
+ console.log(chalk_1.default.gray('Identity ID:'), options.identityId);
171
+ }
172
+ else {
173
+ console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to link identity');
174
+ }
175
+ }
176
+ catch (error) {
177
+ console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
178
+ }
179
+ });
180
+ }
181
+ async function getHumanAuthenticatedClient() {
182
+ const config = await config_1.configManager.getGlobalConfig();
183
+ if (!config.humanJwt || !config.humanUid) {
184
+ throw new Error('Not authenticated as a human. Please log in at humans.agenticpool.net first.');
185
+ }
186
+ if (config.humanJwtExpiresAt && Date.now() > config.humanJwtExpiresAt) {
187
+ throw new Error('Human session expired. Please log in again at humans.agenticpool.net.');
188
+ }
189
+ const humansApiUrl = config.humansApiUrl || DEFAULT_HUMANS_API_URL;
190
+ const client = new api_1.ApiClient(humansApiUrl);
191
+ client.setAuthToken(config.humanJwt);
192
+ return { client, humanUid: config.humanUid };
193
+ }
194
+ function formatTimestamp(ts) {
195
+ if (!ts)
196
+ return 'unknown';
197
+ if (ts._seconds) {
198
+ return new Date(ts._seconds * 1000).toISOString();
199
+ }
200
+ if (typeof ts === 'string' || typeof ts === 'number') {
201
+ return new Date(ts).toISOString();
202
+ }
203
+ return String(ts);
204
+ }
205
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"contacts.js","sourceRoot":"","sources":["../../src/commands/contacts.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 registerContactCommands(program: Command): void {\n  const contacts = program.command('contacts').description('Contact management commands');\n\n  contacts\n    .command('list')\n    .description('List your contacts')\n    .action(async () => {\n      try {\n        const { client } = await getHumanAuthenticatedClient();\n\n        const response = await client.get<any[]>('/v1/contacts');\n\n        if (response.success && response.data) {\n          if (response.data.length === 0) {\n            console.log(chalk.yellow('No contacts yet.'));\n            return;\n          }\n\n          console.log(chalk.green.bold(`\\nYour Contacts (${response.data.length}):\\n`));\n\n          response.data.forEach((contact: any) => {\n            console.log(chalk.cyan.bold(contact.contactDisplayName || contact.contactUid));\n            console.log(chalk.gray('  UID:'), contact.contactUid);\n            if (contact.contactEmail) {\n              console.log(chalk.gray('  Email:'), contact.contactEmail);\n            }\n            if (contact.contactPhone) {\n              console.log(chalk.gray('  Phone:'), contact.contactPhone);\n            }\n            if (contact.contactTelegram) {\n              console.log(chalk.gray('  Telegram:'), contact.contactTelegram);\n            }\n\n            if (contact.linkedIdentities && contact.linkedIdentities.length > 0) {\n              console.log(chalk.gray('  Networks:'));\n              contact.linkedIdentities.forEach((id: any) => {\n                console.log(chalk.gray('    -'), `${id.networkId} (${id.publicToken})`);\n                if (id.agentDescription) {\n                  console.log(chalk.gray('      '), id.agentDescription);\n                }\n              });\n            }\n\n            console.log(chalk.gray('  Status:'), contact.status);\n            console.log();\n          });\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to list contacts');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  contacts\n    .command('show')\n    .description('Show full details of a contact')\n    .requiredOption('-u, --uid <uid>', 'Contact user UID')\n    .action(async (options) => {\n      try {\n        const { client } = await getHumanAuthenticatedClient();\n\n        const response = await client.get<any>(`/v1/contacts/${options.uid}`);\n\n        if (response.success && response.data) {\n          const contact = response.data;\n          console.log(chalk.cyan.bold(`\\n${contact.contactDisplayName || contact.contactUid}\\n`));\n          console.log(chalk.gray('UID:'), contact.contactUid);\n\n          if (contact.contactEmail) {\n            console.log(chalk.gray('Email:'), contact.contactEmail);\n          }\n          if (contact.contactPhone) {\n            console.log(chalk.gray('Phone:'), contact.contactPhone);\n          }\n          if (contact.contactTelegram) {\n            console.log(chalk.gray('Telegram:'), contact.contactTelegram);\n          }\n          if (contact.contactPhotoUrl) {\n            console.log(chalk.gray('Photo:'), contact.contactPhotoUrl);\n          }\n\n          if (contact.notes) {\n            console.log(chalk.gray('\\nNotes:'), contact.notes);\n          }\n\n          console.log(chalk.gray('Status:'), contact.status);\n\n          if (contact.connectionId) {\n            console.log(chalk.gray('Connection:'), contact.connectionId);\n          }\n\n          if (contact.linkedIdentities && contact.linkedIdentities.length > 0) {\n            console.log(chalk.yellow.bold('\\nLinked Identities:\\n'));\n            contact.linkedIdentities.forEach((id: any) => {\n              console.log(chalk.cyan(`  ${id.networkId}`));\n              console.log(chalk.gray('    Token:'), id.publicToken);\n              if (id.agentDescription) {\n                console.log(chalk.gray('    Description:'), id.agentDescription);\n              }\n              console.log();\n            });\n          }\n\n          if (contact.createdAt) {\n            console.log(chalk.gray('Added:'), formatTimestamp(contact.createdAt));\n          }\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Contact not found');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  contacts\n    .command('update')\n    .description('Update contact notes')\n    .requiredOption('-u, --uid <uid>', 'Contact user UID')\n    .requiredOption('-n, --notes <text>', 'Notes about this contact')\n    .action(async (options) => {\n      try {\n        const { client } = await getHumanAuthenticatedClient();\n\n        const response = await client.put(`/v1/contacts/${options.uid}`, {\n          notes: options.notes\n        });\n\n        if (response.success) {\n          console.log(chalk.green('✓ Contact updated!'));\n          console.log(chalk.gray('UID:'), options.uid);\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to update contact');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  contacts\n    .command('block')\n    .description('Block a contact (removes bidirectional contacts)')\n    .requiredOption('-u, --uid <uid>', 'Contact user UID')\n    .action(async (options) => {\n      try {\n        const { client } = await getHumanAuthenticatedClient();\n\n        const response = await client.delete(`/v1/contacts/${options.uid}`);\n\n        if (response.success) {\n          console.log(chalk.green('✓ Contact blocked and removed.'));\n          console.log(chalk.gray('UID:'), options.uid);\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to block contact');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  contacts\n    .command('link-identity')\n    .description('Link a network identity to a contact')\n    .requiredOption('-u, --uid <uid>', 'Contact user UID')\n    .requiredOption('-i, --identity-id <id>', 'Identity ID to link')\n    .action(async (options) => {\n      try {\n        const { client } = await getHumanAuthenticatedClient();\n\n        const response = await client.post(`/v1/contacts/${options.uid}/link-identity`, {\n          identityId: options.identityId\n        });\n\n        if (response.success) {\n          console.log(chalk.green('✓ Identity linked to contact!'));\n          console.log(chalk.gray('Contact UID:'), options.uid);\n          console.log(chalk.gray('Identity ID:'), options.identityId);\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to link 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,2 @@
1
+ import { Command } from 'commander';
2
+ export declare function registerConversationCommands(program: Command): void;