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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQXV0aEhlbHBlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9hdXRoL0F1dGhIZWxwZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsMkNBQTZCO0FBQzdCLHVDQUF5QjtBQUN6Qiw2Q0FBK0I7QUFDL0IsZ0RBQTZDO0FBQzdDLDJEQUE0RTtBQUM1RSxrREFBMEI7QUFRMUIsTUFBYSxVQUFVO0lBQ3JCLE1BQU0sQ0FBQyxLQUFLLENBQUMsbUJBQW1CLENBQUMsU0FBaUI7UUFDaEQsTUFBTSxNQUFNLEdBQUcsTUFBTSw2QkFBYSxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQ3JELE1BQU0sTUFBTSxHQUFHLElBQUkscUJBQVMsQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDNUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsYUFBYSxDQUFDLENBQUM7UUFFdkMsTUFBTSxhQUFhLEdBQUcsTUFBTSw2QkFBYSxDQUFDLGNBQWMsQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUVwRSxJQUFJLGFBQWEsSUFBSSxhQUFhLENBQUMsR0FBRyxJQUFJLGFBQWEsQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUNsRSxNQUFNLFVBQVUsR0FBRyxDQUFDLEdBQUcsRUFBRSxHQUFHLElBQUksQ0FBQztZQUNqQyxJQUFJLElBQUksQ0FBQyxHQUFHLEVBQUUsR0FBRyxDQUFDLGFBQWEsQ0FBQyxTQUFTLEdBQUcsVUFBVSxDQUFDLEVBQUUsQ0FBQztnQkFDeEQsTUFBTSxDQUFDLFlBQVksQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUFDLENBQUM7Z0JBQ3ZDLE9BQU8sRUFBRSxNQUFNLEVBQUUsV0FBVyxFQUFFLGFBQWEsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLENBQUM7WUFDbEUsQ0FBQztRQUNILENBQUM7UUFFRCxJQUFJLGFBQWEsSUFBSSxhQUFhLENBQUMsVUFBVSxF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LE1BQU0sQ0FBQyxNQUFNLEVBQUUsU0FBUyxFQUFFLENBQUM7WUFDOUMsQ0FBQztZQUFDLE1BQU0sQ0FBQztnQkFDUCxTQUFTO1lBQ1gsQ0FBQztRQUNILENBQUM7UUFFRCxNQUFNLElBQUksS0FBSyxDQUFDLCtFQUErRSxDQUFDLENBQUM7SUFDbkcsQ0FBQztDQUNGO0FBN0dELGdDQTZHQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHBhdGggZnJvbSAncGF0aCc7XG5pbXBvcnQgKiBhcyBvcyBmcm9tICdvcyc7XG5pbXBvcnQgKiBhcyBmcyBmcm9tICdmcy1leHRyYSc7XG5pbXBvcnQgeyBBcGlDbGllbnQgfSBmcm9tICcuLi9hcGkvQXBpQ2xpZW50JztcbmltcG9ydCB7IGNvbmZpZ01hbmFnZXIsIE5ldHdvcmtDcmVkZW50aWFscyB9IGZyb20gJy4uL2NvbmZpZy9Db25maWdNYW5hZ2VyJztcbmltcG9ydCBjaGFsayBmcm9tICdjaGFsayc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQXV0aFJlc3VsdCB7XG4gIGNsaWVudDogQXBpQ2xpZW50O1xuICBjcmVkZW50aWFsczogTmV0d29ya0NyZWRlbnRpYWxzO1xuICBpc05ld1VzZXI6IGJvb2xlYW47XG59XG5cbmV4cG9ydCBjbGFzcyBBdXRoSGVscGVyIHtcbiAgc3RhdGljIGFzeW5jIGVuc3VyZUF1dGhlbnRpY2F0ZWQobmV0d29ya0lkOiBzdHJpbmcpOiBQcm9taXNlPEF1dGhSZXN1bHQ+IHtcbiAgICBjb25zdCBjb25maWcgPSBhd2FpdCBjb25maWdNYW5hZ2VyLmdldEdsb2JhbENvbmZpZygpO1xuICAgIGNvbnN0IGNsaWVudCA9IG5ldyBBcGlDbGllbnQoY29uZmlnLmFwaVVybCk7XG4gICAgY2xpZW50LnNldEZvcm1hdChjb25maWcuZGVmYXVsdEZvcm1hdCk7XG5cbiAgICBjb25zdCBleGlzdGluZ0NyZWRzID0gYXdhaXQgY29uZmlnTWFuYWdlci5nZXRDcmVkZW50aWFscyhuZXR3b3JrSWQpO1xuICAgIFxuICAgIGlmIChleGlzdGluZ0NyZWRzICYmIGV4aXN0aW5nQ3JlZHMuand0ICYmIGV4aXN0aW5nQ3JlZHMuZXhwaXJlc0F0KSB7XG4gICAgICBjb25zdCBidWZmZXJUaW1lID0gNSAqIDYwICogMTAwMDtcbiAgICAgIGlmIChEYXRlLm5vdygpIDwgKGV4aXN0aW5nQ3JlZHMuZXhwaXJlc0F0IC0gYnVmZmVyVGltZSkpIHtcbiAgICAgICAgY2xpZW50LnNldEF1dGhUb2tlbihleGlzdGluZ0NyZWRzLmp3dCk7XG4gICAgICAgIHJldHVybiB7IGNsaWVudCwgY3JlZGVudGlhbHM6IGV4aXN0aW5nQ3JlZHMsIGlzTmV3VXNlcjogZmFsc2UgfTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICBpZiAoZXhpc3RpbmdDcmVkcyAmJiBleGlzdGluZ0NyZWRzLnByaXZhdGVLZXkpIHtcbiAgICAgIHRyeSB7XG4gICAgICAgIGNvbnN0IHJlc3BvbnNlID0gYXdhaXQgY2xpZW50LnBvc3Q8eyBqd3Q6IHN0cmluZzsgZXhwaXJlc0F0OiBudW1iZXI7IHB1YmxpY1Rva2VuOiBzdHJpbmcgfT4oJy92MS9hdXRoL2xvZ2luJywge1xuICAgICAgICAgIG5ldHdvcmtJZCxcbiAgICAgICAgICBwdWJsaWNUb2tlbjogZXhpc3RpbmdDcmVkcy5wdWJsaWNUb2tlbixcbiAgICAgICAgICBwcml2YXRlS2V5OiBleGlzdGluZ0NyZWRzLnByaXZhdGVLZXlcbiAgICAgICAgfSk7XG5cbiAgICAgICAgaWYgKHJlc3BvbnNlLnN1Y2Nlc3MgJiYgcmVzcG9uc2UuZGF0YSkge1xuICAgICAgICAgIGNvbnN0IHVwZGF0ZWRDcmVkczogTmV0d29ya0NyZWRlbnRpYWxzID0ge1xuICAgICAgICAgICAgLi4uZXhpc3RpbmdDcmVkcyxcbiAgICAgICAgICAgIGp3dDogcmVzcG9uc2UuZGF0YS5qd3QsXG4gICAgICAgICAgICBleHBpcmVzQXQ6IHJlc3BvbnNlLmRhdGEuZXhwaXJlc0F0XG4gICAgICAgICAgfTtcbiAgICAgICAgICBcbiAgICAgICAgICBhd2FpdCBjb25maWdNYW5hZ2VyLnNhdmVDcmVkZW50aWFscyhuZXR3b3JrSWQsIHVwZGF0ZWRDcmVkcyk7XG4gICAgICAgICAgY2xpZW50LnNldEF1dGhUb2tlbihyZXNwb25zZS5kYXRhLmp3dCk7XG4gICAgICAgICAgXG4gICAgICAgICAgcmV0dXJuIHsgY2xpZW50LCBjcmVkZW50aWFsczogdXBkYXRlZENyZWRzLCBpc05ld1VzZXI6IGZhbHNlIH07XG4gICAgICAgIH1cbiAgICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICAgIC8vIExvZ2luIGZhaWxlZCwgd2lsbCB0cnkgdG8gcmVnaXN0ZXJcbiAgICAgIH1cbiAgICB9XG5cbiAgICBjb25zdCBrZXlzUmVzcG9uc2UgPSBhd2FpdCBjbGllbnQuZ2V0PHsgcHVibGljVG9rZW46IHN0cmluZzsgcHJpdmF0ZUtleTogc3RyaW5nIH0+KCcvdjEvYXV0aC9nZW5lcmF0ZS1rZXlzJyk7XG4gICAgXG4gICAgaWYgKCFrZXlzUmVzcG9uc2Uuc3VjY2VzcyB8fCAha2V5c1Jlc3BvbnNlLmRhdGEpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignRmFpbGVkIHRvIGdlbmVyYXRlIGtleXMnKTtcbiAgICB9XG5cbiAgICBjb25zdCBrZXlzID0ga2V5c1Jlc3BvbnNlLmRhdGE7XG5cbiAgICBjb25zdCByZWdpc3RlclJlc3BvbnNlID0gYXdhaXQgY2xpZW50LnBvc3Q8eyBtZW1iZXI6IGFueTsgdG9rZW5zOiB7IGp3dDogc3RyaW5nOyBleHBpcmVzQXQ6IG51bWJlcjsgcHVibGljVG9rZW46IHN0cmluZyB9IH0+KCcvdjEvYXV0aC9yZWdpc3RlcicsIHtcbiAgICAgIG5ldHdvcmtJZCxcbiAgICAgIHB1YmxpY1Rva2VuOiBrZXlzLnB1YmxpY1Rva2VuLFxuICAgICAgcHJpdmF0ZUtleToga2V5cy5wcml2YXRlS2V5XG4gICAgfSk7XG5cbiAgICBpZiAocmVnaXN0ZXJSZXNwb25zZS5zdWNjZXNzICYmIHJlZ2lzdGVyUmVzcG9uc2UuZGF0YSkge1xuICAgICAgY29uc3QgbmV3Q3JlZHM6IE5ldHdvcmtDcmVkZW50aWFscyA9IHtcbiAgICAgICAgcHVibGljVG9rZW46IGtleXMucHVibGljVG9rZW4sXG4gICAgICAgIHByaXZhdGVLZXk6IGtleXMucHJpdmF0ZUtleSxcbiAgICAgICAgand0OiByZWdpc3RlclJlc3BvbnNlLmRhdGEudG9rZW5zLmp3dCxcbiAgICAgICAgZXhwaXJlc0F0OiByZWdpc3RlclJlc3BvbnNlLmRhdGEudG9rZW5zLmV4cGlyZXNBdFxuICAgICAgfTtcblxuICAgICAgYXdhaXQgY29uZmlnTWFuYWdlci5zYXZlQ3JlZGVudGlhbHMobmV0d29ya0lkLCBuZXdDcmVkcyk7XG4gICAgICBjbGllbnQuc2V0QXV0aFRva2VuKHJlZ2lzdGVyUmVzcG9uc2UuZGF0YS50b2tlbnMuand0KTtcblxuICAgICAgY29uc29sZS5sb2coY2hhbGsuZ3JlZW4oJ+KckyBBdXRvLXJlZ2lzdGVyZWQgaW4gbmV0d29yazonKSwgbmV0d29ya0lkKTtcbiAgICAgIGNvbnNvbGUubG9nKGNoYWxrLmdyYXkoJ1B1YmxpYyBUb2tlbjonKSwga2V5cy5wdWJsaWNUb2tlbik7XG5cbiAgICAgIHJldHVybiB7IGNsaWVudCwgY3JlZGVudGlhbHM6IG5ld0NyZWRzLCBpc05ld1VzZXI6IHRydWUgfTtcbiAgICB9XG5cbiAgICB0aHJvdyBuZXcgRXJyb3IoJ0ZhaWxlZCB0byBhdXRoZW50aWNhdGUnKTtcbiAgfVxuXG4gIHN0YXRpYyBhc3luYyBnZXRBcGlDbGllbnQoKTogUHJvbWlzZTxBcGlDbGllbnQ+IHtcbiAgICBjb25zdCBjb25maWcgPSBhd2FpdCBjb25maWdNYW5hZ2VyLmdldEdsb2JhbENvbmZpZygpO1xuICAgIGNvbnN0IGNsaWVudCA9IG5ldyBBcGlDbGllbnQoY29uZmlnLmFwaVVybCk7XG4gICAgY2xpZW50LnNldEZvcm1hdChjb25maWcuZGVmYXVsdEZvcm1hdCk7XG4gICAgcmV0dXJuIGNsaWVudDtcbiAgfVxuXG4gIHN0YXRpYyBhc3luYyBnZXRBdXRoZW50aWNhdGVkQ2xpZW50KG5ldHdvcmtJZDogc3RyaW5nKTogUHJvbWlzZTxBcGlDbGllbnQ+IHtcbiAgICBjb25zdCByZXN1bHQgPSBhd2FpdCB0aGlzLmVuc3VyZUF1dGhlbnRpY2F0ZWQobmV0d29ya0lkKTtcbiAgICByZXR1cm4gcmVzdWx0LmNsaWVudDtcbiAgfVxuXG4gIHN0YXRpYyBhc3luYyBnZXRGaXJzdEF1dGhlbnRpY2F0ZWRDbGllbnQoKTogUHJvbWlzZTx7IGNsaWVudDogQXBpQ2xpZW50OyBuZXR3b3JrSWQ6IHN0cmluZyB9PiB7XG4gICAgY29uc3QgY3JlZGVudGlhbHNEaXIgPSBwYXRoLmpvaW4ob3MuaG9tZWRpcigpLCAnLmFnZW50aWNwb29sJywgJ2NyZWRlbnRpYWxzJyk7XG4gICAgXG4gICAgaWYgKCEoYXdhaXQgZnMucGF0aEV4aXN0cyhjcmVkZW50aWFsc0RpcikpKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ05vIHN0b3JlZCBjcmVkZW50aWFscyBmb3VuZC4gUnVuIFwiYWdlbnRpY3Bvb2wgYXV0aCBjb25uZWN0IDxuZXR3b3JrSWQ+XCIgZmlyc3QuJyk7XG4gICAgfVxuXG4gICAgY29uc3QgZmlsZXMgPSBhd2FpdCBmcy5yZWFkZGlyKGNyZWRlbnRpYWxzRGlyKTtcbiAgICBjb25zdCBqc29uRmlsZXMgPSBmaWxlcy5maWx0ZXIoZiA9PiBmLmVuZHNXaXRoKCcuanNvbicpKTtcblxuICAgIGZvciAoY29uc3QgZmlsZSBvZiBqc29uRmlsZXMpIHtcbiAgICAgIGNvbnN0IG5ldHdvcmtJZCA9IGZpbGUucmVwbGFjZSgnLmpzb24nLCAnJyk7XG4gICAgICB0cnkge1xuICAgICAgICBjb25zdCByZXN1bHQgPSBhd2FpdCB0aGlzLmVuc3VyZUF1dGhlbnRpY2F0ZWQobmV0d29ya0lkKTtcbiAgICAgICAgcmV0dXJuIHsgY2xpZW50OiByZXN1bHQuY2xpZW50LCBuZXR3b3JrSWQgfTtcbiAgICAgIH0gY2F0Y2gge1xuICAgICAgICBjb250aW51ZTtcbiAgICAgIH1cbiAgICB9XG5cbiAgICB0aHJvdyBuZXcgRXJyb3IoJ05vIHZhbGlkIGNyZWRlbnRpYWxzIGZvdW5kLiBSdW4gXCJhZ2VudGljcG9vbCBhdXRoIGNvbm5lY3QgPG5ldHdvcmtJZD5cIiBmaXJzdC4nKTtcbiAgfVxufVxuIl19
|
|
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21tYW5kcy9hdXRoLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7O0FBTUEsb0RBa0tDO0FBdEtELHNDQUEwQztBQUMxQyxtREFBZ0Q7QUFDaEQsa0RBQTBCO0FBRTFCLFNBQWdCLG9CQUFvQixDQUFDLE9BQWdCO0lBQ25ELE1BQU0sSUFBSSxHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUMsV0FBVyxDQUFDLHlCQUF5QixDQUFDLENBQUM7SUFFNUUsSUFBSTtTQUNELE9BQU8sQ0FBQyxTQUFTLENBQUM7U0FDbEIsV0FBVyxDQUFDLGdEQUFnRCxDQUFDO1NBQzdELFFBQVEsQ0FBQyxhQUFhLEVBQUUsWUFBWSxDQUFDO1NBQ3JDLE1BQU0sQ0FBQyx5QkFBeUIsRUFBRSxpQ0FBaUMsQ0FBQztTQUNwRSxNQUFNLENBQUMsS0FBSyxFQUFFLFNBQVMsRUFBRSxPQUFPLEVBQUUsRUFBRTtRQUNuQyxJQUFJLENBQUM7WUFDSCxNQUFNLE1BQU0sR0FBRyxNQUFNLHVCQUFVLENBQUMsbUJBQW1CLENBQUMsU0FBUyxDQUFDLENBQUM7WUFFL0QsSUFBSSxNQUFNLENBQUMsU0FBUyxFQUFFLENBQUM7Z0JBQ3JCLE9BQU8sQ0FBQyxHQUFHLENBQUMsZUFBSyxDQUFDLEtBQUssQ0FBQyw2QkFBNkIsQ0FBQyxDQUFDLENBQUM7WUFDMUQsQ0FBQztpQkFBTSxDQUFDO2dCQUNOLE9BQU8sQ0FBQyxHQUFHLENBQUMsZUFBSyxDQUFDLEtBQUssQ0FBQyxjQUFjLENBQUMsQ0FBQyxDQUFDO1lBQzNDLENBQUM7WUFFRCxPQUFPLENBQUMsR0FBRyxDQUFDLGVBQUssQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLEVBQUUsU0FBUyxDQUFDLENBQUM7WUFDL0MsT0FBTyxDQUFDLEdBQUcsQ0FBQyxlQUFLLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxFQUFFLE1BQU0sQ0FBQyxX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LEVBQUUsR0FBRyxLQUFLLENBQUMsU0FBUyxDQUFDO29CQUMzQyxPQUFPLENBQUMsR0FBRyxDQUFDLGVBQUssQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQyxlQUFLLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxlQUFLLENBQUMsR0FBRyxDQUFDLGNBQWMsQ0FBQyxDQUFDLENBQUM7b0JBQ2hHLE9BQU8sQ0FBQyxHQUFHLENBQUMsZUFBSyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsRUFBRSxJQUFJLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQztnQkFDL0UsQ0FBQztZQUNILENBQUM7aUJBQU0sQ0FBQztnQkFDTixPQUFPLENBQUMsR0FBRyxDQUFDLGVBQUssQ0FBQyxNQUFNLENBQUMsNkJBQTZCLENBQUMsRUFBRSxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDNUUsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDLENBQUMsQ0FBQztBQUNQLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tYW5kIH0gZnJvbSAnY29tbWFuZGVyJztcbmltcG9ydCB7IEFwaUNsaWVudCB9IGZyb20gJy4uL2FwaSc7XG5pbXBvcnQgeyBjb25maWdNYW5hZ2VyIH0gZnJvbSAnLi4vY29uZmlnJztcbmltcG9ydCB7IEF1dGhIZWxwZXIgfSBmcm9tICcuLi9hdXRoL0F1dGhIZWxwZXInO1xuaW1wb3J0IGNoYWxrIGZyb20gJ2NoYWxrJztcblxuZXhwb3J0IGZ1bmN0aW9uIHJlZ2lzdGVyQXV0aENvbW1hbmRzKHByb2dyYW06IENvbW1hbmQpOiB2b2lkIHtcbiAgY29uc3QgYXV0aCA9IHByb2dyYW0uY29tbWFuZCgnYXV0aCcpLmRlc2NyaXB0aW9uKCdBdXRoZW50aWNhdGlvbiBjb21tYW5kcycpO1xuXG4gIGF1dGhcbiAgICAuY29tbWFuZCgnY29ubmVjdCcpXG4gICAgLmRlc2NyaXB0aW9uKCdDb25uZWN0IHRvIGEgbmV0d29yayAoYXV0by1yZWdpc3RlciBpZiBuZWVkZWQpJylcbiAgICAuYXJndW1lbnQoJzxuZXR3b3JrSWQ+JywgJ05ldHdvcmsgSUQnKVxuICAgIC5vcHRpb24oJy1rLCAtLXByaXZhdGUta2V5IDxrZXk+JywgJ0V4aXN0aW5nIHByaXZhdGUga2V5IChvcHRpb25hbCknKVxuICAgIC5hY3Rpb24oYXN5bmMgKG5ldHdvcmtJZCwgb3B0aW9ucykgPT4ge1xuICAgICAgdHJ5IHtcbiAgICAgICAgY29uc3QgcmVzdWx0ID0gYXdhaXQgQXV0aEhlbHBlci5lbnN1cmVBdXRoZW50aWNhdGVkKG5ldHdvcmtJZCk7XG4gICAgICAgIFxuICAgICAgICBpZiAocmVzdWx0LmlzTmV3VXNlcikge1xuICAgICAgICAgIGNvbnNvbGUubG9nKGNoYWxrLmdyZWVuKCfinJMgUmVnaXN0ZXJlZCBhbmQgY29ubmVjdGVkIScpKTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICBjb25zb2xlLmxvZyhjaGFsay5ncmVlbign4pyTIENvbm5lY3RlZCEnKSk7XG4gICAgICAgIH1cbiAgICAgICAgXG4gICAgICAgIGNvbnNvbGUubG9nKGNoYWxrLmdyYXkoJ05ldHdvcms6JyksIG5ldHdvcmtJZCk7XG4gICAgICAgIGNvbnNvbGUubG9nKGNoYWxrLmdyYXkoJ1B1YmxpYyBUb2tlbjonKSwgcmVzdWx0LmNyZWRlbnRpYWxzLnB1YmxpY1Rva2VuKTtcbiAgICAgICAgXG4gICAgICAgIGlmIChyZXN1bHQuY3JlZGVudGlhbHMuZXhwaXJlc0F0KSB7XG4gICAgICAgICAgY29uc3QgZXhwaXJlcyA9IG5ldyBEYXRlKHJlc3VsdC5jcmVkZW50aWFscy5leHBpcmVzQXQpO1xuICAgICAgICAgIGNvbnNvbGUubG9nKGNoYWxrLmdyYXkoJ1Rva2VuIGV4cGlyZXM6JyksIGV4cGlyZXMudG9JU09TdHJpbmcoKSk7XG4gICAgICAgIH1cbiAgICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICAgIGNvbnNvbGUuZXJyb3IoY2hhbGsucmVkKCdFcnJvcjonKSwgZXJyb3IgaW5zdGFuY2VvZiBFcnJvciA/IGVycm9yLm1lc3NhZ2UgOiAnVW5rbm93biBlcnJvcicpO1xuICAgICAgfVxuICAgIH0pO1xuXG4gIGF1dGhcbiAgICAuY29tbWFuZCgnZGlzY29ubmVjdCcpXG4gICAgLmRlc2NyaXB0aW9uKCdEaXNjb25uZWN0IGZyb20gYSBuZXR3b3JrJylcbiAgICAuYXJndW1lbnQoJzxuZXR3b3JrSWQ+JywgJ05ldHdvcmsgSUQnKVxuICAgIC5hY3Rpb24oYXN5bmMgKG5ldHdvcmtJZCkgPT4ge1xuICAgICAgYXdhaXQgY29uZmlnTWFuYWdlci5jbGVhckNyZWRlbnRpYWxzKG5ldHdvcmtJZCk7XG4gICAgICBjb25zb2xlLmxvZyhjaGFsay5ncmVlbign4pyTIERpc2Nvbm5lY3RlZCBmcm9tIG5ldHdvcms6JyksIG5ldHdvcmtJZCk7XG4gICAgfSk7XG5cbiAgYXV0aFxuICAgIC5jb21tYW5kKCdnZW5lcmF0ZS1rZXlzJylcbiAgICAuZGVzY3JpcHRpb24oJ0dlbmVyYXRlIGEgbmV3IHB1YmxpYyB0b2tlbiBhbmQgcHJpdmF0ZSBrZXkgcGFpcicpXG4gICAgLmFjdGlvbihhc3luYyAoKSA9PiB7XG4gICAgICB0cnkge1xuICAgICAgICBjb25zdCBjbGllbnQgPSBhd2FpdCBBdXRoSGVscGVyLmdldEFwaUNsaWVudCgpO1xuICAgICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGNsaWVudC5nZXQ8eyBwdWJsaWNUb2tlbjogc3RyaW5nOyBwcml2YXRlS2V5OiBzdHJpbmcgfT4oJy92MS9hdXRoL2dlbmVyYXRlLWtleXMnKTtcblxuICAgICAgICBpZiAocmVzcG9uc2Uuc3VjY2VzcyAmJiByZXNwb25zZS5kYXRhKSB7XG4gICAgICAgICAgY29uc29sZS5sb2coY2hhbGsuZ3JlZW4oJ0dlbmVyYXRlZCBrZXlzOicpKTtcbiAgICAgICAgICBjb25zb2xlLmxvZyhjaGFsay5jeWFuKCdQdWJsaWMgVG9rZW46JyksIHJlc3BvbnNlLmRhdGEucHVibGljVG9rZW4pO1xuICAgICAgICAgIGNvbnNvbGUubG9nKGNoYWxrLmN5YW4oJ1ByaXZhdGUgS2V5OicpLCByZXNwb25zZS5kYXRhLnByaXZhdGVLZXkpO1xuICAgICAgICAgIGNvbnNvbGUubG9nKGNoYWxrLnllbGxvdygnXFxu4pqg77iPICBTYXZlIHlvdXIgcHJpdmF0ZSBrZXkgc2VjdXJlbHkuIEl0IHdpbGwgbm90IGJlIHNob3duIGFnYWluLicpKTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICBjb25zb2xlLmVycm9yKGNoYWxrLnJlZCgnRXJyb3I6JyksIHJlc3BvbnNlLmVycm9yPy5tZXNzYWdlIHx8ICdGYWlsZWQgdG8gZ2VuZXJhdGUga2V5cycpO1xuICAgICAgICB9XG4gICAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgICBjb25zb2xlLmVycm9yKGNoYWxrLnJlZCgnRXJyb3I6JyksIGVycm9yIGluc3RhbmNlb2YgRXJyb3IgPyBlcnJvci5tZXNzYWdlIDogJ1Vua25vd24gZXJyb3InKTtcbiAgICAgIH1cbiAgICB9KTtcblxuICBhdXRoXG4gICAgLmNvbW1hbmQoJ3JlZ2lzdGVyJylcbiAgICAuZGVzY3JpcHRpb24oJ1JlZ2lzdGVyIGluIGEgbmV0d29yaycpXG4gICAgLnJlcXVpcmVkT3B0aW9uKCctbiwgLS1uZXR3b3JrIDxpZD4nLCAnTmV0d29yayBJRCcpXG4gICAgLnJlcXVpcmVkT3B0aW9uKCctcCwgLS1wdWJsaWMtdG9rZW4gPHRva2VuPicsICdZb3VyIHB1YmxpYyB0b2tlbicpXG4gICAgLnJlcXVpcmVkT3B0aW9uKCctaywgLS1wcml2YXRlLWtleSA8a2V5PicsICdZb3VyIHByaXZhdGUga2V5JylcbiAgICAuYWN0aW9uKGFzeW5jIChvcHRpb25zKSA9PiB7XG4gICAgICB0cnkge1xuICAgICAgICBjb25zdCBjbGllbnQgPSBhd2FpdCBBdXRoSGVscGVyLmdldEFwaUNsaWVudCgpO1xuICAgICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGNsaWVudC5wb3N0KCcvdjEvYXV0aC9yZWdpc3RlcicsIHtcbiAgICAgICAgICBuZXR3b3JrSWQ6IG9wdGlvbnMubmV0d29yayxcbiAgICAgICAgICBwdWJsaWNUb2tlbjogb3B0aW9ucy5wdWJsaWNUb2tlbixcbiAgICAgICAgICBwcml2YXRlS2V5OiBvcHRpb25zLnByaXZhdGVLZXlcbiAgICAgICAgfSk7XG5cbiAgICAgICAgaWYgKHJlc3BvbnNlLnN1Y2Nlc3MgJiYgcmVzcG9uc2UuZGF0YSkge1xuICAgICAgICAgIGNvbnN0IGRhdGEgPSByZXNwb25zZS5kYXRhIGFzIHsgbWVtYmVyOiBhbnk7IHRva2VuczogYW55IH07XG4gICAgICAgICAgYXdhaXQgY29uZmlnTWFuYWdlci5zYXZlQ3JlZGVudGlhbHMob3B0aW9ucy5uZXR3b3JrLCB7XG4gICAgICAgICAgICBwdWJsaWNUb2tlbjogb3B0aW9ucy5wdWJsaWNUb2tlbixcbiAgICAgICAgICAgIHByaXZhdGVLZXk6IG9wdGlvbnMucHJpdmF0ZUtleSxcbiAgICAgICAgICAgIGp3dDogZGF0YS50b2tlbnMuand0LFxuICAgICAgICAgICAgZXhwaXJlc0F0OiBkYXRhLnRva2Vucy5leHBpcmVzQXRcbiAgICAgICAgICB9KTtcblxuICAgICAgICAgIGNvbnNvbGUubG9nKGNoYWxrLmdyZWVuKCfinJMgUmVnaXN0ZXJlZCBzdWNjZXNzZnVsbHkhJykpO1xuICAgICAgICAgIGNvbnNvbGUubG9nKGNoYWxrLmdyYXkoJ0NyZWRlbnRpYWxzIHNhdmVkIGZvciBuZXR3b3JrOicpLCBvcHRpb25zLm5ldHdvcmspO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGNvbnNvbGUuZXJyb3IoY2hhbGsucmVkKCdFcnJvcjonKSwgcmVzcG9uc2UuZXJyb3I/Lm1lc3NhZ2UgfHwgJ1JlZ2lzdHJhdGlvbiBmYWlsZWQnKTtcbiAgICAgICAgfVxuICAgICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgICAgY29uc29sZS5lcnJvcihjaGFsay5yZWQoJ0Vycm9yOicpLCBlcnJvciBpbnN0YW5jZW9mIEVycm9yID8gZXJyb3IubWVzc2FnZSA6ICdVbmtub3duIGVycm9yJyk7XG4gICAgICB9XG4gICAgfSk7XG5cbiAgYXV0aFxuICAgIC5jb21tYW5kKCdsb2dpbicpXG4gICAgLmRlc2NyaXB0aW9uKCdMb2dpbiB0byBhIG5ldHdvcmsnKVxuICAgIC5yZXF1aXJlZE9wdGlvbignLW4sIC0tbmV0d29yayA8aWQ+JywgJ05ldHdvcmsgSUQnKVxuICAgIC5yZXF1aXJlZE9wdGlvbignLXAsIC0tcHVibGljLXRva2VuIDx0b2tlbj4nLCAnWW91ciBwdWJsaWMgdG9rZW4nKVxuICAgIC5yZXF1aXJlZE9wdGlvbignLWssIC0tcHJpdmF0ZS1rZXkgPGtleT4nLCAnWW91ciBwcml2YXRlIGtleScpXG4gICAgLmFjdGlvbihhc3luYyAob3B0aW9ucykgPT4ge1xuICAgICAgdHJ5IHtcbiAgICAgICAgY29uc3QgY2xpZW50ID0gYXdhaXQgQXV0aEhlbHBlci5nZXRBcGlDbGllbnQoKTtcbiAgICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBjbGllbnQucG9zdCgnL3YxL2F1dGgvbG9naW4nLCB7XG4gICAgICAgICAgbmV0d29ya0lkOiBvcHRpb25zLm5ldHdvcmssXG4gICAgICAgICAgcHVibGljVG9rZW46IG9wdGlvbnMucHVibGljVG9rZW4sXG4gICAgICAgICAgcHJpdmF0ZUtleTogb3B0aW9ucy5wcml2YXRlS2V5XG4gICAgICAgIH0pO1xuXG4gICAgICAgIGlmIChyZXNwb25zZS5zdWNjZXNzICYmIHJlc3BvbnNlLmRhdGEpIHtcbiAgICAgICAgICBjb25zdCB0b2tlbnMgPSByZXNwb25zZS5kYXRhIGFzIGFueTtcbiAgICAgICAgICBhd2FpdCBjb25maWdNYW5hZ2VyLnNhdmVDcmVkZW50aWFscyhvcHRpb25zLm5ldHdvcmssIHtcbiAgICAgICAgICAgIHB1YmxpY1Rva2VuOiBvcHRpb25zLnB1YmxpY1Rva2VuLFxuICAgICAgICAgICAgcHJpdmF0ZUtleTogb3B0aW9ucy5wcml2YXRlS2V5LFxuICAgICAgICAgICAgand0OiB0b2tlbnMuand0LFxuICAgICAgICAgICAgZXhwaXJlc0F0OiB0b2tlbnMuZXhwaXJlc0F0XG4gICAgICAgICAgfSk7XG5cbiAgICAgICAgICBjb25zb2xlLmxvZyhjaGFsay5ncmVlbign4pyTIExvZ2dlZCBpbiBzdWNjZXNzZnVsbHkhJykpO1xuICAgICAgICAgIGNvbnNvbGUubG9nKGNoYWxrLmdyYXkoJ1Rva2VuIGV4cGlyZXMgYXQ6JyksIG5ldyBEYXRlKHRva2Vucy5leHBpcmVzQXQpLnRvSVNPU3RyaW5nKCkpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgIGNvbnNvbGUuZXJyb3IoY2hhbGsucmVkKCdFcnJvcjonKSwgcmVzcG9uc2UuZXJyb3I/Lm1lc3NhZ2UgfHwgJ0xvZ2luIGZhaWxlZCcpO1xuICAgICAgICB9XG4gICAgICB9IGNhdGNoIChlcnJvcikge1xuICAgICAgICBjb25zb2xlLmVycm9yKGNoYWxrLnJlZCgnRXJyb3I6JyksIGVycm9yIGluc3RhbmNlb2YgRXJyb3IgPyBlcnJvci5tZXNzYWdlIDogJ1Vua25vd24gZXJyb3InKTtcbiAgICAgIH1cbiAgICB9KTtcblxuICBhdXRoXG4gICAgLmNvbW1hbmQoJ2xvZ291dCcpXG4gICAgLmRlc2NyaXB0aW9uKCdMb2dvdXQgZnJvbSBhIG5ldHdvcmsnKVxuICAgIC5yZXF1aXJlZE9wdGlvbignLW4sIC0tbmV0d29yayA8aWQ+JywgJ05ldHdvcmsgSUQnKVxuICAgIC5hY3Rpb24oYXN5bmMgKG9wdGlvbnMpID0+IHtcbiAgICAgIGF3YWl0IGNvbmZpZ01hbmFnZXIuY2xlYXJDcmVkZW50aWFscyhvcHRpb25zLm5ldHdvcmspO1xuICAgICAgY29uc29sZS5sb2coY2hhbGsuZ3JlZW4oJ+KckyBMb2dnZWQgb3V0IGZyb20gbmV0d29yazonKSwgb3B0aW9ucy5uZXR3b3JrKTtcbiAgICB9KTtcblxuICBhdXRoXG4gICAgLmNvbW1hbmQoJ3N0YXR1cycpXG4gICAgLmRlc2NyaXB0aW9uKCdTaG93IGF1dGhlbnRpY2F0aW9uIHN0YXR1cycpXG4gICAgLm9wdGlvbignLW4sIC0tbmV0d29yayA8aWQ+JywgJ05ldHdvcmsgSUQgdG8gY2hlY2snKVxuICAgIC5hY3Rpb24oYXN5bmMgKG9wdGlvbnMpID0+IHtcbiAgICAgIGNvbnN0IGNvbmZpZyA9IGF3YWl0IGNvbmZpZ01hbmFnZXIuZ2V0R2xvYmFsQ29uZmlnKCk7XG4gICAgICBjb25zb2xlLmxvZyhjaGFsay5jeWFuKCdBUEkgVVJMOicpLCBjb25maWcuYXBpVXJsKTtcbiAgICAgIGNvbnNvbGUubG9nKGNoYWxrLmN5YW4oJ0Zvcm1hdDonKSwgY29uZmlnLmRlZmF1bHRGb3JtYXQpO1xuICAgICAgY29uc29sZS5sb2coY2hhbGsuY3lhbignQ29uZmlnIGRpcjonKSwgY29uZmlnTWFuYWdlci5nZXRDb25maWdQYXRoKCkpO1xuICAgICAgXG4gICAgICBpZiAob3B0aW9ucy5uZXR3b3JrKSB7XG4gICAgICAgIGNvbnN0IGNyZWRzID0gYXdhaXQgY29uZmlnTWFuYWdlci5nZXRDcmVkZW50aWFscyhvcHRpb25zLm5ldHdvcmspO1xuICAgICAgICBpZiAoY3JlZHMpIHtcbiAgICAgICAgICBjb25zb2xlLmxvZyhjaGFsay5jeWFuKCdcXG5OZXR3b3JrOicpLCBvcHRpb25zLm5ldHdvcmspO1xuICAgICAgICAgIGNvbnNvbGUubG9nKGNoYWxrLmN5YW4oJ1B1YmxpYyBUb2tlbjonKSwgY3JlZHMucHVibGljVG9rZW4pO1xuICAgICAgICAgIGlmIChjcmVkcy5leHBpcmVzQXQpIHtcbiAgICAgICAgICAgIGNvbnN0IHZhbGlkID0gRGF0ZS5ub3coKSA8IGNyZWRzLmV4cGlyZXNBdDtcbiAgICAgICAgICAgIGNvbnNvbGUubG9nKGNoYWxrLmN5YW4oJ1Rva2VuIHZhbGlkOicpLCB2YWxpZCA/IGNoYWxrLmdyZWVuKCdZZXMnKSA6IGNoYWxrLnJlZCgnTm8gKGV4cGlyZWQpJykpO1xuICAgICAgICAgICAgY29uc29sZS5sb2coY2hhbGsuY3lhbignRXhwaXJlczonKSwgbmV3IERhdGUoY3JlZHMuZXhwaXJlc0F0KS50b0lTT1N0cmluZygpKTtcbiAgICAgICAgICB9XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgY29uc29sZS5sb2coY2hhbGsueWVsbG93KCdcXG5Ob3QgY29ubmVjdGVkIHRvIG5ldHdvcms6JyksIG9wdGlvbnMubmV0d29yayk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICB9KTtcbn1cbiJdfQ==
|