society-protocol 1.2.0 → 1.3.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/dist/benchmark/collector.d.ts +17 -0
- package/dist/benchmark/collector.d.ts.map +1 -0
- package/dist/benchmark/collector.js +36 -0
- package/dist/benchmark/collector.js.map +1 -0
- package/dist/benchmark/reporter.d.ts +17 -0
- package/dist/benchmark/reporter.d.ts.map +1 -0
- package/dist/benchmark/reporter.js +140 -0
- package/dist/benchmark/reporter.js.map +1 -0
- package/dist/benchmark/types.d.ts +63 -0
- package/dist/benchmark/types.d.ts.map +1 -0
- package/dist/benchmark/types.js +6 -0
- package/dist/benchmark/types.js.map +1 -0
- package/dist/identity-proof.d.ts +43 -0
- package/dist/identity-proof.d.ts.map +1 -0
- package/dist/identity-proof.js +98 -0
- package/dist/identity-proof.js.map +1 -0
- package/dist/lib.d.ts +4 -0
- package/dist/lib.d.ts.map +1 -1
- package/dist/lib.js +3 -0
- package/dist/lib.js.map +1 -1
- package/dist/persona/types.d.ts +1 -1
- package/dist/persona/types.d.ts.map +1 -1
- package/dist/persona/zkp/engine.d.ts.map +1 -1
- package/dist/persona/zkp/engine.js +8 -0
- package/dist/persona/zkp/engine.js.map +1 -1
- package/dist/reputation.d.ts +10 -0
- package/dist/reputation.d.ts.map +1 -1
- package/dist/reputation.js +23 -4
- package/dist/reputation.js.map +1 -1
- package/dist/rooms.d.ts +11 -0
- package/dist/rooms.d.ts.map +1 -1
- package/dist/rooms.js +38 -0
- package/dist/rooms.js.map +1 -1
- package/dist/sdk/index.d.ts +1 -1
- package/dist/sdk/index.js +1 -1
- package/dist/swp.d.ts +1 -1
- package/dist/swp.d.ts.map +1 -1
- package/dist/swp.js.map +1 -1
- package/package.json +2 -1
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ProtocolBench — In-memory metrics collector.
|
|
3
|
+
*/
|
|
4
|
+
import type { MetricsCollector, CollectedMetrics } from './types.js';
|
|
5
|
+
export declare class InMemoryMetricsCollector implements MetricsCollector {
|
|
6
|
+
private messages;
|
|
7
|
+
private tasks;
|
|
8
|
+
private faults;
|
|
9
|
+
private recoveries;
|
|
10
|
+
recordMessage(type: string, sizeBytes: number, latencyMs: number): void;
|
|
11
|
+
recordTaskCompletion(success: boolean, qualityScore?: number): void;
|
|
12
|
+
recordFault(type: string): void;
|
|
13
|
+
recordRecovery(type: string, recoveryMs: number): void;
|
|
14
|
+
snapshot(): CollectedMetrics;
|
|
15
|
+
reset(): void;
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=collector.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"collector.d.ts","sourceRoot":"","sources":["../../src/benchmark/collector.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAErE,qBAAa,wBAAyB,YAAW,gBAAgB;IAC7D,OAAO,CAAC,QAAQ,CAAoC;IACpD,OAAO,CAAC,KAAK,CAAiC;IAC9C,OAAO,CAAC,MAAM,CAAkC;IAChD,OAAO,CAAC,UAAU,CAAsC;IAExD,aAAa,CAAC,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IAIvE,oBAAoB,CAAC,OAAO,EAAE,OAAO,EAAE,YAAY,GAAE,MAA4B,GAAG,IAAI;IAIxF,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAI/B,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,IAAI;IAItD,QAAQ,IAAI,gBAAgB;IAS5B,KAAK,IAAI,IAAI;CAMhB"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ProtocolBench — In-memory metrics collector.
|
|
3
|
+
*/
|
|
4
|
+
export class InMemoryMetricsCollector {
|
|
5
|
+
messages = [];
|
|
6
|
+
tasks = [];
|
|
7
|
+
faults = [];
|
|
8
|
+
recoveries = [];
|
|
9
|
+
recordMessage(type, sizeBytes, latencyMs) {
|
|
10
|
+
this.messages.push({ type, sizeBytes, latencyMs, timestamp: Date.now() });
|
|
11
|
+
}
|
|
12
|
+
recordTaskCompletion(success, qualityScore = success ? 1.0 : 0.0) {
|
|
13
|
+
this.tasks.push({ success, qualityScore, timestamp: Date.now() });
|
|
14
|
+
}
|
|
15
|
+
recordFault(type) {
|
|
16
|
+
this.faults.push({ type, timestamp: Date.now() });
|
|
17
|
+
}
|
|
18
|
+
recordRecovery(type, recoveryMs) {
|
|
19
|
+
this.recoveries.push({ type, recoveryMs, timestamp: Date.now() });
|
|
20
|
+
}
|
|
21
|
+
snapshot() {
|
|
22
|
+
return {
|
|
23
|
+
messages: [...this.messages],
|
|
24
|
+
tasks: [...this.tasks],
|
|
25
|
+
faults: [...this.faults],
|
|
26
|
+
recoveries: [...this.recoveries],
|
|
27
|
+
};
|
|
28
|
+
}
|
|
29
|
+
reset() {
|
|
30
|
+
this.messages = [];
|
|
31
|
+
this.tasks = [];
|
|
32
|
+
this.faults = [];
|
|
33
|
+
this.recoveries = [];
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=collector.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"collector.js","sourceRoot":"","sources":["../../src/benchmark/collector.ts"],"names":[],"mappings":"AAAA;;GAEG;AAIH,MAAM,OAAO,wBAAwB;IACzB,QAAQ,GAAiC,EAAE,CAAC;IAC5C,KAAK,GAA8B,EAAE,CAAC;IACtC,MAAM,GAA+B,EAAE,CAAC;IACxC,UAAU,GAAmC,EAAE,CAAC;IAExD,aAAa,CAAC,IAAY,EAAE,SAAiB,EAAE,SAAiB;QAC5D,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;IAC9E,CAAC;IAED,oBAAoB,CAAC,OAAgB,EAAE,eAAuB,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG;QAC7E,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;IACtE,CAAC;IAED,WAAW,CAAC,IAAY;QACpB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;IACtD,CAAC;IAED,cAAc,CAAC,IAAY,EAAE,UAAkB;QAC3C,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;IACtE,CAAC;IAED,QAAQ;QACJ,OAAO;YACH,QAAQ,EAAE,CAAC,GAAG,IAAI,CAAC,QAAQ,CAAC;YAC5B,KAAK,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC;YACtB,MAAM,EAAE,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC;YACxB,UAAU,EAAE,CAAC,GAAG,IAAI,CAAC,UAAU,CAAC;SACnC,CAAC;IACN,CAAC;IAED,KAAK;QACD,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;QACnB,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;QAChB,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;QACjB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;IACzB,CAAC;CACJ"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ProtocolBench — Markdown report formatter.
|
|
3
|
+
*/
|
|
4
|
+
import type { ProtocolBenchReport, CollectedMetrics, BenchmarkScenarioResult } from './types.js';
|
|
5
|
+
/**
|
|
6
|
+
* Evaluate collected metrics into a 4-axis scenario result.
|
|
7
|
+
*/
|
|
8
|
+
export declare function evaluateScenario(scenario: string, metrics: CollectedMetrics, durationMs: number): BenchmarkScenarioResult;
|
|
9
|
+
/**
|
|
10
|
+
* Format a ProtocolBench report as markdown for console output.
|
|
11
|
+
*/
|
|
12
|
+
export declare function formatBenchmarkReport(report: ProtocolBenchReport): string;
|
|
13
|
+
/**
|
|
14
|
+
* Compute aggregate scores from scenario results.
|
|
15
|
+
*/
|
|
16
|
+
export declare function aggregateScenarios(scenarios: BenchmarkScenarioResult[]): ProtocolBenchReport['aggregate'];
|
|
17
|
+
//# sourceMappingURL=reporter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reporter.d.ts","sourceRoot":"","sources":["../../src/benchmark/reporter.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAE,mBAAmB,EAAE,gBAAgB,EAAiB,uBAAuB,EAAE,MAAM,YAAY,CAAC;AAWhH;;GAEG;AACH,wBAAgB,gBAAgB,CAC5B,QAAQ,EAAE,MAAM,EAChB,OAAO,EAAE,gBAAgB,EACzB,UAAU,EAAE,MAAM,GACnB,uBAAuB,CA6FzB;AAED;;GAEG;AACH,wBAAgB,qBAAqB,CAAC,MAAM,EAAE,mBAAmB,GAAG,MAAM,CA+BzE;AAED;;GAEG;AACH,wBAAgB,kBAAkB,CAAC,SAAS,EAAE,uBAAuB,EAAE,GAAG,mBAAmB,CAAC,WAAW,CAAC,CAWzG"}
|
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ProtocolBench — Markdown report formatter.
|
|
3
|
+
*/
|
|
4
|
+
/**
|
|
5
|
+
* Compute percentile from a sorted array of numbers.
|
|
6
|
+
*/
|
|
7
|
+
function percentile(sorted, p) {
|
|
8
|
+
if (sorted.length === 0)
|
|
9
|
+
return 0;
|
|
10
|
+
const idx = Math.ceil((p / 100) * sorted.length) - 1;
|
|
11
|
+
return sorted[Math.max(0, idx)];
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* Evaluate collected metrics into a 4-axis scenario result.
|
|
15
|
+
*/
|
|
16
|
+
export function evaluateScenario(scenario, metrics, durationMs) {
|
|
17
|
+
// Task Success
|
|
18
|
+
const totalTasks = metrics.tasks.length;
|
|
19
|
+
const successRate = totalTasks > 0
|
|
20
|
+
? metrics.tasks.filter(t => t.success).length / totalTasks
|
|
21
|
+
: 1.0;
|
|
22
|
+
const avgQuality = totalTasks > 0
|
|
23
|
+
? metrics.tasks.reduce((s, t) => s + t.qualityScore, 0) / totalTasks
|
|
24
|
+
: 1.0;
|
|
25
|
+
const taskSuccess = {
|
|
26
|
+
name: 'Task Success',
|
|
27
|
+
score: (successRate * 0.6 + avgQuality * 0.4),
|
|
28
|
+
metrics: {
|
|
29
|
+
success_rate: successRate,
|
|
30
|
+
avg_quality: avgQuality,
|
|
31
|
+
total_tasks: totalTasks,
|
|
32
|
+
},
|
|
33
|
+
};
|
|
34
|
+
// Latency & Throughput
|
|
35
|
+
const latencies = metrics.messages.map(m => m.latencyMs).sort((a, b) => a - b);
|
|
36
|
+
const p50 = percentile(latencies, 50);
|
|
37
|
+
const p95 = percentile(latencies, 95);
|
|
38
|
+
const p99 = percentile(latencies, 99);
|
|
39
|
+
const throughput = durationMs > 0 ? (metrics.messages.length / (durationMs / 1000)) : 0;
|
|
40
|
+
// Score: p95 < 100ms → 1.0, > 1000ms → 0.0 (log scale)
|
|
41
|
+
const latencyScore = p95 > 0
|
|
42
|
+
? Math.max(0, Math.min(1, 1 - (Math.log10(p95) - 2) / 1))
|
|
43
|
+
: 1.0;
|
|
44
|
+
const throughputScore = Math.min(1, throughput / 1000); // 1000 msgs/sec = 1.0
|
|
45
|
+
const latencyThroughput = {
|
|
46
|
+
name: 'Latency & Throughput',
|
|
47
|
+
score: latencyScore * 0.6 + throughputScore * 0.4,
|
|
48
|
+
metrics: {
|
|
49
|
+
p50_ms: p50,
|
|
50
|
+
p95_ms: p95,
|
|
51
|
+
p99_ms: p99,
|
|
52
|
+
throughput_msgs_sec: Math.round(throughput * 100) / 100,
|
|
53
|
+
},
|
|
54
|
+
};
|
|
55
|
+
// Message Overhead
|
|
56
|
+
const totalMessages = metrics.messages.length;
|
|
57
|
+
const totalBytes = metrics.messages.reduce((s, m) => s + m.sizeBytes, 0);
|
|
58
|
+
const msgsPerTask = totalTasks > 0 ? totalMessages / totalTasks : totalMessages;
|
|
59
|
+
// Score: fewer msgs per task is better; < 5 → 1.0, > 50 → 0.0
|
|
60
|
+
const overheadScore = msgsPerTask > 0
|
|
61
|
+
? Math.max(0, Math.min(1, 1 - (msgsPerTask - 5) / 45))
|
|
62
|
+
: 1.0;
|
|
63
|
+
const messageOverhead = {
|
|
64
|
+
name: 'Message Overhead',
|
|
65
|
+
score: overheadScore,
|
|
66
|
+
metrics: {
|
|
67
|
+
total_messages: totalMessages,
|
|
68
|
+
total_bytes: totalBytes,
|
|
69
|
+
msgs_per_task: Math.round(msgsPerTask * 100) / 100,
|
|
70
|
+
},
|
|
71
|
+
};
|
|
72
|
+
// Robustness
|
|
73
|
+
const totalFaults = metrics.faults.length;
|
|
74
|
+
const totalRecoveries = metrics.recoveries.length;
|
|
75
|
+
const recoveryRate = totalFaults > 0 ? totalRecoveries / totalFaults : 1.0;
|
|
76
|
+
const avgRecoveryMs = totalRecoveries > 0
|
|
77
|
+
? metrics.recoveries.reduce((s, r) => s + r.recoveryMs, 0) / totalRecoveries
|
|
78
|
+
: 0;
|
|
79
|
+
// Score: recovery rate * recovery speed factor
|
|
80
|
+
const recoverySpeed = avgRecoveryMs > 0
|
|
81
|
+
? Math.max(0, Math.min(1, 1 - (avgRecoveryMs - 100) / 900))
|
|
82
|
+
: 1.0;
|
|
83
|
+
const robustness = {
|
|
84
|
+
name: 'Robustness',
|
|
85
|
+
score: Math.min(recoveryRate, recoverySpeed),
|
|
86
|
+
metrics: {
|
|
87
|
+
total_faults: totalFaults,
|
|
88
|
+
total_recoveries: totalRecoveries,
|
|
89
|
+
recovery_rate: recoveryRate,
|
|
90
|
+
avg_recovery_ms: Math.round(avgRecoveryMs * 100) / 100,
|
|
91
|
+
},
|
|
92
|
+
};
|
|
93
|
+
return {
|
|
94
|
+
scenario,
|
|
95
|
+
duration_ms: durationMs,
|
|
96
|
+
axes: { taskSuccess, latencyThroughput, messageOverhead, robustness },
|
|
97
|
+
};
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* Format a ProtocolBench report as markdown for console output.
|
|
101
|
+
*/
|
|
102
|
+
export function formatBenchmarkReport(report) {
|
|
103
|
+
const lines = [];
|
|
104
|
+
lines.push(`# ProtocolBench Report — Society Protocol v${report.version}`);
|
|
105
|
+
lines.push(`Date: ${new Date(report.timestamp).toISOString()} | Platform: ${report.platform}`);
|
|
106
|
+
lines.push('');
|
|
107
|
+
lines.push('## Scenarios');
|
|
108
|
+
lines.push('| Scenario | Success | Latency | Overhead | Robustness | Duration |');
|
|
109
|
+
lines.push('|----------|---------|---------|----------|------------|----------|');
|
|
110
|
+
for (const s of report.scenarios) {
|
|
111
|
+
lines.push(`| ${s.scenario} ` +
|
|
112
|
+
`| ${(s.axes.taskSuccess.score * 100).toFixed(0)}% ` +
|
|
113
|
+
`| ${(s.axes.latencyThroughput.score * 100).toFixed(0)}% ` +
|
|
114
|
+
`| ${(s.axes.messageOverhead.score * 100).toFixed(0)}% ` +
|
|
115
|
+
`| ${(s.axes.robustness.score * 100).toFixed(0)}% ` +
|
|
116
|
+
`| ${s.duration_ms}ms |`);
|
|
117
|
+
}
|
|
118
|
+
lines.push('');
|
|
119
|
+
lines.push('## Aggregate Scores');
|
|
120
|
+
lines.push(`Task Success: ${(report.aggregate.taskSuccess * 100).toFixed(0)}% | ` +
|
|
121
|
+
`Latency: ${(report.aggregate.latencyThroughput * 100).toFixed(0)}% | ` +
|
|
122
|
+
`Overhead: ${(report.aggregate.messageOverhead * 100).toFixed(0)}% | ` +
|
|
123
|
+
`Robustness: ${(report.aggregate.robustness * 100).toFixed(0)}%`);
|
|
124
|
+
lines.push(`**Overall: ${(report.aggregate.overall * 100).toFixed(0)}%**`);
|
|
125
|
+
return lines.join('\n');
|
|
126
|
+
}
|
|
127
|
+
/**
|
|
128
|
+
* Compute aggregate scores from scenario results.
|
|
129
|
+
*/
|
|
130
|
+
export function aggregateScenarios(scenarios) {
|
|
131
|
+
const n = scenarios.length || 1;
|
|
132
|
+
const taskSuccess = scenarios.reduce((s, r) => s + r.axes.taskSuccess.score, 0) / n;
|
|
133
|
+
const latencyThroughput = scenarios.reduce((s, r) => s + r.axes.latencyThroughput.score, 0) / n;
|
|
134
|
+
const messageOverhead = scenarios.reduce((s, r) => s + r.axes.messageOverhead.score, 0) / n;
|
|
135
|
+
const robustness = scenarios.reduce((s, r) => s + r.axes.robustness.score, 0) / n;
|
|
136
|
+
// Weighted overall: success 35%, latency 25%, overhead 20%, robustness 20%
|
|
137
|
+
const overall = taskSuccess * 0.35 + latencyThroughput * 0.25 + messageOverhead * 0.20 + robustness * 0.20;
|
|
138
|
+
return { overall, taskSuccess, latencyThroughput, messageOverhead, robustness };
|
|
139
|
+
}
|
|
140
|
+
//# sourceMappingURL=reporter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reporter.js","sourceRoot":"","sources":["../../src/benchmark/reporter.ts"],"names":[],"mappings":"AAAA;;GAEG;AAIH;;GAEG;AACH,SAAS,UAAU,CAAC,MAAgB,EAAE,CAAS;IAC3C,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC;QAAE,OAAO,CAAC,CAAC;IAClC,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,GAAG,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;IACrD,OAAO,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;AACpC,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,gBAAgB,CAC5B,QAAgB,EAChB,OAAyB,EACzB,UAAkB;IAElB,eAAe;IACf,MAAM,UAAU,GAAG,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC;IACxC,MAAM,WAAW,GAAG,UAAU,GAAG,CAAC;QAC9B,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,MAAM,GAAG,UAAU;QAC1D,CAAC,CAAC,GAAG,CAAC;IACV,MAAM,UAAU,GAAG,UAAU,GAAG,CAAC;QAC7B,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,YAAY,EAAE,CAAC,CAAC,GAAG,UAAU;QACpE,CAAC,CAAC,GAAG,CAAC;IAEV,MAAM,WAAW,GAAkB;QAC/B,IAAI,EAAE,cAAc;QACpB,KAAK,EAAE,CAAC,WAAW,GAAG,GAAG,GAAG,UAAU,GAAG,GAAG,CAAC;QAC7C,OAAO,EAAE;YACL,YAAY,EAAE,WAAW;YACzB,WAAW,EAAE,UAAU;YACvB,WAAW,EAAE,UAAU;SAC1B;KACJ,CAAC;IAEF,uBAAuB;IACvB,MAAM,SAAS,GAAG,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;IAC/E,MAAM,GAAG,GAAG,UAAU,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;IACtC,MAAM,GAAG,GAAG,UAAU,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;IACtC,MAAM,GAAG,GAAG,UAAU,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;IACtC,MAAM,UAAU,GAAG,UAAU,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,UAAU,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAExF,uDAAuD;IACvD,MAAM,YAAY,GAAG,GAAG,GAAG,CAAC;QACxB,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QACzD,CAAC,CAAC,GAAG,CAAC;IACV,MAAM,eAAe,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,UAAU,GAAG,IAAI,CAAC,CAAC,CAAC,sBAAsB;IAE9E,MAAM,iBAAiB,GAAkB;QACrC,IAAI,EAAE,sBAAsB;QAC5B,KAAK,EAAE,YAAY,GAAG,GAAG,GAAG,eAAe,GAAG,GAAG;QACjD,OAAO,EAAE;YACL,MAAM,EAAE,GAAG;YACX,MAAM,EAAE,GAAG;YACX,MAAM,EAAE,GAAG;YACX,mBAAmB,EAAE,IAAI,CAAC,KAAK,CAAC,UAAU,GAAG,GAAG,CAAC,GAAG,GAAG;SAC1D;KACJ,CAAC;IAEF,mBAAmB;IACnB,MAAM,aAAa,GAAG,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC;IAC9C,MAAM,UAAU,GAAG,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;IACzE,MAAM,WAAW,GAAG,UAAU,GAAG,CAAC,CAAC,CAAC,CAAC,aAAa,GAAG,UAAU,CAAC,CAAC,CAAC,aAAa,CAAC;IAEhF,8DAA8D;IAC9D,MAAM,aAAa,GAAG,WAAW,GAAG,CAAC;QACjC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,WAAW,GAAG,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC;QACtD,CAAC,CAAC,GAAG,CAAC;IAEV,MAAM,eAAe,GAAkB;QACnC,IAAI,EAAE,kBAAkB;QACxB,KAAK,EAAE,aAAa;QACpB,OAAO,EAAE;YACL,cAAc,EAAE,aAAa;YAC7B,WAAW,EAAE,UAAU;YACvB,aAAa,EAAE,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,GAAG,CAAC,GAAG,GAAG;SACrD;KACJ,CAAC;IAEF,aAAa;IACb,MAAM,WAAW,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC;IAC1C,MAAM,eAAe,GAAG,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC;IAClD,MAAM,YAAY,GAAG,WAAW,GAAG,CAAC,CAAC,CAAC,CAAC,eAAe,GAAG,WAAW,CAAC,CAAC,CAAC,GAAG,CAAC;IAC3E,MAAM,aAAa,GAAG,eAAe,GAAG,CAAC;QACrC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,CAAC,CAAC,GAAG,eAAe;QAC5E,CAAC,CAAC,CAAC,CAAC;IAER,+CAA+C;IAC/C,MAAM,aAAa,GAAG,aAAa,GAAG,CAAC;QACnC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,aAAa,GAAG,GAAG,CAAC,GAAG,GAAG,CAAC,CAAC;QAC3D,CAAC,CAAC,GAAG,CAAC;IAEV,MAAM,UAAU,GAAkB;QAC9B,IAAI,EAAE,YAAY;QAClB,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,aAAa,CAAC;QAC5C,OAAO,EAAE;YACL,YAAY,EAAE,WAAW;YACzB,gBAAgB,EAAE,eAAe;YACjC,aAAa,EAAE,YAAY;YAC3B,eAAe,EAAE,IAAI,CAAC,KAAK,CAAC,aAAa,GAAG,GAAG,CAAC,GAAG,GAAG;SACzD;KACJ,CAAC;IAEF,OAAO;QACH,QAAQ;QACR,WAAW,EAAE,UAAU;QACvB,IAAI,EAAE,EAAE,WAAW,EAAE,iBAAiB,EAAE,eAAe,EAAE,UAAU,EAAE;KACxE,CAAC;AACN,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,qBAAqB,CAAC,MAA2B;IAC7D,MAAM,KAAK,GAAa,EAAE,CAAC;IAC3B,KAAK,CAAC,IAAI,CAAC,8CAA8C,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC;IAC3E,KAAK,CAAC,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,WAAW,EAAE,gBAAgB,MAAM,CAAC,QAAQ,EAAE,CAAC,CAAC;IAC/F,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACf,KAAK,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IAC3B,KAAK,CAAC,IAAI,CAAC,qEAAqE,CAAC,CAAC;IAClF,KAAK,CAAC,IAAI,CAAC,qEAAqE,CAAC,CAAC;IAElF,KAAK,MAAM,CAAC,IAAI,MAAM,CAAC,SAAS,EAAE,CAAC;QAC/B,KAAK,CAAC,IAAI,CACN,KAAK,CAAC,CAAC,QAAQ,GAAG;YAClB,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI;YACpD,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI;YAC1D,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI;YACxD,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI;YACnD,KAAK,CAAC,CAAC,WAAW,MAAM,CAC3B,CAAC;IACN,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACf,KAAK,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC;IAClC,KAAK,CAAC,IAAI,CACN,iBAAiB,CAAC,MAAM,CAAC,SAAS,CAAC,WAAW,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM;QACtE,YAAY,CAAC,MAAM,CAAC,SAAS,CAAC,iBAAiB,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM;QACvE,aAAa,CAAC,MAAM,CAAC,SAAS,CAAC,eAAe,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM;QACtE,eAAe,CAAC,MAAM,CAAC,SAAS,CAAC,UAAU,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CACnE,CAAC;IACF,KAAK,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,SAAS,CAAC,OAAO,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;IAE3E,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC5B,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,kBAAkB,CAAC,SAAoC;IACnE,MAAM,CAAC,GAAG,SAAS,CAAC,MAAM,IAAI,CAAC,CAAC;IAChC,MAAM,WAAW,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;IACpF,MAAM,iBAAiB,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;IAChG,MAAM,eAAe,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;IAC5F,MAAM,UAAU,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC;IAElF,2EAA2E;IAC3E,MAAM,OAAO,GAAG,WAAW,GAAG,IAAI,GAAG,iBAAiB,GAAG,IAAI,GAAG,eAAe,GAAG,IAAI,GAAG,UAAU,GAAG,IAAI,CAAC;IAE3G,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,iBAAiB,EAAE,eAAe,EAAE,UAAU,EAAE,CAAC;AACpF,CAAC"}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ProtocolBench — Types for multi-axis protocol evaluation.
|
|
3
|
+
* Based on: ProtocolBench (arxiv 2504.14476)
|
|
4
|
+
*/
|
|
5
|
+
export interface BenchmarkAxis {
|
|
6
|
+
name: string;
|
|
7
|
+
score: number;
|
|
8
|
+
metrics: Record<string, number>;
|
|
9
|
+
}
|
|
10
|
+
export interface BenchmarkScenarioResult {
|
|
11
|
+
scenario: string;
|
|
12
|
+
duration_ms: number;
|
|
13
|
+
axes: {
|
|
14
|
+
taskSuccess: BenchmarkAxis;
|
|
15
|
+
latencyThroughput: BenchmarkAxis;
|
|
16
|
+
messageOverhead: BenchmarkAxis;
|
|
17
|
+
robustness: BenchmarkAxis;
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
export interface ProtocolBenchReport {
|
|
21
|
+
version: string;
|
|
22
|
+
timestamp: number;
|
|
23
|
+
platform: string;
|
|
24
|
+
scenarios: BenchmarkScenarioResult[];
|
|
25
|
+
aggregate: {
|
|
26
|
+
overall: number;
|
|
27
|
+
taskSuccess: number;
|
|
28
|
+
latencyThroughput: number;
|
|
29
|
+
messageOverhead: number;
|
|
30
|
+
robustness: number;
|
|
31
|
+
};
|
|
32
|
+
}
|
|
33
|
+
export interface CollectedMetrics {
|
|
34
|
+
messages: {
|
|
35
|
+
type: string;
|
|
36
|
+
sizeBytes: number;
|
|
37
|
+
latencyMs: number;
|
|
38
|
+
timestamp: number;
|
|
39
|
+
}[];
|
|
40
|
+
tasks: {
|
|
41
|
+
success: boolean;
|
|
42
|
+
qualityScore: number;
|
|
43
|
+
timestamp: number;
|
|
44
|
+
}[];
|
|
45
|
+
faults: {
|
|
46
|
+
type: string;
|
|
47
|
+
timestamp: number;
|
|
48
|
+
}[];
|
|
49
|
+
recoveries: {
|
|
50
|
+
type: string;
|
|
51
|
+
recoveryMs: number;
|
|
52
|
+
timestamp: number;
|
|
53
|
+
}[];
|
|
54
|
+
}
|
|
55
|
+
export interface MetricsCollector {
|
|
56
|
+
recordMessage(type: string, sizeBytes: number, latencyMs: number): void;
|
|
57
|
+
recordTaskCompletion(success: boolean, qualityScore?: number): void;
|
|
58
|
+
recordFault(type: string): void;
|
|
59
|
+
recordRecovery(type: string, recoveryMs: number): void;
|
|
60
|
+
snapshot(): CollectedMetrics;
|
|
61
|
+
reset(): void;
|
|
62
|
+
}
|
|
63
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/benchmark/types.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,MAAM,WAAW,aAAa;IAC1B,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CACnC;AAED,MAAM,WAAW,uBAAuB;IACpC,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,IAAI,EAAE;QACF,WAAW,EAAE,aAAa,CAAC;QAC3B,iBAAiB,EAAE,aAAa,CAAC;QACjC,eAAe,EAAE,aAAa,CAAC;QAC/B,UAAU,EAAE,aAAa,CAAC;KAC7B,CAAC;CACL;AAED,MAAM,WAAW,mBAAmB;IAChC,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,uBAAuB,EAAE,CAAC;IACrC,SAAS,EAAE;QACP,OAAO,EAAE,MAAM,CAAC;QAChB,WAAW,EAAE,MAAM,CAAC;QACpB,iBAAiB,EAAE,MAAM,CAAC;QAC1B,eAAe,EAAE,MAAM,CAAC;QACxB,UAAU,EAAE,MAAM,CAAC;KACtB,CAAC;CACL;AAED,MAAM,WAAW,gBAAgB;IAC7B,QAAQ,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;IACtF,KAAK,EAAE;QAAE,OAAO,EAAE,OAAO,CAAC;QAAC,YAAY,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;IACvE,MAAM,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;IAC9C,UAAU,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAA;KAAE,EAAE,CAAC;CACzE;AAED,MAAM,WAAW,gBAAgB;IAC7B,aAAa,CAAC,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACxE,oBAAoB,CAAC,OAAO,EAAE,OAAO,EAAE,YAAY,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACpE,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI,CAAC;IAChC,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;IACvD,QAAQ,IAAI,gBAAgB,CAAC;IAC7B,KAAK,IAAI,IAAI,CAAC;CACjB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/benchmark/types.ts"],"names":[],"mappings":"AAAA;;;GAGG"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Society Protocol — ZKP Identity Proofs (Schnorr PoK)
|
|
3
|
+
*
|
|
4
|
+
* Non-interactive Schnorr proof of DID/key ownership via Fiat-Shamir.
|
|
5
|
+
* Ed25519 signatures ARE Schnorr signatures — we use ed.sign(challenge, key)
|
|
6
|
+
* as a zero-knowledge proof of private key ownership.
|
|
7
|
+
*
|
|
8
|
+
* Based on: Agent-OSI Layer 3 (arxiv 2602.13795)
|
|
9
|
+
*/
|
|
10
|
+
import { type Identity } from './identity.js';
|
|
11
|
+
export interface IdentityProof {
|
|
12
|
+
did: string;
|
|
13
|
+
challenge: string;
|
|
14
|
+
proof: string;
|
|
15
|
+
roomId: string;
|
|
16
|
+
timestamp: number;
|
|
17
|
+
nonce: string;
|
|
18
|
+
expiresAt: number;
|
|
19
|
+
}
|
|
20
|
+
export interface IdentityProofVerifyResult {
|
|
21
|
+
valid: boolean;
|
|
22
|
+
did: string;
|
|
23
|
+
reason?: string;
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Create a non-interactive Schnorr proof of DID ownership.
|
|
27
|
+
*
|
|
28
|
+
* The challenge is SHA-512(did || roomId || timestamp || nonce),
|
|
29
|
+
* and the proof is ed.sign(challenge, privateKey).
|
|
30
|
+
*/
|
|
31
|
+
export declare function createIdentityProof(identity: Identity, roomId: string, ttlMs?: number): IdentityProof;
|
|
32
|
+
/**
|
|
33
|
+
* Verify a non-interactive Schnorr proof of DID ownership.
|
|
34
|
+
*
|
|
35
|
+
* 1. Recompute the challenge from the proof fields
|
|
36
|
+
* 2. Extract public key from the DID
|
|
37
|
+
* 3. Verify the Ed25519 signature
|
|
38
|
+
* 4. Check TTL expiration
|
|
39
|
+
*/
|
|
40
|
+
export declare function verifyIdentityProof(proof: IdentityProof): IdentityProofVerifyResult;
|
|
41
|
+
export declare function serializeIdentityProof(proof: IdentityProof): Uint8Array;
|
|
42
|
+
export declare function deserializeIdentityProof(data: Uint8Array): IdentityProof;
|
|
43
|
+
//# sourceMappingURL=identity-proof.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"identity-proof.d.ts","sourceRoot":"","sources":["../src/identity-proof.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAMH,OAAO,EAAoB,KAAK,QAAQ,EAAE,MAAM,eAAe,CAAC;AAIhE,MAAM,WAAW,aAAa;IAC1B,GAAG,EAAE,MAAM,CAAC;IACZ,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,yBAAyB;IACtC,KAAK,EAAE,OAAO,CAAC;IACf,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,CAAC,EAAE,MAAM,CAAC;CACnB;AAMD;;;;;GAKG;AACH,wBAAgB,mBAAmB,CAC/B,QAAQ,EAAE,QAAQ,EAClB,MAAM,EAAE,MAAM,EACd,KAAK,GAAE,MAAuB,GAC/B,aAAa,CAuBf;AAID;;;;;;;GAOG;AACH,wBAAgB,mBAAmB,CAAC,KAAK,EAAE,aAAa,GAAG,yBAAyB,CAoCnF;AAID,wBAAgB,sBAAsB,CAAC,KAAK,EAAE,aAAa,GAAG,UAAU,CAEvE;AAED,wBAAgB,wBAAwB,CAAC,IAAI,EAAE,UAAU,GAAG,aAAa,CAExE"}
|
|
@@ -0,0 +1,98 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Society Protocol — ZKP Identity Proofs (Schnorr PoK)
|
|
3
|
+
*
|
|
4
|
+
* Non-interactive Schnorr proof of DID/key ownership via Fiat-Shamir.
|
|
5
|
+
* Ed25519 signatures ARE Schnorr signatures — we use ed.sign(challenge, key)
|
|
6
|
+
* as a zero-knowledge proof of private key ownership.
|
|
7
|
+
*
|
|
8
|
+
* Based on: Agent-OSI Layer 3 (arxiv 2602.13795)
|
|
9
|
+
*/
|
|
10
|
+
import * as ed from '@noble/ed25519';
|
|
11
|
+
import { sha512 } from '@noble/hashes/sha512';
|
|
12
|
+
import { toString as uint8ToString, fromString as uint8FromString } from 'uint8arrays';
|
|
13
|
+
import { randomBytes as cryptoRandomBytes } from 'crypto';
|
|
14
|
+
import { publicKeyFromDid } from './identity.js';
|
|
15
|
+
// ─── Proof Generation ───────────────────────────────────────────
|
|
16
|
+
const DEFAULT_TTL_MS = 300_000; // 5 minutes
|
|
17
|
+
/**
|
|
18
|
+
* Create a non-interactive Schnorr proof of DID ownership.
|
|
19
|
+
*
|
|
20
|
+
* The challenge is SHA-512(did || roomId || timestamp || nonce),
|
|
21
|
+
* and the proof is ed.sign(challenge, privateKey).
|
|
22
|
+
*/
|
|
23
|
+
export function createIdentityProof(identity, roomId, ttlMs = DEFAULT_TTL_MS) {
|
|
24
|
+
const timestamp = Date.now();
|
|
25
|
+
const nonce = uint8ToString(randomBytes(16), 'base16');
|
|
26
|
+
const expiresAt = timestamp + ttlMs;
|
|
27
|
+
// Build challenge: SHA-512(did || roomId || timestamp || nonce)
|
|
28
|
+
const challengeInput = `${identity.did}|${roomId}|${timestamp}|${nonce}`;
|
|
29
|
+
const challengeBytes = sha512(new TextEncoder().encode(challengeInput));
|
|
30
|
+
const challenge = uint8ToString(challengeBytes, 'base16');
|
|
31
|
+
// Sign the challenge as Schnorr PoK
|
|
32
|
+
const sig = ed.sign(challengeBytes, identity.privateKey);
|
|
33
|
+
const proof = uint8ToString(sig, 'base64');
|
|
34
|
+
return {
|
|
35
|
+
did: identity.did,
|
|
36
|
+
challenge,
|
|
37
|
+
proof,
|
|
38
|
+
roomId,
|
|
39
|
+
timestamp,
|
|
40
|
+
nonce,
|
|
41
|
+
expiresAt,
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
// ─── Proof Verification ────────────────────────────────────────
|
|
45
|
+
/**
|
|
46
|
+
* Verify a non-interactive Schnorr proof of DID ownership.
|
|
47
|
+
*
|
|
48
|
+
* 1. Recompute the challenge from the proof fields
|
|
49
|
+
* 2. Extract public key from the DID
|
|
50
|
+
* 3. Verify the Ed25519 signature
|
|
51
|
+
* 4. Check TTL expiration
|
|
52
|
+
*/
|
|
53
|
+
export function verifyIdentityProof(proof) {
|
|
54
|
+
// Check expiration
|
|
55
|
+
if (Date.now() > proof.expiresAt) {
|
|
56
|
+
return { valid: false, did: proof.did, reason: 'proof expired' };
|
|
57
|
+
}
|
|
58
|
+
// Recompute challenge
|
|
59
|
+
const challengeInput = `${proof.did}|${proof.roomId}|${proof.timestamp}|${proof.nonce}`;
|
|
60
|
+
const expectedChallengeBytes = sha512(new TextEncoder().encode(challengeInput));
|
|
61
|
+
const expectedChallenge = uint8ToString(expectedChallengeBytes, 'base16');
|
|
62
|
+
// Verify challenge matches
|
|
63
|
+
if (proof.challenge !== expectedChallenge) {
|
|
64
|
+
return { valid: false, did: proof.did, reason: 'challenge mismatch' };
|
|
65
|
+
}
|
|
66
|
+
// Extract public key from DID
|
|
67
|
+
let publicKey;
|
|
68
|
+
try {
|
|
69
|
+
publicKey = publicKeyFromDid(proof.did);
|
|
70
|
+
}
|
|
71
|
+
catch {
|
|
72
|
+
return { valid: false, did: proof.did, reason: 'invalid DID format' };
|
|
73
|
+
}
|
|
74
|
+
// Verify Ed25519 signature (Schnorr PoK)
|
|
75
|
+
try {
|
|
76
|
+
const sigBytes = uint8FromString(proof.proof, 'base64');
|
|
77
|
+
const valid = ed.verify(sigBytes, expectedChallengeBytes, publicKey);
|
|
78
|
+
if (!valid) {
|
|
79
|
+
return { valid: false, did: proof.did, reason: 'signature verification failed' };
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
catch {
|
|
83
|
+
return { valid: false, did: proof.did, reason: 'signature verification error' };
|
|
84
|
+
}
|
|
85
|
+
return { valid: true, did: proof.did };
|
|
86
|
+
}
|
|
87
|
+
// ─── Serialization ──────────────────────────────────────────────
|
|
88
|
+
export function serializeIdentityProof(proof) {
|
|
89
|
+
return new TextEncoder().encode(JSON.stringify(proof));
|
|
90
|
+
}
|
|
91
|
+
export function deserializeIdentityProof(data) {
|
|
92
|
+
return JSON.parse(new TextDecoder().decode(data));
|
|
93
|
+
}
|
|
94
|
+
// ─── Utility ────────────────────────────────────────────────────
|
|
95
|
+
function randomBytes(n) {
|
|
96
|
+
return new Uint8Array(cryptoRandomBytes(n));
|
|
97
|
+
}
|
|
98
|
+
//# sourceMappingURL=identity-proof.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"identity-proof.js","sourceRoot":"","sources":["../src/identity-proof.ts"],"names":[],"mappings":"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"}
|
package/dist/lib.d.ts
CHANGED
|
@@ -28,6 +28,10 @@ export { MCPBridge } from './bridges/mcp-bridge.js';
|
|
|
28
28
|
export { A2ABridge } from './bridges/a2a-bridge.js';
|
|
29
29
|
export { registerNode, resolveNode, stopHeartbeat, generateFriendlyName } from './registry.js';
|
|
30
30
|
export { ContentStore, type FileManifest } from './content-store.js';
|
|
31
|
+
export { createIdentityProof, verifyIdentityProof, serializeIdentityProof, deserializeIdentityProof, type IdentityProof, type IdentityProofVerifyResult, } from './identity-proof.js';
|
|
32
|
+
export { InMemoryMetricsCollector } from './benchmark/collector.js';
|
|
33
|
+
export { evaluateScenario, formatBenchmarkReport, aggregateScenarios } from './benchmark/reporter.js';
|
|
34
|
+
export type { ProtocolBenchReport, BenchmarkScenarioResult, MetricsCollector } from './benchmark/types.js';
|
|
31
35
|
export { DemandSpawner, DEFAULT_SPAWN_CONFIG } from './gateway/demand-spawner.js';
|
|
32
36
|
export { CapabilityRouter } from './gateway/capability-router.js';
|
|
33
37
|
export { SocialEngine } from './social.js';
|
package/dist/lib.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"lib.d.ts","sourceRoot":"","sources":["../src/lib.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EACL,gBAAgB,EAChB,uBAAuB,EACvB,iBAAiB,EACjB,eAAe,EACf,aAAa,EACb,iBAAiB,EACjB,IAAI,EACJ,MAAM,EACN,gBAAgB,EAChB,KAAK,QAAQ,GACd,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,OAAO,EAAE,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AACpE,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AACrC,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EACL,aAAa,EACb,mBAAmB,EACnB,iBAAiB,EACjB,OAAO,EACP,UAAU,EACV,UAAU,EACV,KAAK,aAAa,EAClB,KAAK,cAAc,EACnB,KAAK,kBAAkB,EACvB,KAAK,gBAAgB,EACrB,KAAK,WAAW,EAChB,KAAK,uBAAuB,EAC5B,KAAK,qBAAqB,GAC3B,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAChD,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,sBAAsB,EAAE,MAAM,uBAAuB,CAAC;AAC/D,OAAO,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AACjE,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,EAAE,wBAAwB,EAAE,MAAM,4BAA4B,CAAC;AACtE,OAAO,EAAE,gBAAgB,EAAE,KAAK,sBAAsB,EAAE,KAAK,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAC/G,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAClE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,OAAO,EACL,gBAAgB,EAChB,KAAK,eAAe,EACpB,KAAK,qBAAqB,EAC1B,KAAK,WAAW,EAChB,oBAAoB,EACpB,SAAS,GACV,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAChD,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AACpD,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,aAAa,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AAC/F,OAAO,EAAE,YAAY,EAAE,KAAK,YAAY,EAAE,MAAM,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"lib.d.ts","sourceRoot":"","sources":["../src/lib.ts"],"names":[],"mappings":"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"}
|
package/dist/lib.js
CHANGED
|
@@ -28,6 +28,9 @@ export { MCPBridge } from './bridges/mcp-bridge.js';
|
|
|
28
28
|
export { A2ABridge } from './bridges/a2a-bridge.js';
|
|
29
29
|
export { registerNode, resolveNode, stopHeartbeat, generateFriendlyName } from './registry.js';
|
|
30
30
|
export { ContentStore } from './content-store.js';
|
|
31
|
+
export { createIdentityProof, verifyIdentityProof, serializeIdentityProof, deserializeIdentityProof, } from './identity-proof.js';
|
|
32
|
+
export { InMemoryMetricsCollector } from './benchmark/collector.js';
|
|
33
|
+
export { evaluateScenario, formatBenchmarkReport, aggregateScenarios } from './benchmark/reporter.js';
|
|
31
34
|
// Gateway — Demand-driven agent spawning
|
|
32
35
|
export { DemandSpawner, DEFAULT_SPAWN_CONFIG } from './gateway/demand-spawner.js';
|
|
33
36
|
export { CapabilityRouter } from './gateway/capability-router.js';
|
package/dist/lib.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"lib.js","sourceRoot":"","sources":["../src/lib.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EACL,gBAAgB,EAChB,uBAAuB,EACvB,iBAAiB,EACjB,eAAe,EACf,aAAa,EACb,iBAAiB,EACjB,IAAI,EACJ,MAAM,EACN,gBAAgB,GAEjB,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,OAAO,EAAE,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AACpE,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AACrC,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EACL,aAAa,EACb,mBAAmB,EACnB,iBAAiB,EACjB,OAAO,EACP,UAAU,EACV,UAAU,GAQX,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAChD,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,sBAAsB,EAAE,MAAM,uBAAuB,CAAC;AAC/D,OAAO,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AACjE,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,EAAE,wBAAwB,EAAE,MAAM,4BAA4B,CAAC;AACtE,OAAO,EAAE,gBAAgB,EAAuD,MAAM,wBAAwB,CAAC;AAC/G,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAClE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,OAAO,EACL,gBAAgB,EAIhB,oBAAoB,EACpB,SAAS,GACV,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAChD,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AACpD,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,aAAa,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AAC/F,OAAO,EAAE,YAAY,EAAqB,MAAM,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"lib.js","sourceRoot":"","sources":["../src/lib.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EACL,gBAAgB,EAChB,uBAAuB,EACvB,iBAAiB,EACjB,eAAe,EACf,aAAa,EACb,iBAAiB,EACjB,IAAI,EACJ,MAAM,EACN,gBAAgB,GAEjB,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,OAAO,EAAE,OAAO,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,UAAU,CAAC;AACpE,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAC;AACrC,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EACL,aAAa,EACb,mBAAmB,EACnB,iBAAiB,EACjB,OAAO,EACP,UAAU,EACV,UAAU,GAQX,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAChD,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAE,sBAAsB,EAAE,MAAM,uBAAuB,CAAC;AAC/D,OAAO,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAC;AACjE,OAAO,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAC1D,OAAO,EAAE,wBAAwB,EAAE,MAAM,4BAA4B,CAAC;AACtE,OAAO,EAAE,gBAAgB,EAAuD,MAAM,wBAAwB,CAAC;AAC/G,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAClE,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AACvC,OAAO,EACL,gBAAgB,EAIhB,oBAAoB,EACpB,SAAS,GACV,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC;AAChD,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AACpD,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,aAAa,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AAC/F,OAAO,EAAE,YAAY,EAAqB,MAAM,oBAAoB,CAAC;AACrE,OAAO,EACH,mBAAmB,EACnB,mBAAmB,EACnB,sBAAsB,EACtB,wBAAwB,GAG3B,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,wBAAwB,EAAE,MAAM,0BAA0B,CAAC;AACpE,OAAO,EAAE,gBAAgB,EAAE,qBAAqB,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAGtG,yCAAyC;AACzC,OAAO,EAAE,aAAa,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAClF,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAC;AAElE,eAAe;AACf,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAE3C,OAAO,EACL,YAAY,EACZ,OAAO,EACP,UAAU,EACV,aAAa,EACb,gBAAgB,EAChB,OAAO,IAAI,WAAW,GACvB,MAAM,gBAAgB,CAAC"}
|
package/dist/persona/types.d.ts
CHANGED
|
@@ -3,7 +3,7 @@ export type PersonaNodeId = string;
|
|
|
3
3
|
export type PersonaEdgeId = string;
|
|
4
4
|
export type PersonaClaimId = string;
|
|
5
5
|
export type ZkProofId = string;
|
|
6
|
-
export type ZkCircuitId = 'age_over_18' | 'domain_membership' | 'capability_possession';
|
|
6
|
+
export type ZkCircuitId = 'age_over_18' | 'domain_membership' | 'capability_possession' | 'did_ownership';
|
|
7
7
|
export type PersonaDomain = 'health' | 'work' | 'social' | 'family' | 'finance' | 'learning' | 'travel' | 'identity' | 'preferences' | 'general';
|
|
8
8
|
export type PersonaNodeType = 'entity' | 'event' | 'concept' | 'preference' | 'skill' | 'workflow' | 'claim' | 'memory';
|
|
9
9
|
export type PersonaRedactionOperation = 'read' | 'share' | 'export';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/persona/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,cAAc,GAAG,MAAM,CAAC;AACpC,MAAM,MAAM,aAAa,GAAG,MAAM,CAAC;AACnC,MAAM,MAAM,aAAa,GAAG,MAAM,CAAC;AACnC,MAAM,MAAM,cAAc,GAAG,MAAM,CAAC;AACpC,MAAM,MAAM,SAAS,GAAG,MAAM,CAAC;AAC/B,MAAM,MAAM,WAAW,GAAG,aAAa,GAAG,mBAAmB,GAAG,uBAAuB,CAAC;
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/persona/types.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"engine.d.ts","sourceRoot":"","sources":["../../../src/persona/zkp/engine.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAChD,OAAO,KAAK,EACR,oBAAoB,EACpB,kBAAkB,EAElB,aAAa,EACb,cAAc,EACjB,MAAM,aAAa,CAAC;AACrB,OAAO,KAAK,EAAE,WAAW,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;
|
|
1
|
+
{"version":3,"file":"engine.d.ts","sourceRoot":"","sources":["../../../src/persona/zkp/engine.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;AAChD,OAAO,KAAK,EACR,oBAAoB,EACpB,kBAAkB,EAElB,aAAa,EACb,cAAc,EACjB,MAAM,aAAa,CAAC;AACrB,OAAO,KAAK,EAAE,WAAW,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAC;AAwDrF,qBAAa,gBAAgB;IAQrB,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,WAAW;IARvB,OAAO,CAAC,aAAa,CAAS;IAC9B,OAAO,CAAC,YAAY,CAA6B;IACjD,OAAO,CAAC,UAAU,CAAC,CAAS;IAC5B,OAAO,CAAC,kBAAkB,CAAS;IACnC,OAAO,CAAC,eAAe,CAAgD;gBAG3D,OAAO,EAAE,OAAO,EAChB,WAAW,EAAE,MAAM,EAC3B,MAAM,CAAC,EAAE,MAAM;IAyBnB,YAAY,IAAI,mBAAmB,EAAE;IAarC,eAAe,CAAC,KAAK,EAAE,gBAAgB,GAAG,WAAW;IAUrD,aAAa,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,oBAAoB,GAAG,aAAa;IAuD1E,WAAW,CAAC,KAAK,EAAE,kBAAkB,GAAG,cAAc;IAoDtD,OAAO,CAAC,mBAAmB;IAU3B,OAAO,CAAC,YAAY;IAiCpB,OAAO,CAAC,mBAAmB;IAwC3B,OAAO,CAAC,iBAAiB;IAmCzB,OAAO,CAAC,aAAa;IAarB,OAAO,CAAC,gBAAgB;IAMxB,OAAO,CAAC,mBAAmB;IAgB3B,OAAO,CAAC,yBAAyB;CA8BpC"}
|
|
@@ -29,6 +29,14 @@ const DEFAULT_CIRCUITS = [
|
|
|
29
29
|
privateInputs: ['capabilityToken'],
|
|
30
30
|
active: true,
|
|
31
31
|
},
|
|
32
|
+
{
|
|
33
|
+
circuitId: 'did_ownership',
|
|
34
|
+
version: '1.0.0',
|
|
35
|
+
description: 'Prove ownership of a DID via Schnorr PoK without exposing private key.',
|
|
36
|
+
publicInputs: ['did', 'challenge', 'roomId'],
|
|
37
|
+
privateInputs: ['privateKey'],
|
|
38
|
+
active: true,
|
|
39
|
+
},
|
|
32
40
|
];
|
|
33
41
|
const ARTIFACTS_DIR = join(dirname(fileURLToPath(import.meta.url)), 'artifacts');
|
|
34
42
|
function canonical(value) {
|