adp-agent 0.2.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/LICENSE +21 -0
- package/README.md +141 -0
- package/config.example.json +32 -0
- package/dist/agent-id.d.ts +9 -0
- package/dist/agent-id.js +118 -0
- package/dist/agent-id.js.map +1 -0
- package/dist/agent-id.test.d.ts +1 -0
- package/dist/agent-id.test.js +36 -0
- package/dist/agent-id.test.js.map +1 -0
- package/dist/canonical.d.ts +5 -0
- package/dist/canonical.js +35 -0
- package/dist/canonical.js.map +1 -0
- package/dist/canonical.test.d.ts +1 -0
- package/dist/canonical.test.js +33 -0
- package/dist/canonical.test.js.map +1 -0
- package/dist/capability-test.d.ts +1 -0
- package/dist/capability-test.js +108 -0
- package/dist/capability-test.js.map +1 -0
- package/dist/chat.d.ts +1 -0
- package/dist/chat.js +166 -0
- package/dist/chat.js.map +1 -0
- package/dist/contacts-test.d.ts +1 -0
- package/dist/contacts-test.js +225 -0
- package/dist/contacts-test.js.map +1 -0
- package/dist/crypto.d.ts +11 -0
- package/dist/crypto.js +103 -0
- package/dist/crypto.js.map +1 -0
- package/dist/crypto.test.d.ts +1 -0
- package/dist/crypto.test.js +40 -0
- package/dist/crypto.test.js.map +1 -0
- package/dist/discovery.d.ts +36 -0
- package/dist/discovery.js +291 -0
- package/dist/discovery.js.map +1 -0
- package/dist/envelope.d.ts +42 -0
- package/dist/envelope.js +58 -0
- package/dist/envelope.js.map +1 -0
- package/dist/gateway.d.ts +44 -0
- package/dist/gateway.js +255 -0
- package/dist/gateway.js.map +1 -0
- package/dist/index.d.ts +33 -0
- package/dist/index.js +75 -0
- package/dist/index.js.map +1 -0
- package/dist/integration-test.d.ts +1 -0
- package/dist/integration-test.js +206 -0
- package/dist/integration-test.js.map +1 -0
- package/dist/key-store.d.ts +10 -0
- package/dist/key-store.js +81 -0
- package/dist/key-store.js.map +1 -0
- package/dist/manifest.d.ts +35 -0
- package/dist/manifest.js +24 -0
- package/dist/manifest.js.map +1 -0
- package/dist/mdns-test.d.ts +1 -0
- package/dist/mdns-test.js +93 -0
- package/dist/mdns-test.js.map +1 -0
- package/dist/relay-peer-test.d.ts +1 -0
- package/dist/relay-peer-test.js +220 -0
- package/dist/relay-peer-test.js.map +1 -0
- package/dist/relay-test.d.ts +1 -0
- package/dist/relay-test.js +92 -0
- package/dist/relay-test.js.map +1 -0
- package/dist/relay.d.ts +60 -0
- package/dist/relay.js +277 -0
- package/dist/relay.js.map +1 -0
- package/dist/src/agent-id.d.ts +9 -0
- package/dist/src/agent-id.js +44 -0
- package/dist/src/agent-id.js.map +1 -0
- package/dist/src/agent-id.test.d.ts +1 -0
- package/dist/src/agent-id.test.js +36 -0
- package/dist/src/agent-id.test.js.map +1 -0
- package/dist/src/canonical.d.ts +5 -0
- package/dist/src/canonical.js +37 -0
- package/dist/src/canonical.js.map +1 -0
- package/dist/src/canonical.test.d.ts +1 -0
- package/dist/src/canonical.test.js +33 -0
- package/dist/src/canonical.test.js.map +1 -0
- package/dist/src/capabilities.d.ts +3 -0
- package/dist/src/capabilities.js +39 -0
- package/dist/src/capabilities.js.map +1 -0
- package/dist/src/config.d.ts +35 -0
- package/dist/src/config.js +3 -0
- package/dist/src/config.js.map +1 -0
- package/dist/src/contacts.d.ts +28 -0
- package/dist/src/contacts.js +118 -0
- package/dist/src/contacts.js.map +1 -0
- package/dist/src/crypto.d.ts +11 -0
- package/dist/src/crypto.js +83 -0
- package/dist/src/crypto.js.map +1 -0
- package/dist/src/crypto.test.d.ts +1 -0
- package/dist/src/crypto.test.js +40 -0
- package/dist/src/crypto.test.js.map +1 -0
- package/dist/src/discovery.d.ts +39 -0
- package/dist/src/discovery.js +317 -0
- package/dist/src/discovery.js.map +1 -0
- package/dist/src/envelope.d.ts +55 -0
- package/dist/src/envelope.js +95 -0
- package/dist/src/envelope.js.map +1 -0
- package/dist/src/gateway.d.ts +78 -0
- package/dist/src/gateway.js +540 -0
- package/dist/src/gateway.js.map +1 -0
- package/dist/src/index.d.ts +22 -0
- package/dist/src/index.js +81 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/key-rotation.d.ts +27 -0
- package/dist/src/key-rotation.js +41 -0
- package/dist/src/key-rotation.js.map +1 -0
- package/dist/src/key-store.d.ts +10 -0
- package/dist/src/key-store.js +81 -0
- package/dist/src/key-store.js.map +1 -0
- package/dist/src/logger.d.ts +9 -0
- package/dist/src/logger.js +18 -0
- package/dist/src/logger.js.map +1 -0
- package/dist/src/manifest.d.ts +37 -0
- package/dist/src/manifest.js +24 -0
- package/dist/src/manifest.js.map +1 -0
- package/dist/src/mcp-server.d.ts +38 -0
- package/dist/src/mcp-server.js +408 -0
- package/dist/src/mcp-server.js.map +1 -0
- package/dist/src/net-utils.d.ts +3 -0
- package/dist/src/net-utils.js +71 -0
- package/dist/src/net-utils.js.map +1 -0
- package/dist/src/registry/cache.d.ts +12 -0
- package/dist/src/registry/cache.js +45 -0
- package/dist/src/registry/cache.js.map +1 -0
- package/dist/src/registry/client.d.ts +43 -0
- package/dist/src/registry/client.js +245 -0
- package/dist/src/registry/client.js.map +1 -0
- package/dist/src/registry/config.d.ts +32 -0
- package/dist/src/registry/config.js +79 -0
- package/dist/src/registry/config.js.map +1 -0
- package/dist/src/registry/db.d.ts +10 -0
- package/dist/src/registry/db.js +97 -0
- package/dist/src/registry/db.js.map +1 -0
- package/dist/src/registry/index.d.ts +5 -0
- package/dist/src/registry/index.js +22 -0
- package/dist/src/registry/index.js.map +1 -0
- package/dist/src/registry/service.d.ts +45 -0
- package/dist/src/registry/service.js +802 -0
- package/dist/src/registry/service.js.map +1 -0
- package/dist/src/relay.d.ts +69 -0
- package/dist/src/relay.js +399 -0
- package/dist/src/relay.js.map +1 -0
- package/dist/src/task-manager.d.ts +55 -0
- package/dist/src/task-manager.js +150 -0
- package/dist/src/task-manager.js.map +1 -0
- package/dist/src/trust-store.d.ts +24 -0
- package/dist/src/trust-store.js +144 -0
- package/dist/src/trust-store.js.map +1 -0
- package/dist/src/webhook-client.d.ts +30 -0
- package/dist/src/webhook-client.js +78 -0
- package/dist/src/webhook-client.js.map +1 -0
- package/dist/start-mcp.d.ts +2 -0
- package/dist/start-mcp.js +126 -0
- package/dist/start-mcp.js.map +1 -0
- package/dist/start-registry.d.ts +2 -0
- package/dist/start-registry.js +33 -0
- package/dist/start-registry.js.map +1 -0
- package/dist/start-relay.d.ts +1 -0
- package/dist/start-relay.js +35 -0
- package/dist/start-relay.js.map +1 -0
- package/dist/start.d.ts +1 -0
- package/dist/start.js +364 -0
- package/dist/start.js.map +1 -0
- package/dist/task-manager.d.ts +55 -0
- package/dist/task-manager.js +145 -0
- package/dist/task-manager.js.map +1 -0
- package/dist/task-test.d.ts +1 -0
- package/dist/task-test.js +188 -0
- package/dist/task-test.js.map +1 -0
- package/dist/test-auth.d.ts +1 -0
- package/dist/test-auth.js +166 -0
- package/dist/test-auth.js.map +1 -0
- package/dist/test-key-rotation.d.ts +2 -0
- package/dist/test-key-rotation.js +114 -0
- package/dist/test-key-rotation.js.map +1 -0
- package/dist/test-registry.d.ts +2 -0
- package/dist/test-registry.js +123 -0
- package/dist/test-registry.js.map +1 -0
- package/dist/trust-store.d.ts +23 -0
- package/dist/trust-store.js +111 -0
- package/dist/trust-store.js.map +1 -0
- package/package.json +96 -0
- package/schema.sql +54 -0
package/dist/chat.js
ADDED
|
@@ -0,0 +1,166 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
const readline = __importStar(require("readline"));
|
|
37
|
+
const src_1 = require("./src");
|
|
38
|
+
const crypto_1 = require("./src/crypto");
|
|
39
|
+
const canonical_1 = require("./src/canonical");
|
|
40
|
+
const envelope_1 = require("./src/envelope");
|
|
41
|
+
const capabilities_1 = require("./src/capabilities");
|
|
42
|
+
const args = process.argv.slice(2).filter(a => a !== '--');
|
|
43
|
+
const tag = args.find(a => a.startsWith('agent')) || 'agent1';
|
|
44
|
+
const namespace = process.env.ADP_NAMESPACE || 'local';
|
|
45
|
+
const displayName = process.env.ADP_DISPLAY || tag.toUpperCase();
|
|
46
|
+
const PORT_BASE = 9900;
|
|
47
|
+
let peerWs = null;
|
|
48
|
+
let peerId = '';
|
|
49
|
+
let finalPort = PORT_BASE;
|
|
50
|
+
function printIncoming(from, text) {
|
|
51
|
+
process.stdout.write(`\x1b[2K\r` + `\x1b[36m[${from.slice(-12)}]\x1b[0m ${text}\n`);
|
|
52
|
+
rl.prompt(true);
|
|
53
|
+
}
|
|
54
|
+
let rl;
|
|
55
|
+
async function main() {
|
|
56
|
+
console.log(`
|
|
57
|
+
█████╗ ██████╗ ██████╗ ██████╗██╗ ██╗ █████╗ ████████╗
|
|
58
|
+
██╔══██╗██╔══██╗██╔══██╗ ██╔════╝██║ ██║██╔══██╗╚══██╔══╝
|
|
59
|
+
███████║██║ ██║██████╔╝ ██║ ███████║███████║ ██║
|
|
60
|
+
██╔══██║██║ ██║██╔═══╝ ██║ ██╔══██║██╔══██║ ██║
|
|
61
|
+
██║ ██║██████╔╝██║ ╚██████╗██║ ██║██║ ██║ ██║
|
|
62
|
+
╚═╝ ╚═╝╚═════╝ ╚═╝ ╚═════╝╚═╝ ╚═╝╚═╝ ╚═╝ ╚═╝
|
|
63
|
+
ADP Chat — v0.2
|
|
64
|
+
`);
|
|
65
|
+
finalPort = await (0, src_1.findAvailablePort)(PORT_BASE);
|
|
66
|
+
const { identity, isNew } = (0, src_1.loadOrCreateIdentity)(namespace, tag.replace('agent', 'peer-'), tag);
|
|
67
|
+
if (isNew) {
|
|
68
|
+
console.log(`🆕 New identity → .adp/keys/${tag}.key`);
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
console.log(`📂 Loaded identity → .adp/keys/${tag}.key`);
|
|
72
|
+
}
|
|
73
|
+
console.log(`🔑 ${identity.agentId.slice(0, 55)}...\n`);
|
|
74
|
+
const gateway = new src_1.Gateway({
|
|
75
|
+
port: finalPort,
|
|
76
|
+
host: '0.0.0.0',
|
|
77
|
+
secretKey: identity.secretKey,
|
|
78
|
+
agentId: identity.agentId,
|
|
79
|
+
displayName,
|
|
80
|
+
capabilities: src_1.STANDARD_CAPABILITIES,
|
|
81
|
+
skipVerification: false,
|
|
82
|
+
tofuEnabled: true,
|
|
83
|
+
});
|
|
84
|
+
gateway.registerCapability('custom:chat', (0, capabilities_1.createChatHandler)(identity.agentId, identity.secretKey, (from, text) => {
|
|
85
|
+
printIncoming(from, text);
|
|
86
|
+
}));
|
|
87
|
+
console.log(`🌐 ws://0.0.0.0:${finalPort}/adp`);
|
|
88
|
+
console.log(`🔎 mDNS discovery active\n`);
|
|
89
|
+
const discovery = new src_1.Discovery(identity.agentId, finalPort, {
|
|
90
|
+
onPeerDiscovered: async (peer) => {
|
|
91
|
+
peerId = peer.agentId;
|
|
92
|
+
process.stdout.write(`\r\x1b[2K🔗 Connecting to peer...\r`);
|
|
93
|
+
try {
|
|
94
|
+
peerWs = await (0, src_1.connectToAgent)(peer.agentId, `${peer.host}:${peer.port}`, identity.agentId);
|
|
95
|
+
console.log(`✅ Connected to ${peer.agentId.slice(0, 45)}...`);
|
|
96
|
+
console.log(` Type a message and press Enter to send.\n`);
|
|
97
|
+
rl.prompt(true);
|
|
98
|
+
}
|
|
99
|
+
catch {
|
|
100
|
+
console.log(`⚠️ Cannot connect to peer. Waiting for them to connect to us...\n`);
|
|
101
|
+
rl.prompt(true);
|
|
102
|
+
}
|
|
103
|
+
},
|
|
104
|
+
});
|
|
105
|
+
discovery.start();
|
|
106
|
+
rl = readline.createInterface({
|
|
107
|
+
input: process.stdin,
|
|
108
|
+
output: process.stdout,
|
|
109
|
+
prompt: '\x1b[32m> \x1b[0m',
|
|
110
|
+
terminal: true,
|
|
111
|
+
});
|
|
112
|
+
rl.prompt();
|
|
113
|
+
rl.on('line', (line) => {
|
|
114
|
+
const trimmed = line.trim();
|
|
115
|
+
if (!trimmed) {
|
|
116
|
+
rl.prompt();
|
|
117
|
+
return;
|
|
118
|
+
}
|
|
119
|
+
if (trimmed === '/quit' || trimmed === '/exit') {
|
|
120
|
+
console.log('\n👋 Goodbye!');
|
|
121
|
+
shutdown();
|
|
122
|
+
return;
|
|
123
|
+
}
|
|
124
|
+
if (trimmed === '/peers') {
|
|
125
|
+
const peers = discovery.getPeers();
|
|
126
|
+
if (peers.length === 0) {
|
|
127
|
+
console.log(' No peers discovered yet.');
|
|
128
|
+
}
|
|
129
|
+
else {
|
|
130
|
+
for (const p of peers) {
|
|
131
|
+
console.log(` ${p.agentId.slice(0, 50)}... @ ${p.host}:${p.port}`);
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
rl.prompt();
|
|
135
|
+
return;
|
|
136
|
+
}
|
|
137
|
+
if (!peerWs) {
|
|
138
|
+
console.log(' (no peer connected yet — waiting for mDNS discovery...)');
|
|
139
|
+
rl.prompt();
|
|
140
|
+
return;
|
|
141
|
+
}
|
|
142
|
+
const envelope = (0, crypto_1.signEnvelope)({
|
|
143
|
+
protocol: 'adp/0.2',
|
|
144
|
+
id: (0, envelope_1.generateMessageId)(),
|
|
145
|
+
from: identity.agentId,
|
|
146
|
+
to: peerId,
|
|
147
|
+
action: 'custom:chat',
|
|
148
|
+
params: { text: trimmed },
|
|
149
|
+
timestamp: new Date().toISOString(),
|
|
150
|
+
}, identity.secretKey, canonical_1.canonicalize);
|
|
151
|
+
peerWs.send(JSON.stringify(envelope));
|
|
152
|
+
process.stdout.write(`\x1b[2K\r` + `\x1b[33m[me]\x1b[0m ${trimmed}\n`);
|
|
153
|
+
rl.prompt(true);
|
|
154
|
+
});
|
|
155
|
+
rl.on('close', () => shutdown());
|
|
156
|
+
process.on('SIGINT', () => {
|
|
157
|
+
console.log('\n');
|
|
158
|
+
shutdown();
|
|
159
|
+
});
|
|
160
|
+
}
|
|
161
|
+
function shutdown() {
|
|
162
|
+
rl?.close();
|
|
163
|
+
process.exit(0);
|
|
164
|
+
}
|
|
165
|
+
main().catch(err => { console.error('❌', err); process.exit(1); });
|
|
166
|
+
//# sourceMappingURL=chat.js.map
|
package/dist/chat.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chat.js","sourceRoot":"","sources":["../chat.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,mDAAqC;AACrC,+BAKe;AACf,yCAA4C;AAC5C,+CAA+C;AAC/C,6CAAmD;AACnD,qDAAuD;AAEvD,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC;AAC3D,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,IAAI,QAAQ,CAAC;AAC9D,MAAM,SAAS,GAAG,OAAO,CAAC,GAAG,CAAC,aAAa,IAAI,OAAO,CAAC;AACvD,MAAM,WAAW,GAAG,OAAO,CAAC,GAAG,CAAC,WAAW,IAAI,GAAG,CAAC,WAAW,EAAE,CAAC;AAEjE,MAAM,SAAS,GAAG,IAAI,CAAC;AAEvB,IAAI,MAAM,GAAyC,IAAI,CAAC;AACxD,IAAI,MAAM,GAAG,EAAE,CAAC;AAChB,IAAI,SAAS,GAAW,SAAS,CAAC;AAElC,SAAS,aAAa,CAAC,IAAY,EAAE,IAAY;IAC/C,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,WAAW,GAAG,YAAY,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,YAAY,IAAI,IAAI,CAAC,CAAC;IACpF,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;AAClB,CAAC;AAED,IAAI,EAAsB,CAAC;AAE3B,KAAK,UAAU,IAAI;IACjB,OAAO,CAAC,GAAG,CAAC;;;;;;;;CAQb,CAAC,CAAC;IAED,SAAS,GAAG,MAAM,IAAA,uBAAiB,EAAC,SAAS,CAAC,CAAC;IAE/C,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,GAAG,IAAA,0BAAoB,EAAC,SAAS,EAAE,GAAG,CAAC,OAAO,CAAC,OAAO,EAAE,OAAO,CAAC,EAAE,GAAG,CAAC,CAAC;IAEhG,IAAI,KAAK,EAAE,CAAC;QACV,OAAO,CAAC,GAAG,CAAC,kCAAkC,GAAG,MAAM,CAAC,CAAC;IAC3D,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,GAAG,CAAC,qCAAqC,GAAG,MAAM,CAAC,CAAC;IAC9D,CAAC;IACD,OAAO,CAAC,GAAG,CAAC,OAAO,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC;IAEzD,MAAM,OAAO,GAAG,IAAI,aAAO,CAAC;QAC1B,IAAI,EAAE,SAAS;QACf,IAAI,EAAE,SAAS;QACf,SAAS,EAAE,QAAQ,CAAC,SAAS;QAC7B,OAAO,EAAE,QAAQ,CAAC,OAAO;QACzB,WAAW;QACX,YAAY,EAAE,2BAAqB;QACnC,gBAAgB,EAAE,KAAK;QACvB,WAAW,EAAE,IAAI;KAClB,CAAC,CAAC;IAEH,OAAO,CAAC,kBAAkB,CAAC,aAAa,EAAE,IAAA,gCAAiB,EACzD,QAAQ,CAAC,OAAO,EAChB,QAAQ,CAAC,SAAS,EAClB,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE;QACb,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IAC5B,CAAC,CACF,CAAC,CAAC;IAEH,OAAO,CAAC,GAAG,CAAC,oBAAoB,SAAS,MAAM,CAAC,CAAC;IACjD,OAAO,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAC;IAE3C,MAAM,SAAS,GAAG,IAAI,eAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,SAAS,EAAE;QAC3D,gBAAgB,EAAE,KAAK,EAAE,IAAoB,EAAE,EAAE;YAC/C,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC;YACtB,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,sCAAsC,CAAC,CAAC;YAC7D,IAAI,CAAC;gBACH,MAAM,GAAG,MAAM,IAAA,oBAAc,EAAC,IAAI,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,EAAE,EAAE,QAAQ,CAAC,OAAO,CAAC,CAAC;gBAC3F,OAAO,CAAC,GAAG,CAAC,mBAAmB,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC;gBAC/D,OAAO,CAAC,GAAG,CAAC,8CAA8C,CAAC,CAAC;gBAC5D,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;YAClB,CAAC;YAAC,MAAM,CAAC;gBACP,OAAO,CAAC,GAAG,CAAC,oEAAoE,CAAC,CAAC;gBAClF,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;YAClB,CAAC;QACH,CAAC;KACF,CAAC,CAAC;IAEH,SAAS,CAAC,KAAK,EAAE,CAAC;IAElB,EAAE,GAAG,QAAQ,CAAC,eAAe,CAAC;QAC5B,KAAK,EAAE,OAAO,CAAC,KAAK;QACpB,MAAM,EAAE,OAAO,CAAC,MAAM;QACtB,MAAM,EAAE,mBAAmB;QAC3B,QAAQ,EAAE,IAAI;KACf,CAAC,CAAC;IAEH,EAAE,CAAC,MAAM,EAAE,CAAC;IAEZ,EAAE,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,IAAY,EAAE,EAAE;QAC7B,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC;QAC5B,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,EAAE,CAAC,MAAM,EAAE,CAAC;YACZ,OAAO;QACT,CAAC;QAED,IAAI,OAAO,KAAK,OAAO,IAAI,OAAO,KAAK,OAAO,EAAE,CAAC;YAC/C,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;YAC7B,QAAQ,EAAE,CAAC;YACX,OAAO;QACT,CAAC;QAED,IAAI,OAAO,KAAK,QAAQ,EAAE,CAAC;YACzB,MAAM,KAAK,GAAG,SAAS,CAAC,QAAQ,EAAE,CAAC;YACnC,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACvB,OAAO,CAAC,GAAG,CAAC,6BAA6B,CAAC,CAAC;YAC7C,CAAC;iBAAM,CAAC;gBACN,KAAK,MAAM,CAAC,IAAI,KAAK,EAAE,CAAC;oBACtB,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,WAAW,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;gBACzE,CAAC;YACH,CAAC;YACD,EAAE,CAAC,MAAM,EAAE,CAAC;YACZ,OAAO;QACT,CAAC;QAED,IAAI,CAAC,MAAM,EAAE,CAAC;YACZ,OAAO,CAAC,GAAG,CAAC,4DAA4D,CAAC,CAAC;YAC1E,EAAE,CAAC,MAAM,EAAE,CAAC;YACZ,OAAO;QACT,CAAC;QAED,MAAM,QAAQ,GAAG,IAAA,qBAAY,EAAC;YAC5B,QAAQ,EAAE,SAAS;YACnB,EAAE,EAAE,IAAA,4BAAiB,GAAE;YACvB,IAAI,EAAE,QAAQ,CAAC,OAAO;YACtB,EAAE,EAAE,MAAM;YACV,MAAM,EAAE,aAAa;YACrB,MAAM,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE;YACzB,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;SACpC,EAAE,QAAQ,CAAC,SAAS,EAAE,wBAAY,CAAC,CAAC;QAErC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;QACtC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,WAAW,GAAG,uBAAuB,OAAO,IAAI,CAAC,CAAC;QACvE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAClB,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAC;IAEjC,OAAO,CAAC,EAAE,CAAC,QAAQ,EAAE,GAAG,EAAE;QACxB,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAClB,QAAQ,EAAE,CAAC;IACb,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAS,QAAQ;IACf,EAAE,EAAE,KAAK,EAAE,CAAC;IACZ,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAClB,CAAC;AAED,IAAI,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,EAAE,GAAG,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,225 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
const fs = __importStar(require("fs"));
|
|
37
|
+
const path = __importStar(require("path"));
|
|
38
|
+
const os = __importStar(require("os"));
|
|
39
|
+
const src_1 = require("./src");
|
|
40
|
+
const crypto_1 = require("./src/crypto");
|
|
41
|
+
const agent_id_1 = require("./src/agent-id");
|
|
42
|
+
const canonical_1 = require("./src/canonical");
|
|
43
|
+
const TEST_DIR = path.join(os.tmpdir(), 'adp-contacts-test-' + Date.now());
|
|
44
|
+
const CONTACTS_PATH = path.join(TEST_DIR, 'contacts.json');
|
|
45
|
+
function writeContacts(data) {
|
|
46
|
+
fs.mkdirSync(TEST_DIR, { recursive: true });
|
|
47
|
+
fs.writeFileSync(CONTACTS_PATH, JSON.stringify(data, null, 2));
|
|
48
|
+
}
|
|
49
|
+
async function run() {
|
|
50
|
+
console.log('═══════════════════════════════════════');
|
|
51
|
+
console.log(' ADP — Static Contacts 测试');
|
|
52
|
+
console.log('═══════════════════════════════════════\n');
|
|
53
|
+
const PORT = 9875;
|
|
54
|
+
console.log('--- Test 1: ContactStore load/save/roundtrip ---\n');
|
|
55
|
+
const kpA = (0, crypto_1.generateKeyPair)();
|
|
56
|
+
const agentAId = (0, agent_id_1.buildAgentId)(kpA.publicKey, 'test.local', 'agenta');
|
|
57
|
+
const kpB = (0, crypto_1.generateKeyPair)();
|
|
58
|
+
const agentBId = (0, agent_id_1.buildAgentId)(kpB.publicKey, 'test.local', 'agentb');
|
|
59
|
+
writeContacts({
|
|
60
|
+
[agentAId]: {
|
|
61
|
+
routes: [{ type: 'direct', address: '192.168.1.100:9800' }],
|
|
62
|
+
},
|
|
63
|
+
[agentBId]: {
|
|
64
|
+
routes: [
|
|
65
|
+
{ type: 'relay', relay: 'relay.example.com:9800', session_id: 'sess_abc' },
|
|
66
|
+
{ type: 'direct', address: '10.0.0.5:9800' },
|
|
67
|
+
],
|
|
68
|
+
trust: 'pinned',
|
|
69
|
+
public_key: (0, crypto_1.encodeBase64URL)(kpB.publicKey),
|
|
70
|
+
},
|
|
71
|
+
});
|
|
72
|
+
const cs = new src_1.ContactStore(CONTACTS_PATH);
|
|
73
|
+
await cs.load();
|
|
74
|
+
console.log(`Loaded ${cs.listAgentIds().length} contacts`);
|
|
75
|
+
const routes = cs.getRoutes(agentAId);
|
|
76
|
+
const routePass = routes !== null && routes.length === 1 && routes[0].type === 'direct';
|
|
77
|
+
console.log(`Routes for agentA: ${JSON.stringify(routes)}`);
|
|
78
|
+
console.log(` ${routePass ? '✅ PASS' : '❌ FAIL'}`);
|
|
79
|
+
const pinnedKey = cs.isPinned(agentAId);
|
|
80
|
+
console.log(`Is agentA pinned? ${pinnedKey !== null}`);
|
|
81
|
+
const notPinnedPass = pinnedKey === null;
|
|
82
|
+
console.log(` ${notPinnedPass ? '✅ PASS' : '❌ FAIL'}`);
|
|
83
|
+
const pinnedKeyB = cs.isPinned(agentBId);
|
|
84
|
+
console.log(`Is agentB pinned? ${pinnedKeyB !== null}`);
|
|
85
|
+
const pinnedPass = pinnedKeyB !== null;
|
|
86
|
+
console.log(` ${pinnedPass ? '✅ PASS' : '❌ FAIL'}\n`);
|
|
87
|
+
console.log('--- Test 2: ContactStore set/remove ---\n');
|
|
88
|
+
const kpC = (0, crypto_1.generateKeyPair)();
|
|
89
|
+
const agentCId = (0, agent_id_1.buildAgentId)(kpC.publicKey, 'test.local', 'agentc');
|
|
90
|
+
cs.set(agentCId, {
|
|
91
|
+
routes: [{ type: 'direct', address: '192.168.1.200:9800' }],
|
|
92
|
+
});
|
|
93
|
+
const hasCPass = cs.has(agentCId) && cs.listAgentIds().length === 3;
|
|
94
|
+
console.log(`After set: ${cs.listAgentIds().length} contacts, has agentC? ${cs.has(agentCId)}`);
|
|
95
|
+
console.log(` ${hasCPass ? '✅ PASS' : '❌ FAIL'}`);
|
|
96
|
+
cs.remove(agentCId);
|
|
97
|
+
const removedPass = !cs.has(agentCId) && cs.listAgentIds().length === 2;
|
|
98
|
+
console.log(`After remove: ${cs.listAgentIds().length} contacts, has agentC? ${cs.has(agentCId)}`);
|
|
99
|
+
console.log(` ${removedPass ? '✅ PASS' : '❌ FAIL'}\n`);
|
|
100
|
+
console.log('--- Test 3: Pinned trust — public_key matches agentId ---\n');
|
|
101
|
+
const tsMatch = new src_1.TrustStore();
|
|
102
|
+
const { pinned, conflicts } = cs.pinTrustedKeys(tsMatch);
|
|
103
|
+
console.log(`Pinned: ${JSON.stringify(pinned)}`);
|
|
104
|
+
console.log(`Conflicts: ${JSON.stringify(conflicts)}`);
|
|
105
|
+
const pinMatchPass = pinned.length === 1 && pinned[0] === agentBId && conflicts.length === 0;
|
|
106
|
+
console.log(` ${pinMatchPass ? '✅ PASS' : '❌ FAIL'}`);
|
|
107
|
+
const storedKey = tsMatch.getPublicKey(agentBId);
|
|
108
|
+
const keyMatchPass = storedKey !== null && Buffer.from(storedKey).equals(kpB.publicKey);
|
|
109
|
+
console.log(`Public key stored correctly? ${keyMatchPass}`);
|
|
110
|
+
console.log(` ${keyMatchPass ? '✅ PASS' : '❌ FAIL'}\n`);
|
|
111
|
+
console.log('--- Test 4: Pinned trust — public_key mismatch detected ---\n');
|
|
112
|
+
writeContacts({
|
|
113
|
+
[agentAId]: {
|
|
114
|
+
routes: [{ type: 'direct', address: '192.168.1.100:9800' }],
|
|
115
|
+
trust: 'pinned',
|
|
116
|
+
public_key: (0, crypto_1.encodeBase64URL)(kpB.publicKey),
|
|
117
|
+
},
|
|
118
|
+
});
|
|
119
|
+
const csBad = new src_1.ContactStore(CONTACTS_PATH);
|
|
120
|
+
await csBad.load();
|
|
121
|
+
const tsBad = new src_1.TrustStore();
|
|
122
|
+
const { pinned: pBad, conflicts: cBad } = csBad.pinTrustedKeys(tsBad);
|
|
123
|
+
console.log(`Pinned: ${JSON.stringify(pBad)}`);
|
|
124
|
+
console.log(`Conflicts: ${JSON.stringify(cBad)}`);
|
|
125
|
+
const conflictPass = pBad.length === 0 && cBad.length === 1 && cBad[0] === agentAId;
|
|
126
|
+
console.log(` ${conflictPass ? '✅ PASS' : '❌ FAIL'}\n`);
|
|
127
|
+
console.log('--- Test 5: Gateway integration — pinned trust bypasses TOFU ---\n');
|
|
128
|
+
writeContacts({
|
|
129
|
+
[agentAId]: {
|
|
130
|
+
routes: [{ type: 'direct', address: `localhost:${PORT}` }],
|
|
131
|
+
trust: 'pinned',
|
|
132
|
+
public_key: (0, crypto_1.encodeBase64URL)(kpA.publicKey),
|
|
133
|
+
},
|
|
134
|
+
});
|
|
135
|
+
const csGw = new src_1.ContactStore(CONTACTS_PATH);
|
|
136
|
+
await csGw.load();
|
|
137
|
+
const gateway = new src_1.Gateway({
|
|
138
|
+
port: PORT, host: 'localhost',
|
|
139
|
+
secretKey: kpA.secretKey, agentId: agentAId,
|
|
140
|
+
displayName: 'Agent A',
|
|
141
|
+
capabilities: [...src_1.STANDARD_CAPABILITIES],
|
|
142
|
+
skipVerification: false,
|
|
143
|
+
contacts: csGw,
|
|
144
|
+
});
|
|
145
|
+
await sleep(300);
|
|
146
|
+
const ws = await (0, src_1.connectToAgent)(agentAId, `localhost:${PORT}`, agentBId);
|
|
147
|
+
console.log('Agent B connected to A');
|
|
148
|
+
let pingReplyReceived = false;
|
|
149
|
+
ws.on('message', (raw) => {
|
|
150
|
+
const env = JSON.parse(raw.toString());
|
|
151
|
+
if (env.reply_to === 'ct_ping_001' && env.action === 'adp:ping') {
|
|
152
|
+
pingReplyReceived = true;
|
|
153
|
+
}
|
|
154
|
+
});
|
|
155
|
+
ws.send(JSON.stringify((0, crypto_1.signEnvelope)({
|
|
156
|
+
protocol: 'adp/0.2', id: 'ct_ping_001',
|
|
157
|
+
from: agentBId, to: agentAId,
|
|
158
|
+
action: 'adp:ping',
|
|
159
|
+
params: {},
|
|
160
|
+
timestamp: new Date().toISOString(),
|
|
161
|
+
}, kpB.secretKey, canonical_1.canonicalize)));
|
|
162
|
+
await sleep(800);
|
|
163
|
+
console.log(`Ping reply received? ${pingReplyReceived}`);
|
|
164
|
+
console.log(` ${pingReplyReceived ? '✅ PASS' : '❌ FAIL'}\n`);
|
|
165
|
+
ws.close();
|
|
166
|
+
gateway.close();
|
|
167
|
+
console.log('--- Test 6: Pinned trust with mismatched key causes TRUST_CONFLICT ---\n');
|
|
168
|
+
const kpEvil = (0, crypto_1.generateKeyPair)();
|
|
169
|
+
writeContacts({
|
|
170
|
+
[agentAId]: {
|
|
171
|
+
routes: [{ type: 'direct', address: `localhost:${PORT}` }],
|
|
172
|
+
trust: 'pinned',
|
|
173
|
+
public_key: (0, crypto_1.encodeBase64URL)(kpEvil.publicKey),
|
|
174
|
+
},
|
|
175
|
+
});
|
|
176
|
+
const csEvil = new src_1.ContactStore(CONTACTS_PATH);
|
|
177
|
+
await csEvil.load();
|
|
178
|
+
const { pinned: pinnedEvil, conflicts: conflictsEvil } = csEvil.pinTrustedKeys(new src_1.TrustStore());
|
|
179
|
+
console.log(`Pinned with evil key: pinned=${pinnedEvil.length}, conflicts=${conflictsEvil.length}`);
|
|
180
|
+
const evilPass = pinnedEvil.length === 0 && conflictsEvil.length === 1;
|
|
181
|
+
console.log(` ${evilPass ? '✅ PASS' : '❌ FAIL'}\n`);
|
|
182
|
+
console.log('--- Test 7: Save and reload contacts.json ---\n');
|
|
183
|
+
writeContacts({
|
|
184
|
+
[agentAId]: {
|
|
185
|
+
routes: [{ type: 'direct', address: '192.168.1.100:9800' }],
|
|
186
|
+
},
|
|
187
|
+
});
|
|
188
|
+
const csSave = new src_1.ContactStore(CONTACTS_PATH);
|
|
189
|
+
await csSave.load();
|
|
190
|
+
csSave.set(agentBId, {
|
|
191
|
+
routes: [{ type: 'direct', address: '10.0.0.5:9800' }],
|
|
192
|
+
});
|
|
193
|
+
await csSave.save();
|
|
194
|
+
const csReload = new src_1.ContactStore(CONTACTS_PATH);
|
|
195
|
+
await csReload.load();
|
|
196
|
+
const reloadPass = csReload.has(agentBId) && csReload.listAgentIds().length === 2;
|
|
197
|
+
console.log(`After save+reload: ${csReload.listAgentIds().length} contacts, has agentB? ${csReload.has(agentBId)}`);
|
|
198
|
+
console.log(` ${reloadPass ? '✅ PASS' : '❌ FAIL'}\n`);
|
|
199
|
+
cleanup();
|
|
200
|
+
console.log('═══════════════════════════════════════');
|
|
201
|
+
console.log(' ✅ Static Contacts 全部测试通过!');
|
|
202
|
+
console.log(' ✅ ContactStore load/save/roundtrip');
|
|
203
|
+
console.log(' ✅ ContactStore set/get/remove');
|
|
204
|
+
console.log(' ✅ Pinned trust — public_key matches');
|
|
205
|
+
console.log(' ✅ Pinned trust — public_key mismatch detected');
|
|
206
|
+
console.log(' ✅ Gateway integration — pinned trust bypasses TOFU');
|
|
207
|
+
console.log(' ✅ Evil key conflict detection');
|
|
208
|
+
console.log(' ✅ Save and reload persistence');
|
|
209
|
+
console.log('═══════════════════════════════════════\n');
|
|
210
|
+
}
|
|
211
|
+
function cleanup() {
|
|
212
|
+
try {
|
|
213
|
+
fs.rmSync(TEST_DIR, { recursive: true });
|
|
214
|
+
}
|
|
215
|
+
catch { }
|
|
216
|
+
}
|
|
217
|
+
function sleep(ms) {
|
|
218
|
+
return new Promise((r) => setTimeout(r, ms));
|
|
219
|
+
}
|
|
220
|
+
run().catch((err) => {
|
|
221
|
+
console.error('❌', err);
|
|
222
|
+
cleanup();
|
|
223
|
+
process.exit(1);
|
|
224
|
+
});
|
|
225
|
+
//# sourceMappingURL=contacts-test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"contacts-test.js","sourceRoot":"","sources":["../contacts-test.ts"],"names":[],"mappings":"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"}
|
package/dist/crypto.d.ts
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export interface KeyPair {
|
|
2
|
+
publicKey: Uint8Array;
|
|
3
|
+
secretKey: Uint8Array;
|
|
4
|
+
}
|
|
5
|
+
export declare function generateKeyPair(): KeyPair;
|
|
6
|
+
export declare function generateKeyPairFromSeed(seed: Uint8Array): KeyPair;
|
|
7
|
+
export declare function sign(secretKey: Uint8Array, message: Uint8Array): Uint8Array;
|
|
8
|
+
export declare function verify(publicKey: Uint8Array, message: Uint8Array, signature: Uint8Array): boolean;
|
|
9
|
+
export declare function signEnvelope(envelope: Record<string, unknown>, secretKey: Uint8Array, canonicalize: (obj: unknown) => string): Record<string, unknown>;
|
|
10
|
+
export declare function encodeBase64URL(data: Uint8Array): string;
|
|
11
|
+
export declare function decodeBase64URL(data: string): Uint8Array;
|
package/dist/crypto.js
ADDED
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.generateKeyPair = generateKeyPair;
|
|
37
|
+
exports.generateKeyPairFromSeed = generateKeyPairFromSeed;
|
|
38
|
+
exports.sign = sign;
|
|
39
|
+
exports.verify = verify;
|
|
40
|
+
exports.signEnvelope = signEnvelope;
|
|
41
|
+
exports.encodeBase64URL = encodeBase64URL;
|
|
42
|
+
exports.decodeBase64URL = decodeBase64URL;
|
|
43
|
+
const nacl = __importStar(require("tweetnacl"));
|
|
44
|
+
function generateKeyPair() {
|
|
45
|
+
const keypair = nacl.sign.keyPair();
|
|
46
|
+
return {
|
|
47
|
+
publicKey: keypair.publicKey,
|
|
48
|
+
secretKey: keypair.secretKey,
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
function generateKeyPairFromSeed(seed) {
|
|
52
|
+
if (seed.length !== 32) {
|
|
53
|
+
throw new Error('Seed must be 32 bytes');
|
|
54
|
+
}
|
|
55
|
+
const keypair = nacl.sign.keyPair.fromSeed(seed);
|
|
56
|
+
return {
|
|
57
|
+
publicKey: keypair.publicKey,
|
|
58
|
+
secretKey: keypair.secretKey,
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
function sign(secretKey, message) {
|
|
62
|
+
return nacl.sign.detached(message, secretKey);
|
|
63
|
+
}
|
|
64
|
+
function verify(publicKey, message, signature) {
|
|
65
|
+
return nacl.sign.detached.verify(message, signature, publicKey);
|
|
66
|
+
}
|
|
67
|
+
function signEnvelope(envelope, secretKey, canonicalize) {
|
|
68
|
+
const { sig: _ignoredSig, ...unsigned } = envelope;
|
|
69
|
+
const canonical = canonicalize(unsigned);
|
|
70
|
+
const messageBytes = new TextEncoder().encode(canonical);
|
|
71
|
+
const signatureBytes = sign(secretKey, messageBytes);
|
|
72
|
+
const sig = encodeBase64URL(signatureBytes);
|
|
73
|
+
return { ...unsigned, sig };
|
|
74
|
+
}
|
|
75
|
+
function encodeBase64URL(data) {
|
|
76
|
+
let result = '';
|
|
77
|
+
for (let i = 0; i < data.length; i += 3) {
|
|
78
|
+
const b1 = data[i];
|
|
79
|
+
const b2 = i + 1 < data.length ? data[i + 1] : 0;
|
|
80
|
+
const b3 = i + 2 < data.length ? data[i + 2] : 0;
|
|
81
|
+
result += BASE64_URL_CHARS[b1 >> 2];
|
|
82
|
+
result += BASE64_URL_CHARS[((b1 & 0x03) << 4) | (b2 >> 4)];
|
|
83
|
+
if (i + 1 < data.length) {
|
|
84
|
+
result += BASE64_URL_CHARS[((b2 & 0x0f) << 2) | (b3 >> 6)];
|
|
85
|
+
}
|
|
86
|
+
if (i + 2 < data.length) {
|
|
87
|
+
result += BASE64_URL_CHARS[b3 & 0x3f];
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
return result;
|
|
91
|
+
}
|
|
92
|
+
function decodeBase64URL(data) {
|
|
93
|
+
const padded = data.padEnd(data.length + (4 - data.length % 4) % 4, '=');
|
|
94
|
+
const base64 = padded.replace(/-/g, '+').replace(/_/g, '/');
|
|
95
|
+
const binary = Buffer.from(base64, 'base64').toString('binary');
|
|
96
|
+
const bytes = new Uint8Array(binary.length);
|
|
97
|
+
for (let i = 0; i < binary.length; i++) {
|
|
98
|
+
bytes[i] = binary.charCodeAt(i);
|
|
99
|
+
}
|
|
100
|
+
return bytes;
|
|
101
|
+
}
|
|
102
|
+
const BASE64_URL_CHARS = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_';
|
|
103
|
+
//# sourceMappingURL=crypto.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"crypto.js","sourceRoot":"","sources":["../src/crypto.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const crypto_1 = require("./crypto");
|
|
4
|
+
describe('Crypto', () => {
|
|
5
|
+
it('should generate key pair', () => {
|
|
6
|
+
const keypair = (0, crypto_1.generateKeyPair)();
|
|
7
|
+
expect(keypair.publicKey.length).toBe(32);
|
|
8
|
+
expect(keypair.secretKey.length).toBe(64);
|
|
9
|
+
});
|
|
10
|
+
it('should sign and verify', () => {
|
|
11
|
+
const keypair = (0, crypto_1.generateKeyPair)();
|
|
12
|
+
const message = new TextEncoder().encode('Hello, ADP!');
|
|
13
|
+
const signature = (0, crypto_1.sign)(keypair.secretKey, message);
|
|
14
|
+
expect(signature.length).toBe(64);
|
|
15
|
+
const isValid = (0, crypto_1.verify)(keypair.publicKey, message, signature);
|
|
16
|
+
expect(isValid).toBe(true);
|
|
17
|
+
});
|
|
18
|
+
it('should reject invalid signature', () => {
|
|
19
|
+
const keypair = (0, crypto_1.generateKeyPair)();
|
|
20
|
+
const message = new TextEncoder().encode('Hello, ADP!');
|
|
21
|
+
const wrongMessage = new TextEncoder().encode('Hello, World!');
|
|
22
|
+
const signature = (0, crypto_1.sign)(keypair.secretKey, message);
|
|
23
|
+
const isValid = (0, crypto_1.verify)(keypair.publicKey, wrongMessage, signature);
|
|
24
|
+
expect(isValid).toBe(false);
|
|
25
|
+
});
|
|
26
|
+
it('should encode and decode Base64URL', () => {
|
|
27
|
+
const data = new Uint8Array([0x00, 0x01, 0x02, 0x03, 0x04]);
|
|
28
|
+
const encoded = (0, crypto_1.encodeBase64URL)(data);
|
|
29
|
+
const decoded = (0, crypto_1.decodeBase64URL)(encoded);
|
|
30
|
+
expect(decoded).toEqual(data);
|
|
31
|
+
});
|
|
32
|
+
it('should handle Ed25519 public key encoding', () => {
|
|
33
|
+
const keypair = (0, crypto_1.generateKeyPair)();
|
|
34
|
+
const encoded = (0, crypto_1.encodeBase64URL)(keypair.publicKey);
|
|
35
|
+
expect(encoded.length).toBe(43);
|
|
36
|
+
const decoded = (0, crypto_1.decodeBase64URL)(encoded);
|
|
37
|
+
expect(decoded).toEqual(keypair.publicKey);
|
|
38
|
+
});
|
|
39
|
+
});
|
|
40
|
+
//# sourceMappingURL=crypto.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"crypto.test.js","sourceRoot":"","sources":["../src/crypto.test.ts"],"names":[],"mappings":";;AAAA,qCAA2F;AAE3F,QAAQ,CAAC,QAAQ,EAAE,GAAG,EAAE;IACtB,EAAE,CAAC,0BAA0B,EAAE,GAAG,EAAE;QAClC,MAAM,OAAO,GAAG,IAAA,wBAAe,GAAE,CAAC;QAElC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAC1C,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IAC5C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,wBAAwB,EAAE,GAAG,EAAE;QAChC,MAAM,OAAO,GAAG,IAAA,wBAAe,GAAE,CAAC;QAClC,MAAM,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;QAExD,MAAM,SAAS,GAAG,IAAA,aAAI,EAAC,OAAO,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QAEnD,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAElC,MAAM,OAAO,GAAG,IAAA,eAAM,EAAC,OAAO,CAAC,SAAS,EAAE,OAAO,EAAE,SAAS,CAAC,CAAC;QAC9D,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC7B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;QACzC,MAAM,OAAO,GAAG,IAAA,wBAAe,GAAE,CAAC;QAClC,MAAM,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;QACxD,MAAM,YAAY,GAAG,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;QAE/D,MAAM,SAAS,GAAG,IAAA,aAAI,EAAC,OAAO,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QAEnD,MAAM,OAAO,GAAG,IAAA,eAAM,EAAC,OAAO,CAAC,SAAS,EAAE,YAAY,EAAE,SAAS,CAAC,CAAC;QACnE,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oCAAoC,EAAE,GAAG,EAAE;QAC5C,MAAM,IAAI,GAAG,IAAI,UAAU,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC;QAC5D,MAAM,OAAO,GAAG,IAAA,wBAAe,EAAC,IAAI,CAAC,CAAC;QACtC,MAAM,OAAO,GAAG,IAAA,wBAAe,EAAC,OAAO,CAAC,CAAC;QAEzC,MAAM,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE,GAAG,EAAE;QACnD,MAAM,OAAO,GAAG,IAAA,wBAAe,GAAE,CAAC;QAClC,MAAM,OAAO,GAAG,IAAA,wBAAe,EAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QAEnD,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAEhC,MAAM,OAAO,GAAG,IAAA,wBAAe,EAAC,OAAO,CAAC,CAAC;QACzC,MAAM,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import mDNS from 'multicast-dns';
|
|
2
|
+
export interface DiscoveredPeer {
|
|
3
|
+
agentId: string;
|
|
4
|
+
host: string;
|
|
5
|
+
port: number;
|
|
6
|
+
protocol: string;
|
|
7
|
+
lastSeen: number;
|
|
8
|
+
}
|
|
9
|
+
export interface DiscoveryCallbacks {
|
|
10
|
+
onPeerDiscovered?: (peer: DiscoveredPeer) => void;
|
|
11
|
+
onPeerLost?: (agentId: string) => void;
|
|
12
|
+
}
|
|
13
|
+
export declare function getSharedMdns(): mDNS.MulticastDNS;
|
|
14
|
+
export declare class Discovery {
|
|
15
|
+
private mdns;
|
|
16
|
+
private ownsMdns;
|
|
17
|
+
private agentId;
|
|
18
|
+
private port;
|
|
19
|
+
private instanceName;
|
|
20
|
+
private hostname;
|
|
21
|
+
private callbacks;
|
|
22
|
+
private peers;
|
|
23
|
+
private announceTimer;
|
|
24
|
+
private browseTimer;
|
|
25
|
+
private staleTimer;
|
|
26
|
+
private running;
|
|
27
|
+
constructor(agentId: string, port: number, callbacks?: DiscoveryCallbacks, mdnsInstance?: mDNS.MulticastDNS);
|
|
28
|
+
start(): void;
|
|
29
|
+
private proactiveAnnounce;
|
|
30
|
+
private browse;
|
|
31
|
+
private cleanStale;
|
|
32
|
+
private parseTXT;
|
|
33
|
+
private getLocalIP;
|
|
34
|
+
getPeers(): DiscoveredPeer[];
|
|
35
|
+
shutdown(): void;
|
|
36
|
+
}
|