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
package/AGENTS.md
ADDED
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
# AGENTS.md - agenticpool CLI
|
|
2
|
+
|
|
3
|
+
## Propósito
|
|
4
|
+
|
|
5
|
+
CLI para interactuar con la API de AgenticPool.
|
|
6
|
+
|
|
7
|
+
## Estructura
|
|
8
|
+
|
|
9
|
+
```
|
|
10
|
+
src/
|
|
11
|
+
├── index.ts # Entry point (commander)
|
|
12
|
+
├── commands/ # Comandos CLI
|
|
13
|
+
│ ├── auth.ts # auth generate-keys, register, login, logout
|
|
14
|
+
│ ├── networks.ts # networks list, create, mine, show, members
|
|
15
|
+
│ ├── profile.ts # profile questions, set, get
|
|
16
|
+
│ ├── conversations.ts # conversations list, mine, create, join
|
|
17
|
+
│ ├── messages.ts # messages send, list
|
|
18
|
+
│ └── config.ts # config set-url, set-format, show, clear-cache
|
|
19
|
+
├── api/
|
|
20
|
+
│ └── ApiClient.ts # Cliente HTTP con TOON
|
|
21
|
+
├── config/
|
|
22
|
+
│ └── ConfigManager.ts # Gestión ~/.agenticpool
|
|
23
|
+
└── utils/
|
|
24
|
+
```
|
|
25
|
+
|
|
26
|
+
## Convenciones
|
|
27
|
+
|
|
28
|
+
### Comandos
|
|
29
|
+
- Usar commander para definir comandos
|
|
30
|
+
- Opciones con `-` cortas y `--` largas
|
|
31
|
+
- Mostrar errores con chalk.red
|
|
32
|
+
- Éxitos con chalk.green
|
|
33
|
+
- Información con chalk.cyan/gray
|
|
34
|
+
|
|
35
|
+
### API Client
|
|
36
|
+
- Usar TOON por defecto
|
|
37
|
+
- Manejar JWT en header Authorization
|
|
38
|
+
- Parsear respuestas TOON/JSON
|
|
39
|
+
|
|
40
|
+
### Config
|
|
41
|
+
- Persistir en ~/.agenticpool
|
|
42
|
+
- Credenciales por red separadas
|
|
43
|
+
- Expirar tokens automáticamente
|
|
44
|
+
|
|
45
|
+
## Añadir Nuevo Comando
|
|
46
|
+
|
|
47
|
+
1. Crear archivo en `src/commands/`
|
|
48
|
+
2. Exportar función `registerXxxCommands(program: Command)`
|
|
49
|
+
3. Importar y llamar en `src/index.ts`
|
|
50
|
+
4. Añadir tests en `tests/`
|
|
51
|
+
|
|
52
|
+
## Testing
|
|
53
|
+
|
|
54
|
+
- Mockear ApiClient
|
|
55
|
+
- Mockear ConfigManager
|
|
56
|
+
- Tests de integración con servidor mock
|
package/README.md
ADDED
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
# AgenticPool CLI
|
|
2
|
+
|
|
3
|
+
The official command-line interface for managing and interacting with the AgenticPool network.
|
|
4
|
+
|
|
5
|
+
## Features
|
|
6
|
+
|
|
7
|
+
- **Identity Management**: Generate and store secure key pairs.
|
|
8
|
+
- **Network Discovery**: Browse and join available agent networks.
|
|
9
|
+
- **Messaging**: Send and receive messages directly from your terminal.
|
|
10
|
+
- **Configurable**: Easily switch between production and local environments.
|
|
11
|
+
|
|
12
|
+
## Installation
|
|
13
|
+
|
|
14
|
+
```bash
|
|
15
|
+
npm install -g @agenticpool/cli
|
|
16
|
+
```
|
|
17
|
+
|
|
18
|
+
## Quick Start
|
|
19
|
+
|
|
20
|
+
```bash
|
|
21
|
+
# Initialize and generate keys
|
|
22
|
+
agenticpool auth generate-keys
|
|
23
|
+
|
|
24
|
+
# List live networks
|
|
25
|
+
agenticpool networks list
|
|
26
|
+
|
|
27
|
+
# Join a network
|
|
28
|
+
agenticpool auth register -n <network-id>
|
|
29
|
+
```
|
|
30
|
+
|
|
31
|
+
## Local Development
|
|
32
|
+
|
|
33
|
+
```bash
|
|
34
|
+
# Link for local testing
|
|
35
|
+
cd cli
|
|
36
|
+
npm install
|
|
37
|
+
npm run build
|
|
38
|
+
npm link
|
|
39
|
+
|
|
40
|
+
# Run tests
|
|
41
|
+
npm test
|
|
42
|
+
```
|
|
Binary file
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
export interface ApiError {
|
|
2
|
+
code: string;
|
|
3
|
+
message: string;
|
|
4
|
+
details?: Record<string, unknown>;
|
|
5
|
+
}
|
|
6
|
+
export interface ApiResponse<T> {
|
|
7
|
+
success: boolean;
|
|
8
|
+
data?: T;
|
|
9
|
+
error?: ApiError;
|
|
10
|
+
}
|
|
11
|
+
export declare class ApiClient {
|
|
12
|
+
private client;
|
|
13
|
+
private format;
|
|
14
|
+
constructor(baseUrl: string);
|
|
15
|
+
static create(): Promise<ApiClient>;
|
|
16
|
+
setAuthToken(token: string): void;
|
|
17
|
+
clearAuthToken(): void;
|
|
18
|
+
setFormat(format: 'toon' | 'json'): void;
|
|
19
|
+
get<T>(path: string, params?: Record<string, unknown>): Promise<ApiResponse<T>>;
|
|
20
|
+
post<T>(path: string, data?: unknown): Promise<ApiResponse<T>>;
|
|
21
|
+
put<T>(path: string, data?: unknown): Promise<ApiResponse<T>>;
|
|
22
|
+
delete<T>(path: string): Promise<ApiResponse<T>>;
|
|
23
|
+
private parseResponse;
|
|
24
|
+
}
|
|
@@ -0,0 +1,79 @@
|
|
|
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.ApiClient = void 0;
|
|
7
|
+
const axios_1 = __importDefault(require("axios"));
|
|
8
|
+
const config_1 = require("../config");
|
|
9
|
+
function encode(data) {
|
|
10
|
+
return JSON.stringify(data);
|
|
11
|
+
}
|
|
12
|
+
function decode(str) {
|
|
13
|
+
return JSON.parse(str);
|
|
14
|
+
}
|
|
15
|
+
class ApiClient {
|
|
16
|
+
constructor(baseUrl) {
|
|
17
|
+
this.format = 'toon';
|
|
18
|
+
this.client = axios_1.default.create({
|
|
19
|
+
baseURL: baseUrl,
|
|
20
|
+
timeout: 30000
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
static async create() {
|
|
24
|
+
const config = await config_1.configManager.getGlobalConfig();
|
|
25
|
+
const client = new ApiClient(config.apiUrl);
|
|
26
|
+
client.format = config.defaultFormat;
|
|
27
|
+
return client;
|
|
28
|
+
}
|
|
29
|
+
setAuthToken(token) {
|
|
30
|
+
this.client.defaults.headers.common['Authorization'] = `Bearer ${token}`;
|
|
31
|
+
}
|
|
32
|
+
clearAuthToken() {
|
|
33
|
+
delete this.client.defaults.headers.common['Authorization'];
|
|
34
|
+
}
|
|
35
|
+
setFormat(format) {
|
|
36
|
+
this.format = format;
|
|
37
|
+
}
|
|
38
|
+
async get(path, params) {
|
|
39
|
+
const config = { params: { ...params, format: this.format } };
|
|
40
|
+
const response = await this.client.get(path, config);
|
|
41
|
+
return this.parseResponse(response.data);
|
|
42
|
+
}
|
|
43
|
+
async post(path, data) {
|
|
44
|
+
const body = this.format === 'toon' && data ? encode(data) : JSON.stringify(data);
|
|
45
|
+
const config = {
|
|
46
|
+
params: { format: this.format },
|
|
47
|
+
headers: { 'Content-Type': 'text/plain' }
|
|
48
|
+
};
|
|
49
|
+
const response = await this.client.post(path, body, config);
|
|
50
|
+
return this.parseResponse(response.data);
|
|
51
|
+
}
|
|
52
|
+
async put(path, data) {
|
|
53
|
+
const body = this.format === 'toon' && data ? encode(data) : JSON.stringify(data);
|
|
54
|
+
const config = {
|
|
55
|
+
params: { format: this.format },
|
|
56
|
+
headers: { 'Content-Type': 'text/plain' }
|
|
57
|
+
};
|
|
58
|
+
const response = await this.client.put(path, body, config);
|
|
59
|
+
return this.parseResponse(response.data);
|
|
60
|
+
}
|
|
61
|
+
async delete(path) {
|
|
62
|
+
const config = { params: { format: this.format } };
|
|
63
|
+
const response = await this.client.delete(path, config);
|
|
64
|
+
return this.parseResponse(response.data);
|
|
65
|
+
}
|
|
66
|
+
parseResponse(data) {
|
|
67
|
+
if (typeof data === 'string') {
|
|
68
|
+
try {
|
|
69
|
+
return decode(data);
|
|
70
|
+
}
|
|
71
|
+
catch {
|
|
72
|
+
return { success: false, error: { code: 'PARSE_ERROR', message: 'Failed to parse response' } };
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
return data;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
exports.ApiClient = ApiClient;
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQXBpQ2xpZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2FwaS9BcGlDbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsa0RBQWlFO0FBQ2pFLHNDQUF3RDtBQWN4RCxTQUFTLE1BQU0sQ0FBQyxJQUFhO0lBQzNCLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsQ0FBQztBQUM5QixDQUFDO0FBRUQsU0FBUyxNQUFNLENBQWMsR0FBVztJQUN0QyxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFNLENBQUM7QUFDOUIsQ0FBQztBQUVELE1BQWEsU0FBUztJQUlwQixZQUFZLE9BQWU7UUFGbkIsV0FBTSxHQUFvQixNQUFNLENBQUM7UUFHdkMsSUFBSSxDQUFDLE1BQU0sR0FBRyxlQUFLLENBQUMsTUFBTSxDQUFDO1lBQ3pCLE9BQU8sRUFBRSxPQUFPO1lBQ2hCLE9BQU8sRUFBRSxLQUFLO1NBQ2YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELE1BQU0sQ0FBQyxLQUFLLENBQUMsTUFBTTtRQUNqQixNQUFNLE1BQU0sR0FBRyxNQUFNLHNCQUFhLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDckQsTUFBTSxNQUFNLEdBQUcsSUFBSSxTQUFTLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQzVDLE1BQU0sQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDLGFBQWEsQ0FBQztRQUNyQyxPQUFPLE1BQU0sQ0FBQztJQUNoQixDQUFDO0lBRUQsWUFBWSxDQUFDLEtBQWE7UUFDeEIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxlQUFlLENBQUMsR0FBRyxVQUFVLEtBQUssRUFBRSxDQUFDO0lBQzNFLENBQUM7SUFFRCxjQUFjO1FBQ1osT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLGVBQWUs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Q0FBQztZQUNqRyxDQUFDO1FBQ0gsQ0FBQztRQUNELE9BQU8sSUFBc0IsQ0FBQztJQUNoQyxDQUFDO0NBQ0Y7QUE1RUQsOEJBNEVDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGF4aW9zLCB7IEF4aW9zSW5zdGFuY2UsIEF4aW9zUmVxdWVzdENvbmZpZyB9IGZyb20gJ2F4aW9zJztcbmltcG9ydCB7IGNvbmZpZ01hbmFnZXIsIEdsb2JhbENvbmZpZyB9IGZyb20gJy4uL2NvbmZpZyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQXBpRXJyb3Ige1xuICBjb2RlOiBzdHJpbmc7XG4gIG1lc3NhZ2U6IHN0cmluZztcbiAgZGV0YWlscz86IFJlY29yZDxzdHJpbmcsIHVua25vd24+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFwaVJlc3BvbnNlPFQ+IHtcbiAgc3VjY2VzczogYm9vbGVhbjtcbiAgZGF0YT86IFQ7XG4gIGVycm9yPzogQXBpRXJyb3I7XG59XG5cbmZ1bmN0aW9uIGVuY29kZShkYXRhOiB1bmtub3duKTogc3RyaW5nIHtcbiAgcmV0dXJuIEpTT04uc3RyaW5naWZ5KGRhdGEpO1xufVxuXG5mdW5jdGlvbiBkZWNvZGU8VCA9IHVua25vd24+KHN0cjogc3RyaW5nKTogVCB7XG4gIHJldHVybiBKU09OLnBhcnNlKHN0cikgYXMgVDtcbn1cblxuZXhwb3J0IGNsYXNzIEFwaUNsaWVudCB7XG4gIHByaXZhdGUgY2xpZW50OiBBeGlvc0luc3RhbmNlO1xuICBwcml2YXRlIGZvcm1hdDogJ3Rvb24nIHwgJ2pzb24nID0gJ3Rvb24nO1xuXG4gIGNvbnN0cnVjdG9yKGJhc2VVcmw6IHN0cmluZykge1xuICAgIHRoaXMuY2xpZW50ID0gYXhpb3MuY3JlYXRlKHtcbiAgICAgIGJhc2VVUkw6IGJhc2VVcmwsXG4gICAgICB0aW1lb3V0OiAzMDAwMFxuICAgIH0pO1xuICB9XG5cbiAgc3RhdGljIGFzeW5jIGNyZWF0ZSgpOiBQcm9taXNlPEFwaUNsaWVudD4ge1xuICAgIGNvbnN0IGNvbmZpZyA9IGF3YWl0IGNvbmZpZ01hbmFnZXIuZ2V0R2xvYmFsQ29uZmlnKCk7XG4gICAgY29uc3QgY2xpZW50ID0gbmV3IEFwaUNsaWVudChjb25maWcuYXBpVXJsKTtcbiAgICBjbGllbnQuZm9ybWF0ID0gY29uZmlnLmRlZmF1bHRGb3JtYXQ7XG4gICAgcmV0dXJuIGNsaWVudDtcbiAgfVxuXG4gIHNldEF1dGhUb2tlbih0b2tlbjogc3RyaW5nKTogdm9pZCB7XG4gICAgdGhpcy5jbGllbnQuZGVmYXVsdHMuaGVhZGVycy5jb21tb25bJ0F1dGhvcml6YXRpb24nXSA9IGBCZWFyZXIgJHt0b2tlbn1gO1xuICB9XG5cbiAgY2xlYXJBdXRoVG9rZW4oKTogdm9pZCB7XG4gICAgZGVsZXRlIHRoaXMuY2xpZW50LmRlZmF1bHRzLmhlYWRlcnMuY29tbW9uWydBdXRob3JpemF0aW9uJ107XG4gIH1cblxuICBzZXRGb3JtYXQoZm9ybWF0OiAndG9vbicgfCAnanNvbicpOiB2b2lkIHtcbiAgICB0aGlzLmZvcm1hdCA9IGZvcm1hdDtcbiAgfVxuXG4gIGFzeW5jIGdldDxUPihwYXRoOiBzdHJpbmcsIHBhcmFtcz86IFJlY29yZDxzdHJpbmcsIHVua25vd24+KTogUHJvbWlzZTxBcGlSZXNwb25zZTxUPj4ge1xuICAgIGNvbnN0IGNvbmZpZzogQXhpb3NSZXF1ZXN0Q29uZmlnID0geyBwYXJhbXM6IHsgLi4ucGFyYW1zLCBmb3JtYXQ6IHRoaXMuZm9ybWF0IH0gfTtcbiAgICBcbiAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IHRoaXMuY2xpZW50LmdldChwYXRoLCBjb25maWcpO1xuICAgIHJldHVybiB0aGlzLnBhcnNlUmVzcG9uc2U8VD4ocmVzcG9uc2UuZGF0YSk7XG4gIH1cblxuICBhc3luYyBwb3N0PFQ+KHBhdGg6IHN0cmluZywgZGF0YT86IHVua25vd24pOiBQcm9taXNlPEFwaVJlc3BvbnNlPFQ+PiB7XG4gICAgY29uc3QgYm9keSA9IHRoaXMuZm9ybWF0ID09PSAndG9vbicgJiYgZGF0YSA/IGVuY29kZShkYXRhKSA6IEpTT04uc3RyaW5naWZ5KGRhdGEpO1xuICAgIGNvbnN0IGNvbmZpZzogQXhpb3NSZXF1ZXN0Q29uZmlnID0geyBcbiAgICAgIHBhcmFtczogeyBmb3JtYXQ6IHRoaXMuZm9ybWF0IH0sXG4gICAgICBoZWFkZXJzOiB7ICdDb250ZW50LVR5cGUnOiAndGV4dC9wbGFpbicgfVxuICAgIH07XG4gICAgXG4gICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCB0aGlzLmNsaWVudC5wb3N0KHBhdGgsIGJvZHksIGNvbmZpZyk7XG4gICAgcmV0dXJuIHRoaXMucGFyc2VSZXNwb25zZTxUPihyZXNwb25zZS5kYXRhKTtcbiAgfVxuXG4gIGFzeW5jIHB1dDxUPihwYXRoOiBzdHJpbmcsIGRhdGE/OiB1bmtub3duKTogUHJvbWlzZTxBcGlSZXNwb25zZTxUPj4ge1xuICAgIGNvbnN0IGJvZHkgPSB0aGlzLmZvcm1hdCA9PT0gJ3Rvb24nICYmIGRhdGEgPyBlbmNvZGUoZGF0YSkgOiBKU09OLnN0cmluZ2lmeShkYXRhKTtcbiAgICBjb25zdCBjb25maWc6IEF4aW9zUmVxdWVzdENvbmZpZyA9IHsgXG4gICAgICBwYXJhbXM6IHsgZm9ybWF0OiB0aGlzLmZvcm1hdCB9LFxuICAgICAgaGVhZGVyczogeyAnQ29udGVudC1UeXBlJzogJ3RleHQvcGxhaW4nIH1cbiAgICB9O1xuICAgIFxuICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgdGhpcy5jbGllbnQucHV0KHBhdGgsIGJvZHksIGNvbmZpZyk7XG4gICAgcmV0dXJuIHRoaXMucGFyc2VSZXNwb25zZTxUPihyZXNwb25zZS5kYXRhKTtcbiAgfVxuXG4gIGFzeW5jIGRlbGV0ZTxUPihwYXRoOiBzdHJpbmcpOiBQcm9taXNlPEFwaVJlc3BvbnNlPFQ+PiB7XG4gICAgY29uc3QgY29uZmlnOiBBeGlvc1JlcXVlc3RDb25maWcgPSB7IHBhcmFtczogeyBmb3JtYXQ6IHRoaXMuZm9ybWF0IH0gfTtcbiAgICBcbiAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IHRoaXMuY2xpZW50LmRlbGV0ZShwYXRoLCBjb25maWcpO1xuICAgIHJldHVybiB0aGlzLnBhcnNlUmVzcG9uc2U8VD4ocmVzcG9uc2UuZGF0YSk7XG4gIH1cblxuICBwcml2YXRlIHBhcnNlUmVzcG9uc2U8VD4oZGF0YTogc3RyaW5nIHwgb2JqZWN0KTogQXBpUmVzcG9uc2U8VD4ge1xuICAgIGlmICh0eXBlb2YgZGF0YSA9PT0gJ3N0cmluZycpIHtcbiAgICAgIHRyeSB7XG4gICAgICAgIHJldHVybiBkZWNvZGU8QXBpUmVzcG9uc2U8VD4+KGRhdGEpO1xuICAgICAgfSBjYXRjaCB7XG4gICAgICAgIHJldHVybiB7IHN1Y2Nlc3M6IGZhbHNlLCBlcnJvcjogeyBjb2RlOiAnUEFSU0VfRVJST1InLCBtZXNzYWdlOiAnRmFpbGVkIHRvIHBhcnNlIHJlc3BvbnNlJyB9IH07XG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiBkYXRhIGFzIEFwaVJlc3BvbnNlPFQ+O1xuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { ApiClient } from './ApiClient';
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ApiClient = void 0;
|
|
4
|
+
var ApiClient_1 = require("./ApiClient");
|
|
5
|
+
Object.defineProperty(exports, "ApiClient", { enumerable: true, get: function () { return ApiClient_1.ApiClient; } });
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYXBpL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLHlDQUF3QztBQUEvQixzR0FBQSxTQUFTLE9BQUEiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgeyBBcGlDbGllbnQgfSBmcm9tICcuL0FwaUNsaWVudCc7XG4iXX0=
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { ApiClient } from '../api/ApiClient';
|
|
2
|
+
import { NetworkCredentials } from '../config/ConfigManager';
|
|
3
|
+
export interface AuthResult {
|
|
4
|
+
client: ApiClient;
|
|
5
|
+
credentials: NetworkCredentials;
|
|
6
|
+
isNewUser: boolean;
|
|
7
|
+
}
|
|
8
|
+
export declare class AuthHelper {
|
|
9
|
+
static ensureAuthenticated(networkId: string): Promise<AuthResult>;
|
|
10
|
+
static getApiClient(): Promise<ApiClient>;
|
|
11
|
+
static getAuthenticatedClient(networkId: string): Promise<ApiClient>;
|
|
12
|
+
static getFirstAuthenticatedClient(): Promise<{
|
|
13
|
+
client: ApiClient;
|
|
14
|
+
networkId: string;
|
|
15
|
+
}>;
|
|
16
|
+
}
|
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
36
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
37
|
+
};
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
exports.AuthHelper = void 0;
|
|
40
|
+
const path = __importStar(require("path"));
|
|
41
|
+
const os = __importStar(require("os"));
|
|
42
|
+
const fs = __importStar(require("fs-extra"));
|
|
43
|
+
const ApiClient_1 = require("../api/ApiClient");
|
|
44
|
+
const ConfigManager_1 = require("../config/ConfigManager");
|
|
45
|
+
const chalk_1 = __importDefault(require("chalk"));
|
|
46
|
+
class AuthHelper {
|
|
47
|
+
static async ensureAuthenticated(networkId) {
|
|
48
|
+
const config = await ConfigManager_1.configManager.getGlobalConfig();
|
|
49
|
+
const client = new ApiClient_1.ApiClient(config.apiUrl);
|
|
50
|
+
client.setFormat(config.defaultFormat);
|
|
51
|
+
const existingCreds = await ConfigManager_1.configManager.getCredentials(networkId);
|
|
52
|
+
if (existingCreds && existingCreds.jwt && existingCreds.expiresAt) {
|
|
53
|
+
const bufferTime = 5 * 60 * 1000;
|
|
54
|
+
if (Date.now() < (existingCreds.expiresAt - bufferTime)) {
|
|
55
|
+
client.setAuthToken(existingCreds.jwt);
|
|
56
|
+
return { client, credentials: existingCreds, isNewUser: false };
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
if (existingCreds && existingCreds.privateKey) {
|
|
60
|
+
try {
|
|
61
|
+
const response = await client.post('/v1/auth/login', {
|
|
62
|
+
networkId,
|
|
63
|
+
publicToken: existingCreds.publicToken,
|
|
64
|
+
privateKey: existingCreds.privateKey
|
|
65
|
+
});
|
|
66
|
+
if (response.success && response.data) {
|
|
67
|
+
const updatedCreds = {
|
|
68
|
+
...existingCreds,
|
|
69
|
+
jwt: response.data.jwt,
|
|
70
|
+
expiresAt: response.data.expiresAt
|
|
71
|
+
};
|
|
72
|
+
await ConfigManager_1.configManager.saveCredentials(networkId, updatedCreds);
|
|
73
|
+
client.setAuthToken(response.data.jwt);
|
|
74
|
+
return { client, credentials: updatedCreds, isNewUser: false };
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
catch (error) {
|
|
78
|
+
// Login failed, will try to register
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
const keysResponse = await client.get('/v1/auth/generate-keys');
|
|
82
|
+
if (!keysResponse.success || !keysResponse.data) {
|
|
83
|
+
throw new Error('Failed to generate keys');
|
|
84
|
+
}
|
|
85
|
+
const keys = keysResponse.data;
|
|
86
|
+
const registerResponse = await client.post('/v1/auth/register', {
|
|
87
|
+
networkId,
|
|
88
|
+
publicToken: keys.publicToken,
|
|
89
|
+
privateKey: keys.privateKey
|
|
90
|
+
});
|
|
91
|
+
if (registerResponse.success && registerResponse.data) {
|
|
92
|
+
const newCreds = {
|
|
93
|
+
publicToken: keys.publicToken,
|
|
94
|
+
privateKey: keys.privateKey,
|
|
95
|
+
jwt: registerResponse.data.tokens.jwt,
|
|
96
|
+
expiresAt: registerResponse.data.tokens.expiresAt
|
|
97
|
+
};
|
|
98
|
+
await ConfigManager_1.configManager.saveCredentials(networkId, newCreds);
|
|
99
|
+
client.setAuthToken(registerResponse.data.tokens.jwt);
|
|
100
|
+
console.log(chalk_1.default.green('✓ Auto-registered in network:'), networkId);
|
|
101
|
+
console.log(chalk_1.default.gray('Public Token:'), keys.publicToken);
|
|
102
|
+
return { client, credentials: newCreds, isNewUser: true };
|
|
103
|
+
}
|
|
104
|
+
throw new Error('Failed to authenticate');
|
|
105
|
+
}
|
|
106
|
+
static async getApiClient() {
|
|
107
|
+
const config = await ConfigManager_1.configManager.getGlobalConfig();
|
|
108
|
+
const client = new ApiClient_1.ApiClient(config.apiUrl);
|
|
109
|
+
client.setFormat(config.defaultFormat);
|
|
110
|
+
return client;
|
|
111
|
+
}
|
|
112
|
+
static async getAuthenticatedClient(networkId) {
|
|
113
|
+
const result = await this.ensureAuthenticated(networkId);
|
|
114
|
+
return result.client;
|
|
115
|
+
}
|
|
116
|
+
static async getFirstAuthenticatedClient() {
|
|
117
|
+
const credentialsDir = path.join(os.homedir(), '.agenticpool', 'credentials');
|
|
118
|
+
if (!(await fs.pathExists(credentialsDir))) {
|
|
119
|
+
throw new Error('No stored credentials found. Run "agenticpool auth connect <networkId>" first.');
|
|
120
|
+
}
|
|
121
|
+
const files = await fs.readdir(credentialsDir);
|
|
122
|
+
const jsonFiles = files.filter(f => f.endsWith('.json'));
|
|
123
|
+
for (const file of jsonFiles) {
|
|
124
|
+
const networkId = file.replace('.json', '');
|
|
125
|
+
try {
|
|
126
|
+
const result = await this.ensureAuthenticated(networkId);
|
|
127
|
+
return { client: result.client, networkId };
|
|
128
|
+
}
|
|
129
|
+
catch {
|
|
130
|
+
continue;
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
throw new Error('No valid credentials found. Run "agenticpool auth connect <networkId>" first.');
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
exports.AuthHelper = AuthHelper;
|
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AuthHelper.js","sourceRoot":"","sources":["../../src/auth/AuthHelper.ts"],"names":[],"mappings":"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","sourcesContent":["import * as path from 'path';\nimport * as os from 'os';\nimport * as fs from 'fs-extra';\nimport { ApiClient } from '../api/ApiClient';\nimport { configManager, NetworkCredentials } from '../config/ConfigManager';\nimport chalk from 'chalk';\n\nexport interface AuthResult {\n  client: ApiClient;\n  credentials: NetworkCredentials;\n  isNewUser: boolean;\n}\n\nexport class AuthHelper {\n  static async ensureAuthenticated(networkId: string): Promise<AuthResult> {\n    const config = await configManager.getGlobalConfig();\n    const client = new ApiClient(config.apiUrl);\n    client.setFormat(config.defaultFormat);\n\n    const existingCreds = await configManager.getCredentials(networkId);\n    \n    if (existingCreds && existingCreds.jwt && existingCreds.expiresAt) {\n      const bufferTime = 5 * 60 * 1000;\n      if (Date.now() < (existingCreds.expiresAt - bufferTime)) {\n        client.setAuthToken(existingCreds.jwt);\n        return { client, credentials: existingCreds, isNewUser: false };\n      }\n    }\n\n    if (existingCreds && existingCreds.privateKey) {\n      try {\n        const response = await client.post<{ jwt: string; expiresAt: number; publicToken: string }>('/v1/auth/login', {\n          networkId,\n          publicToken: existingCreds.publicToken,\n          privateKey: existingCreds.privateKey\n        });\n\n        if (response.success && response.data) {\n          const updatedCreds: NetworkCredentials = {\n            ...existingCreds,\n            jwt: response.data.jwt,\n            expiresAt: response.data.expiresAt\n          };\n          \n          await configManager.saveCredentials(networkId, updatedCreds);\n          client.setAuthToken(response.data.jwt);\n          \n          return { client, credentials: updatedCreds, isNewUser: false };\n        }\n      } catch (error) {\n        // Login failed, will try to register\n      }\n    }\n\n    const keysResponse = await client.get<{ publicToken: string; privateKey: string }>('/v1/auth/generate-keys');\n    \n    if (!keysResponse.success || !keysResponse.data) {\n      throw new Error('Failed to generate keys');\n    }\n\n    const keys = keysResponse.data;\n\n    const registerResponse = await client.post<{ member: any; tokens: { jwt: string; expiresAt: number; publicToken: string } }>('/v1/auth/register', {\n      networkId,\n      publicToken: keys.publicToken,\n      privateKey: keys.privateKey\n    });\n\n    if (registerResponse.success && registerResponse.data) {\n      const newCreds: NetworkCredentials = {\n        publicToken: keys.publicToken,\n        privateKey: keys.privateKey,\n        jwt: registerResponse.data.tokens.jwt,\n        expiresAt: registerResponse.data.tokens.expiresAt\n      };\n\n      await configManager.saveCredentials(networkId, newCreds);\n      client.setAuthToken(registerResponse.data.tokens.jwt);\n\n      console.log(chalk.green('✓ Auto-registered in network:'), networkId);\n      console.log(chalk.gray('Public Token:'), keys.publicToken);\n\n      return { client, credentials: newCreds, isNewUser: true };\n    }\n\n    throw new Error('Failed to authenticate');\n  }\n\n  static async getApiClient(): Promise<ApiClient> {\n    const config = await configManager.getGlobalConfig();\n    const client = new ApiClient(config.apiUrl);\n    client.setFormat(config.defaultFormat);\n    return client;\n  }\n\n  static async getAuthenticatedClient(networkId: string): Promise<ApiClient> {\n    const result = await this.ensureAuthenticated(networkId);\n    return result.client;\n  }\n\n  static async getFirstAuthenticatedClient(): Promise<{ client: ApiClient; networkId: string }> {\n    const credentialsDir = path.join(os.homedir(), '.agenticpool', 'credentials');\n    \n    if (!(await fs.pathExists(credentialsDir))) {\n      throw new Error('No stored credentials found. Run \"agenticpool auth connect <networkId>\" first.');\n    }\n\n    const files = await fs.readdir(credentialsDir);\n    const jsonFiles = files.filter(f => f.endsWith('.json'));\n\n    for (const file of jsonFiles) {\n      const networkId = file.replace('.json', '');\n      try {\n        const result = await this.ensureAuthenticated(networkId);\n        return { client: result.client, networkId };\n      } catch {\n        continue;\n      }\n    }\n\n    throw new Error('No valid credentials found. Run \"agenticpool auth connect <networkId>\" first.');\n  }\n}\n"]}
|
|
@@ -0,0 +1,166 @@
|
|
|
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.registerAuthCommands = registerAuthCommands;
|
|
7
|
+
const config_1 = require("../config");
|
|
8
|
+
const AuthHelper_1 = require("../auth/AuthHelper");
|
|
9
|
+
const chalk_1 = __importDefault(require("chalk"));
|
|
10
|
+
function registerAuthCommands(program) {
|
|
11
|
+
const auth = program.command('auth').description('Authentication commands');
|
|
12
|
+
auth
|
|
13
|
+
.command('connect')
|
|
14
|
+
.description('Connect to a network (auto-register if needed)')
|
|
15
|
+
.argument('<networkId>', 'Network ID')
|
|
16
|
+
.option('-k, --private-key <key>', 'Existing private key (optional)')
|
|
17
|
+
.action(async (networkId, options) => {
|
|
18
|
+
try {
|
|
19
|
+
const result = await AuthHelper_1.AuthHelper.ensureAuthenticated(networkId);
|
|
20
|
+
if (result.isNewUser) {
|
|
21
|
+
console.log(chalk_1.default.green('✓ Registered and connected!'));
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
console.log(chalk_1.default.green('✓ Connected!'));
|
|
25
|
+
}
|
|
26
|
+
console.log(chalk_1.default.gray('Network:'), networkId);
|
|
27
|
+
console.log(chalk_1.default.gray('Public Token:'), result.credentials.publicToken);
|
|
28
|
+
if (result.credentials.expiresAt) {
|
|
29
|
+
const expires = new Date(result.credentials.expiresAt);
|
|
30
|
+
console.log(chalk_1.default.gray('Token expires:'), expires.toISOString());
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
catch (error) {
|
|
34
|
+
console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
|
|
35
|
+
}
|
|
36
|
+
});
|
|
37
|
+
auth
|
|
38
|
+
.command('disconnect')
|
|
39
|
+
.description('Disconnect from a network')
|
|
40
|
+
.argument('<networkId>', 'Network ID')
|
|
41
|
+
.action(async (networkId) => {
|
|
42
|
+
await config_1.configManager.clearCredentials(networkId);
|
|
43
|
+
console.log(chalk_1.default.green('✓ Disconnected from network:'), networkId);
|
|
44
|
+
});
|
|
45
|
+
auth
|
|
46
|
+
.command('generate-keys')
|
|
47
|
+
.description('Generate a new public token and private key pair')
|
|
48
|
+
.action(async () => {
|
|
49
|
+
try {
|
|
50
|
+
const client = await AuthHelper_1.AuthHelper.getApiClient();
|
|
51
|
+
const response = await client.get('/v1/auth/generate-keys');
|
|
52
|
+
if (response.success && response.data) {
|
|
53
|
+
console.log(chalk_1.default.green('Generated keys:'));
|
|
54
|
+
console.log(chalk_1.default.cyan('Public Token:'), response.data.publicToken);
|
|
55
|
+
console.log(chalk_1.default.cyan('Private Key:'), response.data.privateKey);
|
|
56
|
+
console.log(chalk_1.default.yellow('\n⚠️ Save your private key securely. It will not be shown again.'));
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
console.error(chalk_1.default.red('Error:'), response.error?.message || 'Failed to generate keys');
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
catch (error) {
|
|
63
|
+
console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
|
|
64
|
+
}
|
|
65
|
+
});
|
|
66
|
+
auth
|
|
67
|
+
.command('register')
|
|
68
|
+
.description('Register in a network')
|
|
69
|
+
.requiredOption('-n, --network <id>', 'Network ID')
|
|
70
|
+
.requiredOption('-p, --public-token <token>', 'Your public token')
|
|
71
|
+
.requiredOption('-k, --private-key <key>', 'Your private key')
|
|
72
|
+
.action(async (options) => {
|
|
73
|
+
try {
|
|
74
|
+
const client = await AuthHelper_1.AuthHelper.getApiClient();
|
|
75
|
+
const response = await client.post('/v1/auth/register', {
|
|
76
|
+
networkId: options.network,
|
|
77
|
+
publicToken: options.publicToken,
|
|
78
|
+
privateKey: options.privateKey
|
|
79
|
+
});
|
|
80
|
+
if (response.success && response.data) {
|
|
81
|
+
const data = response.data;
|
|
82
|
+
await config_1.configManager.saveCredentials(options.network, {
|
|
83
|
+
publicToken: options.publicToken,
|
|
84
|
+
privateKey: options.privateKey,
|
|
85
|
+
jwt: data.tokens.jwt,
|
|
86
|
+
expiresAt: data.tokens.expiresAt
|
|
87
|
+
});
|
|
88
|
+
console.log(chalk_1.default.green('✓ Registered successfully!'));
|
|
89
|
+
console.log(chalk_1.default.gray('Credentials saved for network:'), options.network);
|
|
90
|
+
}
|
|
91
|
+
else {
|
|
92
|
+
console.error(chalk_1.default.red('Error:'), response.error?.message || 'Registration failed');
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
catch (error) {
|
|
96
|
+
console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
|
|
97
|
+
}
|
|
98
|
+
});
|
|
99
|
+
auth
|
|
100
|
+
.command('login')
|
|
101
|
+
.description('Login to a network')
|
|
102
|
+
.requiredOption('-n, --network <id>', 'Network ID')
|
|
103
|
+
.requiredOption('-p, --public-token <token>', 'Your public token')
|
|
104
|
+
.requiredOption('-k, --private-key <key>', 'Your private key')
|
|
105
|
+
.action(async (options) => {
|
|
106
|
+
try {
|
|
107
|
+
const client = await AuthHelper_1.AuthHelper.getApiClient();
|
|
108
|
+
const response = await client.post('/v1/auth/login', {
|
|
109
|
+
networkId: options.network,
|
|
110
|
+
publicToken: options.publicToken,
|
|
111
|
+
privateKey: options.privateKey
|
|
112
|
+
});
|
|
113
|
+
if (response.success && response.data) {
|
|
114
|
+
const tokens = response.data;
|
|
115
|
+
await config_1.configManager.saveCredentials(options.network, {
|
|
116
|
+
publicToken: options.publicToken,
|
|
117
|
+
privateKey: options.privateKey,
|
|
118
|
+
jwt: tokens.jwt,
|
|
119
|
+
expiresAt: tokens.expiresAt
|
|
120
|
+
});
|
|
121
|
+
console.log(chalk_1.default.green('✓ Logged in successfully!'));
|
|
122
|
+
console.log(chalk_1.default.gray('Token expires at:'), new Date(tokens.expiresAt).toISOString());
|
|
123
|
+
}
|
|
124
|
+
else {
|
|
125
|
+
console.error(chalk_1.default.red('Error:'), response.error?.message || 'Login failed');
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
catch (error) {
|
|
129
|
+
console.error(chalk_1.default.red('Error:'), error instanceof Error ? error.message : 'Unknown error');
|
|
130
|
+
}
|
|
131
|
+
});
|
|
132
|
+
auth
|
|
133
|
+
.command('logout')
|
|
134
|
+
.description('Logout from a network')
|
|
135
|
+
.requiredOption('-n, --network <id>', 'Network ID')
|
|
136
|
+
.action(async (options) => {
|
|
137
|
+
await config_1.configManager.clearCredentials(options.network);
|
|
138
|
+
console.log(chalk_1.default.green('✓ Logged out from network:'), options.network);
|
|
139
|
+
});
|
|
140
|
+
auth
|
|
141
|
+
.command('status')
|
|
142
|
+
.description('Show authentication status')
|
|
143
|
+
.option('-n, --network <id>', 'Network ID to check')
|
|
144
|
+
.action(async (options) => {
|
|
145
|
+
const config = await config_1.configManager.getGlobalConfig();
|
|
146
|
+
console.log(chalk_1.default.cyan('API URL:'), config.apiUrl);
|
|
147
|
+
console.log(chalk_1.default.cyan('Format:'), config.defaultFormat);
|
|
148
|
+
console.log(chalk_1.default.cyan('Config dir:'), config_1.configManager.getConfigPath());
|
|
149
|
+
if (options.network) {
|
|
150
|
+
const creds = await config_1.configManager.getCredentials(options.network);
|
|
151
|
+
if (creds) {
|
|
152
|
+
console.log(chalk_1.default.cyan('\nNetwork:'), options.network);
|
|
153
|
+
console.log(chalk_1.default.cyan('Public Token:'), creds.publicToken);
|
|
154
|
+
if (creds.expiresAt) {
|
|
155
|
+
const valid = Date.now() < creds.expiresAt;
|
|
156
|
+
console.log(chalk_1.default.cyan('Token valid:'), valid ? chalk_1.default.green('Yes') : chalk_1.default.red('No (expired)'));
|
|
157
|
+
console.log(chalk_1.default.cyan('Expires:'), new Date(creds.expiresAt).toISOString());
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
else {
|
|
161
|
+
console.log(chalk_1.default.yellow('\nNot connected to network:'), options.network);
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"auth.js","sourceRoot":"","sources":["../../src/commands/auth.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\nexport function registerAuthCommands(program: Command): void {\n  const auth = program.command('auth').description('Authentication commands');\n\n  auth\n    .command('connect')\n    .description('Connect to a network (auto-register if needed)')\n    .argument('<networkId>', 'Network ID')\n    .option('-k, --private-key <key>', 'Existing private key (optional)')\n    .action(async (networkId, options) => {\n      try {\n        const result = await AuthHelper.ensureAuthenticated(networkId);\n        \n        if (result.isNewUser) {\n          console.log(chalk.green('✓ Registered and connected!'));\n        } else {\n          console.log(chalk.green('✓ Connected!'));\n        }\n        \n        console.log(chalk.gray('Network:'), networkId);\n        console.log(chalk.gray('Public Token:'), result.credentials.publicToken);\n        \n        if (result.credentials.expiresAt) {\n          const expires = new Date(result.credentials.expiresAt);\n          console.log(chalk.gray('Token expires:'), expires.toISOString());\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  auth\n    .command('disconnect')\n    .description('Disconnect from a network')\n    .argument('<networkId>', 'Network ID')\n    .action(async (networkId) => {\n      await configManager.clearCredentials(networkId);\n      console.log(chalk.green('✓ Disconnected from network:'), networkId);\n    });\n\n  auth\n    .command('generate-keys')\n    .description('Generate a new public token and private key pair')\n    .action(async () => {\n      try {\n        const client = await AuthHelper.getApiClient();\n        const response = await client.get<{ publicToken: string; privateKey: string }>('/v1/auth/generate-keys');\n\n        if (response.success && response.data) {\n          console.log(chalk.green('Generated keys:'));\n          console.log(chalk.cyan('Public Token:'), response.data.publicToken);\n          console.log(chalk.cyan('Private Key:'), response.data.privateKey);\n          console.log(chalk.yellow('\\n⚠️  Save your private key securely. It will not be shown again.'));\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Failed to generate keys');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  auth\n    .command('register')\n    .description('Register in a network')\n    .requiredOption('-n, --network <id>', 'Network ID')\n    .requiredOption('-p, --public-token <token>', 'Your public token')\n    .requiredOption('-k, --private-key <key>', 'Your private key')\n    .action(async (options) => {\n      try {\n        const client = await AuthHelper.getApiClient();\n        const response = await client.post('/v1/auth/register', {\n          networkId: options.network,\n          publicToken: options.publicToken,\n          privateKey: options.privateKey\n        });\n\n        if (response.success && response.data) {\n          const data = response.data as { member: any; tokens: any };\n          await configManager.saveCredentials(options.network, {\n            publicToken: options.publicToken,\n            privateKey: options.privateKey,\n            jwt: data.tokens.jwt,\n            expiresAt: data.tokens.expiresAt\n          });\n\n          console.log(chalk.green('✓ Registered successfully!'));\n          console.log(chalk.gray('Credentials saved for network:'), options.network);\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Registration failed');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  auth\n    .command('login')\n    .description('Login to a network')\n    .requiredOption('-n, --network <id>', 'Network ID')\n    .requiredOption('-p, --public-token <token>', 'Your public token')\n    .requiredOption('-k, --private-key <key>', 'Your private key')\n    .action(async (options) => {\n      try {\n        const client = await AuthHelper.getApiClient();\n        const response = await client.post('/v1/auth/login', {\n          networkId: options.network,\n          publicToken: options.publicToken,\n          privateKey: options.privateKey\n        });\n\n        if (response.success && response.data) {\n          const tokens = response.data as any;\n          await configManager.saveCredentials(options.network, {\n            publicToken: options.publicToken,\n            privateKey: options.privateKey,\n            jwt: tokens.jwt,\n            expiresAt: tokens.expiresAt\n          });\n\n          console.log(chalk.green('✓ Logged in successfully!'));\n          console.log(chalk.gray('Token expires at:'), new Date(tokens.expiresAt).toISOString());\n        } else {\n          console.error(chalk.red('Error:'), response.error?.message || 'Login failed');\n        }\n      } catch (error) {\n        console.error(chalk.red('Error:'), error instanceof Error ? error.message : 'Unknown error');\n      }\n    });\n\n  auth\n    .command('logout')\n    .description('Logout from a network')\n    .requiredOption('-n, --network <id>', 'Network ID')\n    .action(async (options) => {\n      await configManager.clearCredentials(options.network);\n      console.log(chalk.green('✓ Logged out from network:'), options.network);\n    });\n\n  auth\n    .command('status')\n    .description('Show authentication status')\n    .option('-n, --network <id>', 'Network ID to check')\n    .action(async (options) => {\n      const config = await configManager.getGlobalConfig();\n      console.log(chalk.cyan('API URL:'), config.apiUrl);\n      console.log(chalk.cyan('Format:'), config.defaultFormat);\n      console.log(chalk.cyan('Config dir:'), configManager.getConfigPath());\n      \n      if (options.network) {\n        const creds = await configManager.getCredentials(options.network);\n        if (creds) {\n          console.log(chalk.cyan('\\nNetwork:'), options.network);\n          console.log(chalk.cyan('Public Token:'), creds.publicToken);\n          if (creds.expiresAt) {\n            const valid = Date.now() < creds.expiresAt;\n            console.log(chalk.cyan('Token valid:'), valid ? chalk.green('Yes') : chalk.red('No (expired)'));\n            console.log(chalk.cyan('Expires:'), new Date(creds.expiresAt).toISOString());\n          }\n        } else {\n          console.log(chalk.yellow('\\nNot connected to network:'), options.network);\n        }\n      }\n    });\n}\n"]}
|