@rubric-protocol/sdk 1.1.0 → 1.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/README.md +178 -90
- package/dist/background-queue.d.ts +57 -0
- package/dist/background-queue.d.ts.map +1 -0
- package/dist/background-queue.js +164 -0
- package/dist/background-queue.js.map +1 -0
- package/dist/index.d.ts +14 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +25 -20
- package/dist/index.js.map +1 -1
- package/dist/ml-dsa-local.d.ts +35 -0
- package/dist/ml-dsa-local.d.ts.map +1 -0
- package/dist/ml-dsa-local.js +151 -0
- package/dist/ml-dsa-local.js.map +1 -0
- package/dist/plugins/langchain.d.ts +30 -0
- package/dist/plugins/langchain.d.ts.map +1 -0
- package/dist/plugins/langchain.js +85 -0
- package/dist/plugins/langchain.js.map +1 -0
- package/dist/plugins/openai-plugin.d.ts +23 -0
- package/dist/plugins/openai-plugin.d.ts.map +1 -0
- package/dist/plugins/openai-plugin.js +72 -0
- package/dist/plugins/openai-plugin.js.map +1 -0
- package/dist/proof-types.d.ts +48 -0
- package/dist/proof-types.d.ts.map +1 -0
- package/dist/proof-types.js +105 -0
- package/dist/proof-types.js.map +1 -0
- package/dist/proof-upgrade-manager.d.ts +24 -0
- package/dist/proof-upgrade-manager.d.ts.map +1 -0
- package/dist/proof-upgrade-manager.js +103 -0
- package/dist/proof-upgrade-manager.js.map +1 -0
- package/dist/rubric-client.d.ts +104 -0
- package/dist/rubric-client.d.ts.map +1 -0
- package/dist/rubric-client.js +243 -0
- package/dist/rubric-client.js.map +1 -0
- package/dist/signing.d.ts +35 -0
- package/dist/signing.d.ts.map +1 -0
- package/dist/signing.js +151 -0
- package/dist/signing.js.map +1 -0
- package/package.json +43 -12
- package/dist/cli.d.ts +0 -30
- package/dist/cli.d.ts.map +0 -1
- package/dist/cli.js +0 -165
- package/dist/cli.js.map +0 -1
- package/dist/client.d.ts +0 -379
- package/dist/client.d.ts.map +0 -1
- package/dist/client.js +0 -447
- package/dist/client.js.map +0 -1
- package/dist/types.d.ts +0 -296
- package/dist/types.d.ts.map +0 -1
- package/dist/types.js +0 -6
- package/dist/types.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"proof-upgrade-manager.d.ts","sourceRoot":"","sources":["../proof-upgrade-manager.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,cAAc,EAAyC,MAAM,eAAe,CAAC;AAEjG,MAAM,WAAW,oBAAoB;IACnC,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAYD,qBAAa,mBAAmB;IAC9B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAiC;IACxD,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAmE;IAC3F,OAAO,CAAC,KAAK,CAA+C;gBAEhD,MAAM,EAAE,oBAAoB;IAIxC,KAAK,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI;IAM7B,aAAa,CAAC,SAAS,EAAE,cAAc,GAAG,SAAS;IAMnD,IAAI,IAAI,IAAI;IAKZ,IAAI,IAAI,IAAI,MAAM,CAA8B;IAEhD,OAAO,CAAC,cAAc;YAMR,KAAK;IA6BnB,OAAO,CAAC,aAAa;CAYtB;AAGD,wBAAgB,iBAAiB,CAAC,MAAM,CAAC,EAAE,oBAAoB,GAAG,mBAAmB,CAGpF;AACD,wBAAgB,mBAAmB,IAAI,IAAI,CAAmD"}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ProofUpgradeManager = void 0;
|
|
4
|
+
exports.getUpgradeManager = getUpgradeManager;
|
|
5
|
+
exports.resetUpgradeManager = resetUpgradeManager;
|
|
6
|
+
const proof_types_1 = require("./proof-types");
|
|
7
|
+
class ProofUpgradeManager {
|
|
8
|
+
constructor(config) {
|
|
9
|
+
this.tracked = new Map();
|
|
10
|
+
this.timer = null;
|
|
11
|
+
this.config = { pollInterval: 3000, maxTrackingAge: 120000, hcsTopicId: '0.0.8207826', ...config };
|
|
12
|
+
}
|
|
13
|
+
track(proof) {
|
|
14
|
+
if (proof.isConfirmed)
|
|
15
|
+
return;
|
|
16
|
+
this.tracked.set(proof.attestationId, { proof, trackedAt: Date.now() });
|
|
17
|
+
this._ensureRunning();
|
|
18
|
+
}
|
|
19
|
+
buildAndTrack(localData) {
|
|
20
|
+
const proof = new proof_types_1.LiveProof(localData);
|
|
21
|
+
this.track(proof);
|
|
22
|
+
return proof;
|
|
23
|
+
}
|
|
24
|
+
stop() {
|
|
25
|
+
if (this.timer) {
|
|
26
|
+
clearInterval(this.timer);
|
|
27
|
+
this.timer = null;
|
|
28
|
+
}
|
|
29
|
+
this.tracked.clear();
|
|
30
|
+
}
|
|
31
|
+
get size() { return this.tracked.size; }
|
|
32
|
+
_ensureRunning() {
|
|
33
|
+
if (this.timer)
|
|
34
|
+
return;
|
|
35
|
+
this.timer = setInterval(() => this._poll(), this.config.pollInterval);
|
|
36
|
+
if (typeof this.timer === 'object' && 'unref' in this.timer)
|
|
37
|
+
this.timer.unref();
|
|
38
|
+
}
|
|
39
|
+
async _poll() {
|
|
40
|
+
if (this.tracked.size === 0)
|
|
41
|
+
return;
|
|
42
|
+
const now = Date.now();
|
|
43
|
+
const toRemove = [];
|
|
44
|
+
const toFetch = [];
|
|
45
|
+
for (const [id, entry] of this.tracked) {
|
|
46
|
+
if (now - entry.trackedAt > this.config.maxTrackingAge) {
|
|
47
|
+
toRemove.push(id);
|
|
48
|
+
continue;
|
|
49
|
+
}
|
|
50
|
+
if (!entry.proof.isConfirmed)
|
|
51
|
+
toFetch.push({ id, proof: entry.proof });
|
|
52
|
+
else
|
|
53
|
+
toRemove.push(id);
|
|
54
|
+
}
|
|
55
|
+
for (const id of toRemove)
|
|
56
|
+
this.tracked.delete(id);
|
|
57
|
+
if (toFetch.length === 0)
|
|
58
|
+
return;
|
|
59
|
+
let statuses;
|
|
60
|
+
try {
|
|
61
|
+
const res = await fetch(`${this.config.baseUrl}/v1/proof-status/batch`, { method: 'POST', headers: { 'Content-Type': 'application/json', 'x-api-key': this.config.apiKey }, body: JSON.stringify({ attestationIds: toFetch.map(i => i.id) }), signal: AbortSignal.timeout(10000) });
|
|
62
|
+
if (!res.ok)
|
|
63
|
+
throw new Error(`HTTP ${res.status}`);
|
|
64
|
+
const data = await res.json();
|
|
65
|
+
statuses = data.statuses ?? data;
|
|
66
|
+
}
|
|
67
|
+
catch {
|
|
68
|
+
statuses = (await Promise.allSettled(toFetch.map(i => fetch(`${this.config.baseUrl}/v1/proof-status/${encodeURIComponent(i.id)}`, { headers: { 'x-api-key': this.config.apiKey }, signal: AbortSignal.timeout(10000) }).then(r => r.json())))).map(r => r.status === 'fulfilled' ? r.value : null).filter((s) => s !== null);
|
|
69
|
+
}
|
|
70
|
+
for (const status of statuses) {
|
|
71
|
+
const entry = this.tracked.get(status.attestationId);
|
|
72
|
+
if (!entry)
|
|
73
|
+
continue;
|
|
74
|
+
this._applyUpgrade(entry.proof, status);
|
|
75
|
+
if (entry.proof.isConfirmed)
|
|
76
|
+
this.tracked.delete(status.attestationId);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
_applyUpgrade(proof, status) {
|
|
80
|
+
if (status.stage === 'anchored' && proof.stage === 'local') {
|
|
81
|
+
const b = proof.data;
|
|
82
|
+
proof._upgrade({ stage: 'anchored', attestationId: proof.attestationId, agentId: proof.agentId, localSignature: b.localSignature, publicKey: b.publicKey, signedAt: b.signedAt, payload: b.payload, merkleRoot: status.merkleRoot, serverAttestationId: status.attestationId, anchoredAt: status.anchoredAt });
|
|
83
|
+
}
|
|
84
|
+
if (status.stage === 'confirmed') {
|
|
85
|
+
const b = proof.data;
|
|
86
|
+
const topicId = status.hcsTopicId ?? this.config.hcsTopicId;
|
|
87
|
+
const seqNum = status.hcsSequenceNumber;
|
|
88
|
+
proof._upgrade({ stage: 'confirmed', attestationId: proof.attestationId, agentId: proof.agentId, localSignature: b.localSignature ?? '', publicKey: b.publicKey ?? '', signedAt: b.signedAt ?? '', payload: b.payload ?? {}, merkleRoot: b.merkleRoot ?? status.merkleRoot ?? '', serverAttestationId: b.serverAttestationId ?? status.attestationId, anchoredAt: b.anchoredAt ?? new Date().toISOString(), hcsTopicId: topicId, hcsSequenceNumber: seqNum, hcsTimestamp: status.hcsTimestamp, hashScanUrl: `https://hashscan.io/testnet/topic/${topicId}/${seqNum}` });
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
exports.ProofUpgradeManager = ProofUpgradeManager;
|
|
93
|
+
let _globalManager = null;
|
|
94
|
+
function getUpgradeManager(config) {
|
|
95
|
+
if (!_globalManager) {
|
|
96
|
+
if (!config)
|
|
97
|
+
throw new Error('ProofUpgradeManager not initialized');
|
|
98
|
+
_globalManager = new ProofUpgradeManager(config);
|
|
99
|
+
}
|
|
100
|
+
return _globalManager;
|
|
101
|
+
}
|
|
102
|
+
function resetUpgradeManager() { _globalManager?.stop(); _globalManager = null; }
|
|
103
|
+
//# sourceMappingURL=proof-upgrade-manager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"proof-upgrade-manager.js","sourceRoot":"","sources":["../proof-upgrade-manager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import { QueueConfig } from './background-queue';
|
|
2
|
+
import { LiveProof, ConfirmedProofData } from './proof-types';
|
|
3
|
+
export interface RubricClientConfig {
|
|
4
|
+
apiKey: string;
|
|
5
|
+
node?: 'us' | 'sg' | 'jp' | 'ca' | 'eu' | 'auto';
|
|
6
|
+
localSigning?: boolean;
|
|
7
|
+
keystorePath?: string;
|
|
8
|
+
keystorePassphrase?: string;
|
|
9
|
+
backgroundQueue?: boolean;
|
|
10
|
+
queueConfig?: Partial<QueueConfig>;
|
|
11
|
+
endpoint?: string;
|
|
12
|
+
timeout?: number;
|
|
13
|
+
enterprise?: boolean;
|
|
14
|
+
proofUpgrade?: boolean;
|
|
15
|
+
}
|
|
16
|
+
export type RubricEventType = 'inference.decision' | 'inference.recommendation' | 'inference.classification' | 'inference.generation' | 'inference.screening' | 'inference.scoring' | 'human.review' | 'human.override' | 'human.approval' | 'human.rejection' | 'human.escalation' | 'model.deployment' | 'model.version-change' | 'model.retirement' | 'model.training-complete' | 'model.validation-complete' | 'model.calibration' | 'data.dataset-registered' | 'data.dataset-version' | 'data.quality-check' | 'data.drift-detected' | 'risk.assessment' | 'risk.mitigation-applied' | 'risk.threshold-breach' | 'risk.bias-detected' | 'incident.detected' | 'incident.reported' | 'incident.mitigated' | 'incident.resolved' | 'performance.benchmark' | 'performance.drift-detected' | 'performance.audit' | 'performance.monitoring' | 'compliance.conformity-assessed' | 'compliance.declaration-signed' | 'compliance.registration' | string;
|
|
17
|
+
export type OutcomeType = 'approved' | 'rejected' | 'referred' | 'deferred' | 'escalated' | 'flagged' | 'generated' | 'classified' | 'scored' | 'no-action' | string;
|
|
18
|
+
export type RiskLevel = 'minimal' | 'low' | 'medium' | 'high' | 'critical';
|
|
19
|
+
export type ModelTier = 'tier-1' | 'tier-2' | 'tier-3';
|
|
20
|
+
export type ValidationStatus = 'in-development' | 'pending-validation' | 'validated' | 'conditionally-approved' | 'approved' | 'under-review' | 'suspended' | 'retired';
|
|
21
|
+
export type IncidentSeverity = 'minor' | 'moderate' | 'serious' | 'critical';
|
|
22
|
+
export interface ComplianceFields {
|
|
23
|
+
rubricEventType?: RubricEventType;
|
|
24
|
+
systemId?: string;
|
|
25
|
+
systemVersion?: string;
|
|
26
|
+
modelVersion?: string;
|
|
27
|
+
modelHash?: string;
|
|
28
|
+
upstreamModelId?: string;
|
|
29
|
+
outcome?: OutcomeType;
|
|
30
|
+
confidence?: number;
|
|
31
|
+
latencyMs?: number;
|
|
32
|
+
inputHash?: string;
|
|
33
|
+
outputHash?: string;
|
|
34
|
+
sessionStartedAt?: string;
|
|
35
|
+
sessionEndedAt?: string;
|
|
36
|
+
workflowStep?: string;
|
|
37
|
+
reviewerId?: string;
|
|
38
|
+
reviewDecision?: 'confirmed' | 'overridden' | 'escalated' | 'deferred' | 'rejected-ai-output';
|
|
39
|
+
oversightMechanism?: string;
|
|
40
|
+
humanOverrideReason?: string;
|
|
41
|
+
riskLevel?: RiskLevel;
|
|
42
|
+
riskFactors?: string[];
|
|
43
|
+
populationGroup?: string;
|
|
44
|
+
affectedPersonCount?: number;
|
|
45
|
+
jurisdiction?: string[];
|
|
46
|
+
regulatoryContext?: string[];
|
|
47
|
+
standardsApplied?: string[];
|
|
48
|
+
incidentId?: string;
|
|
49
|
+
incidentSeverity?: IncidentSeverity;
|
|
50
|
+
modelTier?: ModelTier;
|
|
51
|
+
validationStatus?: ValidationStatus;
|
|
52
|
+
validationId?: string;
|
|
53
|
+
exceptionFlag?: boolean;
|
|
54
|
+
datasetId?: string;
|
|
55
|
+
datasetVersion?: string;
|
|
56
|
+
tags?: Record<string, string>;
|
|
57
|
+
}
|
|
58
|
+
export interface SystemRegistrationRequest {
|
|
59
|
+
systemId: string;
|
|
60
|
+
intendedUse: string;
|
|
61
|
+
jurisdiction: string[];
|
|
62
|
+
systemName?: string;
|
|
63
|
+
organizationName?: string;
|
|
64
|
+
contactEmail?: string;
|
|
65
|
+
description?: string;
|
|
66
|
+
}
|
|
67
|
+
export interface AttestationRequest extends ComplianceFields {
|
|
68
|
+
agentId: string;
|
|
69
|
+
sessionId?: string;
|
|
70
|
+
decision: string;
|
|
71
|
+
data?: Record<string, unknown>;
|
|
72
|
+
sourceId: string;
|
|
73
|
+
output?: string;
|
|
74
|
+
leafType?: string;
|
|
75
|
+
metadata?: Record<string, string | number | boolean>;
|
|
76
|
+
pipelineId?: string;
|
|
77
|
+
risk?: 'normal' | 'high';
|
|
78
|
+
payloadKey?: string;
|
|
79
|
+
}
|
|
80
|
+
export declare class RubricClient {
|
|
81
|
+
private readonly config;
|
|
82
|
+
private keyPair;
|
|
83
|
+
private queue;
|
|
84
|
+
private upgradeManager;
|
|
85
|
+
private nodeIndex;
|
|
86
|
+
private initialized;
|
|
87
|
+
constructor(config: RubricClientConfig);
|
|
88
|
+
init(): Promise<void>;
|
|
89
|
+
registerSystem(req: SystemRegistrationRequest): Promise<any>;
|
|
90
|
+
validatePayload(systemId: string, payload: Record<string, unknown>): Promise<any>;
|
|
91
|
+
attest(req: AttestationRequest): Promise<LiveProof>;
|
|
92
|
+
attestAndConfirm(req: AttestationRequest, timeoutMs?: number): Promise<ConfirmedProofData>;
|
|
93
|
+
shutdown(): Promise<void>;
|
|
94
|
+
queueStats(): import("./background-queue").QueueStats;
|
|
95
|
+
upgradeStats(): {
|
|
96
|
+
tracking: number;
|
|
97
|
+
};
|
|
98
|
+
private _submitInBackground;
|
|
99
|
+
private _submitAndTrack;
|
|
100
|
+
private _pollStatus;
|
|
101
|
+
private _endpoint;
|
|
102
|
+
}
|
|
103
|
+
export declare function createRubricClient(config: RubricClientConfig): RubricClient;
|
|
104
|
+
//# sourceMappingURL=rubric-client.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rubric-client.d.ts","sourceRoot":"","sources":["../rubric-client.ts"],"names":[],"mappings":"AACA,OAAO,EAAmB,WAAW,EAAE,MAAM,oBAAoB,CAAC;AAClE,OAAO,EAAE,SAAS,EAAkB,kBAAkB,EAAE,MAAM,eAAe,CAAC;AAM9E,MAAM,WAAW,kBAAkB;IACjC,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,GAAG,MAAM,CAAC;IACjD,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,WAAW,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,CAAC;IACnC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,YAAY,CAAC,EAAE,OAAO,CAAC;CACxB;AAED,MAAM,MAAM,eAAe,GACvB,oBAAoB,GAAG,0BAA0B,GAAG,0BAA0B,GAC9E,sBAAsB,GAAG,qBAAqB,GAAG,mBAAmB,GACpE,cAAc,GAAG,gBAAgB,GAAG,gBAAgB,GAAG,iBAAiB,GAAG,kBAAkB,GAC7F,kBAAkB,GAAG,sBAAsB,GAAG,kBAAkB,GAChE,yBAAyB,GAAG,2BAA2B,GAAG,mBAAmB,GAC7E,yBAAyB,GAAG,sBAAsB,GAAG,oBAAoB,GAAG,qBAAqB,GACjG,iBAAiB,GAAG,yBAAyB,GAAG,uBAAuB,GAAG,oBAAoB,GAC9F,mBAAmB,GAAG,mBAAmB,GAAG,oBAAoB,GAAG,mBAAmB,GACtF,uBAAuB,GAAG,4BAA4B,GAAG,mBAAmB,GAAG,wBAAwB,GACvG,gCAAgC,GAAG,+BAA+B,GAAG,yBAAyB,GAC9F,MAAM,CAAC;AAEX,MAAM,MAAM,WAAW,GAAG,UAAU,GAAG,UAAU,GAAG,UAAU,GAAG,UAAU,GAAG,WAAW,GACrF,SAAS,GAAG,WAAW,GAAG,YAAY,GAAG,QAAQ,GAAG,WAAW,GAAG,MAAM,CAAC;AAE7E,MAAM,MAAM,SAAS,GAAG,SAAS,GAAG,KAAK,GAAG,QAAQ,GAAG,MAAM,GAAG,UAAU,CAAC;AAC3E,MAAM,MAAM,SAAS,GAAG,QAAQ,GAAG,QAAQ,GAAG,QAAQ,CAAC;AACvD,MAAM,MAAM,gBAAgB,GAAG,gBAAgB,GAAG,oBAAoB,GAAG,WAAW,GAChF,wBAAwB,GAAG,UAAU,GAAG,cAAc,GAAG,WAAW,GAAG,SAAS,CAAC;AACrF,MAAM,MAAM,gBAAgB,GAAG,OAAO,GAAG,UAAU,GAAG,SAAS,GAAG,UAAU,CAAC;AAE7E,MAAM,WAAW,gBAAgB;IAE/B,eAAe,CAAC,EAAE,eAAe,CAAC;IAClC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,aAAa,CAAC,EAAE,MAAM,CAAC;IAEvB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,eAAe,CAAC,EAAE,MAAM,CAAC;IAEzB,OAAO,CAAC,EAAE,WAAW,CAAC;IACtB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,MAAM,CAAC;IAEpB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,YAAY,CAAC,EAAE,MAAM,CAAC;IAEtB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,cAAc,CAAC,EAAE,WAAW,GAAG,YAAY,GAAG,WAAW,GAAG,UAAU,GAAG,oBAAoB,CAAC;IAC9F,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAE7B,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,EAAE,CAAC;IACvB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAE7B,YAAY,CAAC,EAAE,MAAM,EAAE,CAAC;IACxB,iBAAiB,CAAC,EAAE,MAAM,EAAE,CAAC;IAC7B,gBAAgB,CAAC,EAAE,MAAM,EAAE,CAAC;IAE5B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,gBAAgB,CAAC,EAAE,gBAAgB,CAAC;IAEpC,SAAS,CAAC,EAAE,SAAS,CAAC;IACtB,gBAAgB,CAAC,EAAE,gBAAgB,CAAC;IACpC,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,aAAa,CAAC,EAAE,OAAO,CAAC;IAExB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,cAAc,CAAC,EAAE,MAAM,CAAC;IAExB,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CAC/B;AAED,MAAM,WAAW,yBAAyB;IACxC,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,EAAE,MAAM,EAAE,CAAC;IACvB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,kBAAmB,SAAQ,gBAAgB;IAC1D,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAC/B,QAAQ,EAAE,MAAM,CAAC;IAEjB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,CAAC,CAAC;IACrD,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,IAAI,CAAC,EAAE,QAAQ,GAAG,MAAM,CAAC;IACzB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAYD,qBAAa,YAAY;IACvB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAM;IAC7B,OAAO,CAAC,OAAO,CAA6B;IAC5C,OAAO,CAAC,KAAK,CAAgC;IAC7C,OAAO,CAAC,cAAc,CAAoC;IAC1D,OAAO,CAAC,SAAS,CAAK;IACtB,OAAO,CAAC,WAAW,CAAS;gBAEhB,MAAM,EAAE,kBAAkB;IAIhC,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAgBrB,cAAc,CAAC,GAAG,EAAE,yBAAyB,GAAG,OAAO,CAAC,GAAG,CAAC;IAY5D,eAAe,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,OAAO,CAAC,GAAG,CAAC;IAYjF,MAAM,CAAC,GAAG,EAAE,kBAAkB,GAAG,OAAO,CAAC,SAAS,CAAC;IA8BnD,gBAAgB,CAAC,GAAG,EAAE,kBAAkB,EAAE,SAAS,SAAS,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAK1F,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC;IAK/B,UAAU;IACV,YAAY;;;IAEZ,OAAO,CAAC,mBAAmB;IAI3B,OAAO,CAAC,eAAe;YA0BT,WAAW;IAoDzB,OAAO,CAAC,SAAS;CAKlB;AAED,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,kBAAkB,GAAG,YAAY,CAE3E"}
|
|
@@ -0,0 +1,243 @@
|
|
|
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.RubricClient = void 0;
|
|
37
|
+
exports.createRubricClient = createRubricClient;
|
|
38
|
+
const signing_1 = require("./signing");
|
|
39
|
+
const background_queue_1 = require("./background-queue");
|
|
40
|
+
const proof_types_1 = require("./proof-types");
|
|
41
|
+
const proof_upgrade_manager_1 = require("./proof-upgrade-manager");
|
|
42
|
+
const crypto = __importStar(require("crypto"));
|
|
43
|
+
const path = __importStar(require("path"));
|
|
44
|
+
const os = __importStar(require("os"));
|
|
45
|
+
// Endpoints are configured at runtime — not hardcoded in the SDK
|
|
46
|
+
// Set via RubricClientConfig.endpoint or RUBRIC_ENDPOINT environment variable
|
|
47
|
+
const NODES = {
|
|
48
|
+
us: process.env.RUBRIC_ENDPOINT_US || 'https://api.rubric-protocol.com/v1',
|
|
49
|
+
sg: process.env.RUBRIC_ENDPOINT_SG || 'https://api.rubric-protocol.com/v1',
|
|
50
|
+
jp: process.env.RUBRIC_ENDPOINT_JP || 'https://api.rubric-protocol.com/v1',
|
|
51
|
+
ca: process.env.RUBRIC_ENDPOINT_CA || 'https://api.rubric-protocol.com/v1',
|
|
52
|
+
eu: process.env.RUBRIC_ENDPOINT_EU || 'https://api.rubric-protocol.com/v1',
|
|
53
|
+
};
|
|
54
|
+
class RubricClient {
|
|
55
|
+
constructor(config) {
|
|
56
|
+
this.keyPair = null;
|
|
57
|
+
this.queue = null;
|
|
58
|
+
this.upgradeManager = null;
|
|
59
|
+
this.nodeIndex = 0;
|
|
60
|
+
this.initialized = false;
|
|
61
|
+
this.config = { node: 'us', localSigning: false, keystorePath: path.join(os.homedir(), '.rubric', 'sdk-keypair.json'), keystorePassphrase: '', backgroundQueue: false, queueConfig: {}, timeout: 15000, enterprise: false, proofUpgrade: config.localSigning ?? false, ...config };
|
|
62
|
+
}
|
|
63
|
+
async init() {
|
|
64
|
+
if (this.initialized)
|
|
65
|
+
return;
|
|
66
|
+
if (this.config.localSigning) {
|
|
67
|
+
this.keyPair = (0, signing_1.loadOrCreateKeyPair)(this.config.keystorePath, this.config.keystorePassphrase || undefined);
|
|
68
|
+
console.log(`[RubricClient] Keypair loaded. pubKey: ${this.keyPair.publicKeyHex.slice(0, 16)}․`);
|
|
69
|
+
}
|
|
70
|
+
if (this.config.backgroundQueue) {
|
|
71
|
+
this.queue = new background_queue_1.BackgroundQueue({ flushInterval: 5000, batchSize: 1000, maxAttempts: 5, backoffBase: 1000, ...this.config.queueConfig, onDeadLetter: (item) => { console.error(`[RubricQueue] Dead letter: ${item.id} ${item.lastError}`); this.config.queueConfig?.onDeadLetter?.(item); } });
|
|
72
|
+
this.queue.start();
|
|
73
|
+
}
|
|
74
|
+
if (this.config.proofUpgrade) {
|
|
75
|
+
this.upgradeManager = new proof_upgrade_manager_1.ProofUpgradeManager({ baseUrl: this._endpoint(), apiKey: this.config.apiKey, pollInterval: 3000, maxTrackingAge: 120000 });
|
|
76
|
+
}
|
|
77
|
+
this.initialized = true;
|
|
78
|
+
}
|
|
79
|
+
async registerSystem(req) {
|
|
80
|
+
await this.init();
|
|
81
|
+
const baseUrl = this._endpoint().replace('/v1/tiered-attest', '').replace('/v1/record', '').replace(/\/+$/, '');
|
|
82
|
+
const resp = await fetch(`${baseUrl}/v1/system/register`, {
|
|
83
|
+
method: 'POST',
|
|
84
|
+
headers: { 'x-api-key': this.config.apiKey, 'Content-Type': 'application/json' },
|
|
85
|
+
body: JSON.stringify({ ...req, jurisdiction: req.jurisdiction.map((j) => j.toUpperCase()) }),
|
|
86
|
+
});
|
|
87
|
+
if (!resp.ok)
|
|
88
|
+
throw new Error(`System registration failed: ${resp.status}`);
|
|
89
|
+
return resp.json();
|
|
90
|
+
}
|
|
91
|
+
async validatePayload(systemId, payload) {
|
|
92
|
+
await this.init();
|
|
93
|
+
const baseUrl = this._endpoint().replace('/v1/tiered-attest', '').replace('/v1/record', '').replace(/\/+$/, '');
|
|
94
|
+
const resp = await fetch(`${baseUrl}/v1/system/validate`, {
|
|
95
|
+
method: 'POST',
|
|
96
|
+
headers: { 'x-api-key': this.config.apiKey, 'Content-Type': 'application/json' },
|
|
97
|
+
body: JSON.stringify({ systemId, payload }),
|
|
98
|
+
});
|
|
99
|
+
if (!resp.ok)
|
|
100
|
+
return null;
|
|
101
|
+
return resp.json();
|
|
102
|
+
}
|
|
103
|
+
async attest(req) {
|
|
104
|
+
await this.init();
|
|
105
|
+
const attestationId = crypto.randomUUID();
|
|
106
|
+
const submittedAt = new Date().toISOString();
|
|
107
|
+
const url = this._endpoint() + (this.config.enterprise ? '/v1/tiered-attest' : '/v1/attest');
|
|
108
|
+
// Build data payload (what gets signed and stored)
|
|
109
|
+
const data = { attestationId, agentId: req.agentId, output: req.output, leafType: req.leafType ?? 'AGENT_OUTPUT', submittedAt, ...(req.metadata && { metadata: req.metadata }), ...(req.confidence !== undefined && { confidence: req.confidence }) };
|
|
110
|
+
let localSignature = '', publicKey = '';
|
|
111
|
+
if (this.config.localSigning && this.keyPair) {
|
|
112
|
+
const signed = (0, signing_1.signPayload)(data, this.keyPair.secretKey, this.keyPair.publicKey);
|
|
113
|
+
localSignature = signed.signature;
|
|
114
|
+
publicKey = signed.publicKey;
|
|
115
|
+
data.clientSignature = localSignature;
|
|
116
|
+
data.clientPublicKey = publicKey;
|
|
117
|
+
data.clientSignedAt = signed.signedAt;
|
|
118
|
+
data.signatureAlgorithm = signed.algorithm;
|
|
119
|
+
}
|
|
120
|
+
// Wrap in server-expected format: { sourceId, data, pipelineId, attestationId }
|
|
121
|
+
const body = { attestationId, sourceId: req.agentId, data, ...(req.pipelineId && { pipelineId: req.pipelineId }) };
|
|
122
|
+
const localData = { stage: 'local', attestationId, agentId: req.agentId, localSignature, publicKey, signedAt: submittedAt, payload: body };
|
|
123
|
+
const proof = this.upgradeManager ? new proof_types_1.LiveProof(localData) : new proof_types_1.LiveProof(localData);
|
|
124
|
+
const headers = { 'x-api-key': this.config.apiKey, 'Content-Type': 'application/json' };
|
|
125
|
+
if (this.upgradeManager) {
|
|
126
|
+
// Must await server response to get server-assigned attestationId for upgrade polling
|
|
127
|
+
this._submitAndTrack(url, body, headers, proof);
|
|
128
|
+
}
|
|
129
|
+
else if (req.risk === 'high' || !this.queue) {
|
|
130
|
+
this._submitInBackground(url, body, headers);
|
|
131
|
+
}
|
|
132
|
+
else {
|
|
133
|
+
this.queue.enqueue(url, body, headers);
|
|
134
|
+
}
|
|
135
|
+
return proof;
|
|
136
|
+
}
|
|
137
|
+
async attestAndConfirm(req, timeoutMs = 90000) {
|
|
138
|
+
const proof = await this.attest({ ...req, risk: 'high' });
|
|
139
|
+
return proof.waitFor('confirmed', timeoutMs);
|
|
140
|
+
}
|
|
141
|
+
async shutdown() {
|
|
142
|
+
await this.queue?.stop();
|
|
143
|
+
this.upgradeManager?.stop();
|
|
144
|
+
}
|
|
145
|
+
queueStats() { return this.queue?.stats() ?? null; }
|
|
146
|
+
upgradeStats() { return { tracking: this.upgradeManager?.size ?? 0 }; }
|
|
147
|
+
_submitInBackground(url, body, headers) {
|
|
148
|
+
fetch(url, { method: 'POST', headers, body: JSON.stringify(body), signal: AbortSignal.timeout(this.config.timeout) }).catch(err => console.warn('[RubricClient] Background submit error:', err));
|
|
149
|
+
}
|
|
150
|
+
_submitAndTrack(url, body, headers, proof) {
|
|
151
|
+
const baseUrl = this._endpoint();
|
|
152
|
+
const clientAttestationId = body.attestationId;
|
|
153
|
+
const isEnterprise = this.config.enterprise;
|
|
154
|
+
const apiKey = this.config.apiKey;
|
|
155
|
+
const timeout = this.config.timeout;
|
|
156
|
+
fetch(url, { method: 'POST', headers, body: JSON.stringify(body), signal: AbortSignal.timeout(timeout) })
|
|
157
|
+
.then(async (res) => {
|
|
158
|
+
if (!res.ok) {
|
|
159
|
+
console.warn('[RubricClient] Submit failed:', res.status);
|
|
160
|
+
return;
|
|
161
|
+
}
|
|
162
|
+
const data = await res.json();
|
|
163
|
+
const serverAttestationId = data.attestationId ?? clientAttestationId;
|
|
164
|
+
const localData = proof.data;
|
|
165
|
+
if (isEnterprise && this.upgradeManager) {
|
|
166
|
+
// Enterprise: use ProofUpgradeManager with /v1/proof-status/
|
|
167
|
+
const trackData = { ...localData, attestationId: serverAttestationId };
|
|
168
|
+
const trackProof = new proof_types_1.LiveProof(trackData);
|
|
169
|
+
trackProof.onUpgrade('any', (p) => proof._upgrade({ ...p, attestationId: clientAttestationId }));
|
|
170
|
+
this.upgradeManager.track(trackProof);
|
|
171
|
+
}
|
|
172
|
+
else {
|
|
173
|
+
// Standard: poll /v1/status/:serverAttestationId directly
|
|
174
|
+
this._pollStatus(baseUrl, serverAttestationId, clientAttestationId, proof, apiKey, timeout);
|
|
175
|
+
}
|
|
176
|
+
})
|
|
177
|
+
.catch(err => console.warn('[RubricClient] Background submit error:', err));
|
|
178
|
+
}
|
|
179
|
+
async _pollStatus(baseUrl, serverAttestationId, clientAttestationId, proof, apiKey, timeout) {
|
|
180
|
+
const maxAttempts = 20;
|
|
181
|
+
const interval = 3000;
|
|
182
|
+
for (let i = 0; i < maxAttempts; i++) {
|
|
183
|
+
await new Promise(r => setTimeout(r, interval));
|
|
184
|
+
try {
|
|
185
|
+
const res = await fetch(`${baseUrl}/v1/status/${serverAttestationId}`, {
|
|
186
|
+
headers: { 'x-api-key': apiKey },
|
|
187
|
+
signal: AbortSignal.timeout(timeout),
|
|
188
|
+
});
|
|
189
|
+
if (!res.ok)
|
|
190
|
+
continue;
|
|
191
|
+
const status = await res.json();
|
|
192
|
+
const localData = proof.data;
|
|
193
|
+
if (status.status === 'confirmed' && proof.stage !== 'confirmed') {
|
|
194
|
+
const seqNum = status.seqNum ? parseInt(status.seqNum) : null;
|
|
195
|
+
// Fire anchored first if still local
|
|
196
|
+
if (proof.stage === 'local') {
|
|
197
|
+
proof._upgrade({
|
|
198
|
+
stage: 'anchored',
|
|
199
|
+
attestationId: clientAttestationId,
|
|
200
|
+
agentId: localData.agentId,
|
|
201
|
+
localSignature: localData.localSignature ?? '',
|
|
202
|
+
publicKey: localData.publicKey ?? '',
|
|
203
|
+
signedAt: localData.signedAt,
|
|
204
|
+
payload: localData.payload,
|
|
205
|
+
merkleRoot: status.forestRoot ?? '',
|
|
206
|
+
serverAttestationId,
|
|
207
|
+
anchoredAt: status.confirmedAt ?? new Date().toISOString(),
|
|
208
|
+
});
|
|
209
|
+
}
|
|
210
|
+
proof._upgrade({
|
|
211
|
+
stage: 'confirmed',
|
|
212
|
+
attestationId: clientAttestationId,
|
|
213
|
+
agentId: localData.agentId,
|
|
214
|
+
localSignature: localData.localSignature ?? '',
|
|
215
|
+
publicKey: localData.publicKey ?? '',
|
|
216
|
+
signedAt: localData.signedAt,
|
|
217
|
+
payload: localData.payload,
|
|
218
|
+
merkleRoot: status.forestRoot ?? '',
|
|
219
|
+
serverAttestationId,
|
|
220
|
+
anchoredAt: status.confirmedAt ?? new Date().toISOString(),
|
|
221
|
+
hcsTopicId: '0.0.8207826',
|
|
222
|
+
hcsSequenceNumber: seqNum,
|
|
223
|
+
hcsTimestamp: status.confirmedAt ?? null,
|
|
224
|
+
hashScanUrl: seqNum ? `https://hashscan.io/testnet/topic/0.0.8207826/${seqNum}` : '',
|
|
225
|
+
});
|
|
226
|
+
return;
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
catch { /* non-fatal, continue polling */ }
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
_endpoint() {
|
|
233
|
+
if (this.config.node !== 'auto')
|
|
234
|
+
return NODES[this.config.node] ?? NODES.us;
|
|
235
|
+
const keys = Object.keys(NODES);
|
|
236
|
+
return NODES[keys[this.nodeIndex++ % keys.length]];
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
exports.RubricClient = RubricClient;
|
|
240
|
+
function createRubricClient(config) {
|
|
241
|
+
return new RubricClient(config);
|
|
242
|
+
}
|
|
243
|
+
//# sourceMappingURL=rubric-client.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rubric-client.js","sourceRoot":"","sources":["../rubric-client.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Rubric Protocol — Local ML-DSA-65 Signing
|
|
3
|
+
* Uses @noble/post-quantum (NIST FIPS 204)
|
|
4
|
+
* Handles key generation, signing, verification, and filesystem persistence.
|
|
5
|
+
*/
|
|
6
|
+
export interface LocalKeyPair {
|
|
7
|
+
publicKey: Uint8Array;
|
|
8
|
+
secretKey: Uint8Array;
|
|
9
|
+
publicKeyHex: string;
|
|
10
|
+
created: string;
|
|
11
|
+
}
|
|
12
|
+
export interface SignedPayload {
|
|
13
|
+
payload: Record<string, unknown>;
|
|
14
|
+
signature: string;
|
|
15
|
+
publicKey: string;
|
|
16
|
+
signedAt: string;
|
|
17
|
+
algorithm: 'ML-DSA-65';
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* Generate a fresh ML-DRA-65 keypair from a 32-byte random seed.
|
|
21
|
+
*/
|
|
22
|
+
export declare function generateKeyPair(): LocalKeyPair;
|
|
23
|
+
/**
|
|
24
|
+
* Sign an arbitrary payload object with a local secret key.
|
|
25
|
+
* Canonical JSON serialization ensures deterministic signing.
|
|
26
|
+
*/
|
|
27
|
+
export declare function signPayload(payload: Record<string, unknown>, secretKey: Uint8Array, publicKey: Uint8Array): SignedPayload;
|
|
28
|
+
/**
|
|
29
|
+
* Verify a signed payload locally (for testing / offline verification).
|
|
30
|
+
*/
|
|
31
|
+
export declare function verifySignedPayload(signed: SignedPayload): boolean;
|
|
32
|
+
export declare function saveKeyPair(kp: LocalKeyPair, filePath: string, passphrase?: string): void;
|
|
33
|
+
export declare function loadKeyPair(filePath: string, passphrase?: string): LocalKeyPair;
|
|
34
|
+
export declare function loadOrCreateKeyPair(filePath: string, passphrase?: string): LocalKeyPair;
|
|
35
|
+
//# sourceMappingURL=signing.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"signing.d.ts","sourceRoot":"","sources":["../signing.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AASH,MAAM,WAAW,YAAY;IAC3B,SAAS,EAAE,UAAU,CAAC;IACtB,SAAS,EAAE,UAAU,CAAC;IACtB,YAAY,EAAE,MAAM,CAAC;IACrB,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,aAAa;IAC5B,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACjC,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,WAAW,CAAC;CACxB;AAID;;GAEG;AACH,wBAAgB,eAAe,IAAI,YAAY,CAS9C;AAID;;;GAGG;AACH,wBAAgB,WAAW,CACzB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAChC,SAAS,EAAE,UAAU,EACrB,SAAS,EAAE,UAAU,GACpB,aAAa,CAYf;AAID;;GAEG;AACH,wBAAgB,mBAAmB,CAAC,MAAM,EAAE,aAAa,GAAG,OAAO,CAUlE;AAcD,wBAAgB,WAAW,CACzB,EAAE,EAAE,YAAY,EAChB,QAAQ,EAAE,MAAM,EAChB,UAAU,CAAC,EAAE,MAAM,GAClB,IAAI,CAgBN;AAED,wBAAgB,WAAW,CAAC,QAAQ,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,YAAY,CAc/E;AAED,wBAAgB,mBAAmB,CAAC,QAAQ,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,YAAY,CAKvF"}
|