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.
- package/AGENTS.md +56 -0
- package/README.md +42 -0
- package/agenticpool-cli-1.0.0.tgz +0 -0
- package/dist/api/ApiClient.d.ts +24 -0
- package/dist/api/ApiClient.js +79 -0
- package/dist/api/index.d.ts +1 -0
- package/dist/api/index.js +6 -0
- package/dist/auth/AuthHelper.d.ts +16 -0
- package/dist/auth/AuthHelper.js +137 -0
- package/dist/commands/auth.d.ts +2 -0
- package/dist/commands/auth.js +166 -0
- package/dist/commands/config.d.ts +2 -0
- package/dist/commands/config.js +51 -0
- package/dist/commands/connections.d.ts +2 -0
- package/dist/commands/connections.js +244 -0
- package/dist/commands/contacts.d.ts +2 -0
- package/dist/commands/contacts.js +205 -0
- package/dist/commands/conversations.d.ts +2 -0
- package/dist/commands/conversations.js +209 -0
- package/dist/commands/humans.d.ts +2 -0
- package/dist/commands/humans.js +129 -0
- package/dist/commands/identities.d.ts +2 -0
- package/dist/commands/identities.js +120 -0
- package/dist/commands/index.d.ts +10 -0
- package/dist/commands/index.js +24 -0
- package/dist/commands/messages.d.ts +2 -0
- package/dist/commands/messages.js +72 -0
- package/dist/commands/networks.d.ts +2 -0
- package/dist/commands/networks.js +237 -0
- package/dist/commands/profile.d.ts +2 -0
- package/dist/commands/profile.js +204 -0
- package/dist/config/ConfigManager.d.ts +31 -0
- package/dist/config/ConfigManager.js +135 -0
- package/dist/config/index.d.ts +1 -0
- package/dist/config/index.js +7 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +22 -0
- package/dist/limits/LimitsManager.d.ts +23 -0
- package/dist/limits/LimitsManager.js +99 -0
- package/jest.config.js +23 -0
- package/package.json +47 -0
- package/src/api/ApiClient.ts +100 -0
- package/src/api/index.ts +1 -0
- package/src/auth/AuthHelper.ts +123 -0
- package/src/commands/auth.ts +169 -0
- package/src/commands/config.ts +51 -0
- package/src/commands/connections.ts +261 -0
- package/src/commands/contacts.ts +221 -0
- package/src/commands/conversations.ts +218 -0
- package/src/commands/humans.ts +124 -0
- package/src/commands/identities.ts +126 -0
- package/src/commands/index.ts +10 -0
- package/src/commands/messages.ts +72 -0
- package/src/commands/networks.ts +245 -0
- package/src/commands/profile.ts +184 -0
- package/src/config/ConfigManager.ts +137 -0
- package/src/config/index.ts +1 -0
- package/src/index.ts +35 -0
- package/src/limits/LimitsManager.ts +76 -0
- package/tests/ApiClient.test.ts +99 -0
- package/tests/ConfigManager.test.ts +41 -0
- package/tests/LimitsManager.test.ts +169 -0
- package/tests/__mocks__/@toon-format/toon.ts +27 -0
- package/tests/integration/cleanup.ts +187 -0
- package/tests/integration/e2e-cli.test.ts +465 -0
- package/tests/integration/e2e.test.ts +480 -0
- package/tests/integration/run-e2e.sh +44 -0
- package/tests/integration/setup.ts +188 -0
- 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,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,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"]}
|