@xyo-network/boundwitness-validator 2.111.3 → 3.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/browser/index.d.ts +21 -2
- package/dist/neutral/index.d.ts +21 -2
- package/dist/node/index.d.ts +21 -2
- package/dist/node/index.mjs +12 -17
- package/dist/node/index.mjs.map +1 -1
- package/package.json +13 -32
- package/dist/browser/Validator.d.cts +0 -19
- package/dist/browser/Validator.d.cts.map +0 -1
- package/dist/browser/Validator.d.mts +0 -19
- package/dist/browser/Validator.d.mts.map +0 -1
- package/dist/browser/Validator.d.ts +0 -19
- package/dist/browser/Validator.d.ts.map +0 -1
- package/dist/browser/index.cjs +0 -134
- package/dist/browser/index.cjs.map +0 -1
- package/dist/browser/index.d.cts +0 -2
- package/dist/browser/index.d.cts.map +0 -1
- package/dist/browser/index.d.mts +0 -2
- package/dist/browser/index.d.mts.map +0 -1
- package/dist/browser/index.d.ts.map +0 -1
- package/dist/neutral/Validator.d.cts +0 -19
- package/dist/neutral/Validator.d.cts.map +0 -1
- package/dist/neutral/Validator.d.mts +0 -19
- package/dist/neutral/Validator.d.mts.map +0 -1
- package/dist/neutral/Validator.d.ts +0 -19
- package/dist/neutral/Validator.d.ts.map +0 -1
- package/dist/neutral/index.cjs +0 -134
- package/dist/neutral/index.cjs.map +0 -1
- package/dist/neutral/index.d.cts +0 -2
- package/dist/neutral/index.d.cts.map +0 -1
- package/dist/neutral/index.d.mts +0 -2
- package/dist/neutral/index.d.mts.map +0 -1
- package/dist/neutral/index.d.ts.map +0 -1
- package/dist/node/Validator.d.cts +0 -19
- package/dist/node/Validator.d.cts.map +0 -1
- package/dist/node/Validator.d.mts +0 -19
- package/dist/node/Validator.d.mts.map +0 -1
- package/dist/node/Validator.d.ts +0 -19
- package/dist/node/Validator.d.ts.map +0 -1
- package/dist/node/index.cjs +0 -143
- package/dist/node/index.cjs.map +0 -1
- package/dist/node/index.d.cts +0 -2
- package/dist/node/index.d.cts.map +0 -1
- package/dist/node/index.d.mts +0 -2
- package/dist/node/index.d.mts.map +0 -1
- package/dist/node/index.d.ts.map +0 -1
package/dist/browser/index.d.ts
CHANGED
|
@@ -1,2 +1,21 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import { BoundWitness } from '@xyo-network/boundwitness-model';
|
|
2
|
+
import { PayloadValidator } from '@xyo-network/payload-validator';
|
|
3
|
+
|
|
4
|
+
declare class BoundWitnessValidator<T extends BoundWitness<{
|
|
5
|
+
schema: string;
|
|
6
|
+
}> = BoundWitness> extends PayloadValidator<T> {
|
|
7
|
+
protected get expectedSchema(): string;
|
|
8
|
+
static validateSignature(hash: ArrayBuffer, address: ArrayBuffer, signature?: ArrayBuffer): Promise<Error[]>;
|
|
9
|
+
addresses(): Error[];
|
|
10
|
+
addressesUniqueness(): Error[];
|
|
11
|
+
previousHashes(): Error[];
|
|
12
|
+
schema(): Error[];
|
|
13
|
+
schemas(): Error[];
|
|
14
|
+
signatures(): Promise<Error[]>;
|
|
15
|
+
validate(): Promise<Error[]>;
|
|
16
|
+
validateArrayLengths(): Error[];
|
|
17
|
+
validatePayloadHashesLength(): Error[];
|
|
18
|
+
private validateArrayLength;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export { BoundWitnessValidator };
|
package/dist/neutral/index.d.ts
CHANGED
|
@@ -1,2 +1,21 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import { BoundWitness } from '@xyo-network/boundwitness-model';
|
|
2
|
+
import { PayloadValidator } from '@xyo-network/payload-validator';
|
|
3
|
+
|
|
4
|
+
declare class BoundWitnessValidator<T extends BoundWitness<{
|
|
5
|
+
schema: string;
|
|
6
|
+
}> = BoundWitness> extends PayloadValidator<T> {
|
|
7
|
+
protected get expectedSchema(): string;
|
|
8
|
+
static validateSignature(hash: ArrayBuffer, address: ArrayBuffer, signature?: ArrayBuffer): Promise<Error[]>;
|
|
9
|
+
addresses(): Error[];
|
|
10
|
+
addressesUniqueness(): Error[];
|
|
11
|
+
previousHashes(): Error[];
|
|
12
|
+
schema(): Error[];
|
|
13
|
+
schemas(): Error[];
|
|
14
|
+
signatures(): Promise<Error[]>;
|
|
15
|
+
validate(): Promise<Error[]>;
|
|
16
|
+
validateArrayLengths(): Error[];
|
|
17
|
+
validatePayloadHashesLength(): Error[];
|
|
18
|
+
private validateArrayLength;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export { BoundWitnessValidator };
|
package/dist/node/index.d.ts
CHANGED
|
@@ -1,2 +1,21 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import { BoundWitness } from '@xyo-network/boundwitness-model';
|
|
2
|
+
import { PayloadValidator } from '@xyo-network/payload-validator';
|
|
3
|
+
|
|
4
|
+
declare class BoundWitnessValidator<T extends BoundWitness<{
|
|
5
|
+
schema: string;
|
|
6
|
+
}> = BoundWitness> extends PayloadValidator<T> {
|
|
7
|
+
protected get expectedSchema(): string;
|
|
8
|
+
static validateSignature(hash: ArrayBuffer, address: ArrayBuffer, signature?: ArrayBuffer): Promise<Error[]>;
|
|
9
|
+
addresses(): Error[];
|
|
10
|
+
addressesUniqueness(): Error[];
|
|
11
|
+
previousHashes(): Error[];
|
|
12
|
+
schema(): Error[];
|
|
13
|
+
schemas(): Error[];
|
|
14
|
+
signatures(): Promise<Error[]>;
|
|
15
|
+
validate(): Promise<Error[]>;
|
|
16
|
+
validateArrayLengths(): Error[];
|
|
17
|
+
validatePayloadHashesLength(): Error[];
|
|
18
|
+
private validateArrayLength;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
export { BoundWitnessValidator };
|
package/dist/node/index.mjs
CHANGED
|
@@ -31,7 +31,7 @@ var BoundWitnessValidator = class _BoundWitnessValidator extends PayloadValidato
|
|
|
31
31
|
const errors = [];
|
|
32
32
|
const { addresses } = this.obj;
|
|
33
33
|
const uniqAddresses = uniq(addresses);
|
|
34
|
-
if (
|
|
34
|
+
if (addresses?.length !== uniqAddresses?.length) errors.push(new Error("addresses must be unique"));
|
|
35
35
|
return errors;
|
|
36
36
|
}
|
|
37
37
|
previousHashes() {
|
|
@@ -50,8 +50,7 @@ var BoundWitnessValidator = class _BoundWitnessValidator extends PayloadValidato
|
|
|
50
50
|
const Schemas = this.obj.payload_schemas;
|
|
51
51
|
if (Schemas) {
|
|
52
52
|
const schemaValidators = Schemas.map((schema) => {
|
|
53
|
-
|
|
54
|
-
return (_b = (_a = PayloadValidator).schemaNameValidatorFactory) == null ? void 0 : _b.call(_a, schema);
|
|
53
|
+
return PayloadValidator.schemaNameValidatorFactory?.(schema);
|
|
55
54
|
});
|
|
56
55
|
for (const validator of schemaValidators) {
|
|
57
56
|
if (validator) {
|
|
@@ -62,20 +61,16 @@ var BoundWitnessValidator = class _BoundWitnessValidator extends PayloadValidato
|
|
|
62
61
|
return errors;
|
|
63
62
|
}
|
|
64
63
|
async signatures() {
|
|
65
|
-
var _a, _b;
|
|
66
64
|
return [
|
|
67
|
-
...validateArraysSameLength(
|
|
65
|
+
...validateArraysSameLength(this.obj.$meta?.signatures ?? [], this.obj.addresses ?? [], "Length mismatch: address/signature"),
|
|
68
66
|
...(await Promise.all(
|
|
69
|
-
|
|
70
|
-
async (address, index) =>
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
);
|
|
77
|
-
}
|
|
78
|
-
)) ?? []
|
|
67
|
+
this.obj.addresses?.map(
|
|
68
|
+
async (address, index) => _BoundWitnessValidator.validateSignature(
|
|
69
|
+
toUint8Array(await PayloadBuilder.dataHash(this.payload)),
|
|
70
|
+
toUint8Array(address),
|
|
71
|
+
toUint8Array(this.obj.$meta?.signatures?.[index])
|
|
72
|
+
)
|
|
73
|
+
) ?? []
|
|
79
74
|
)).flat()
|
|
80
75
|
];
|
|
81
76
|
}
|
|
@@ -104,8 +99,8 @@ var BoundWitnessValidator = class _BoundWitnessValidator extends PayloadValidato
|
|
|
104
99
|
const errors = [];
|
|
105
100
|
const [array, arrayErrors] = validateType("array", this.stringKeyObj[fieldName], true);
|
|
106
101
|
const [compareArray, compareArrayErrors] = validateType("array", this.stringKeyObj[compareArrayName], true);
|
|
107
|
-
if (
|
|
108
|
-
errors.push(new Error(`${fieldName}/${compareArrayName} count mismatch [${array
|
|
102
|
+
if (array?.length !== compareArray?.length) {
|
|
103
|
+
errors.push(new Error(`${fieldName}/${compareArrayName} count mismatch [${array?.length} !== ${compareArray?.length}]`));
|
|
109
104
|
}
|
|
110
105
|
return [...arrayErrors, ...compareArrayErrors, ...errors];
|
|
111
106
|
}
|
package/dist/node/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/Validator.ts"],"sourcesContent":["import { toUint8Array } from '@xylabs/arraybuffer'\nimport { uniq } from '@xylabs/lodash'\nimport { validateType } from '@xylabs/typeof'\nimport { Elliptic } from '@xyo-network/account'\nimport { BoundWitness, BoundWitnessSchema } from '@xyo-network/boundwitness-model'\nimport { PayloadBuilder } from '@xyo-network/payload'\nimport { PayloadValidator } from '@xyo-network/payload-validator'\n\nconst validateArraysSameLength = (a: unknown[], b: unknown[], message = 'Array length mismatch') => {\n return a.length == b.length ? [] : [new Error(`${message} []`)]\n}\n\nexport class BoundWitnessValidator<T extends BoundWitness<{ schema: string }> = BoundWitness> extends PayloadValidator<T> {\n protected get expectedSchema(): string {\n return BoundWitnessSchema\n }\n\n static async validateSignature(hash: ArrayBuffer, address: ArrayBuffer, signature?: ArrayBuffer): Promise<Error[]> {\n if (!signature) {\n return [new Error(`Missing signature [${address}]`)]\n }\n if (!(await Elliptic.verify(hash, signature, address))) {\n return [new Error(`Invalid signature [${address}]`)]\n }\n return []\n }\n\n addresses(): Error[] {\n const errors: Error[] = []\n // const { addresses } = this.obj\n // if (!addresses?.length) errors.push(new Error('addresses missing [at least one address required]'))\n errors.push(...this.addressesUniqueness())\n return errors\n }\n\n addressesUniqueness(): Error[] {\n const errors: Error[] = []\n const { addresses } = this.obj\n const uniqAddresses = uniq(addresses)\n if (addresses?.length !== uniqAddresses?.length) errors.push(new Error('addresses must be unique'))\n return errors\n }\n\n previousHashes() {\n const errors: Error[] = []\n return errors\n }\n\n schema(): Error[] {\n const errors: Error[] = []\n if (this.obj.schema !== this.expectedSchema) {\n errors.push(new Error(`invalid schema [${this.expectedSchema} !== ${this.obj.schema}]`))\n }\n return errors\n }\n\n schemas(): Error[] {\n const errors: Error[] = []\n const Schemas = this.obj.payload_schemas\n if (Schemas) {\n const schemaValidators = Schemas.map((schema: string) => {\n return PayloadValidator.schemaNameValidatorFactory?.(schema)\n })\n for (const validator of schemaValidators) {\n if (validator) {\n errors.push(...validator.all())\n }\n }\n }\n return errors\n }\n\n async signatures(): Promise<Error[]> {\n return [\n ...validateArraysSameLength(this.obj.$meta?.signatures ?? [], this.obj.addresses ?? [], 'Length mismatch: address/signature'),\n ...(\n await Promise.all(\n this.obj.addresses?.map<Promise<Error[]>>(async (address, index) =>\n BoundWitnessValidator.validateSignature(\n toUint8Array(await PayloadBuilder.dataHash(this.payload)),\n toUint8Array(address),\n toUint8Array(this.obj.$meta?.signatures?.[index]),\n ),\n ) ?? [],\n )\n ).flat(),\n ]\n }\n\n override async validate() {\n return [\n ...(await this.signatures()),\n ...this.addresses(),\n ...this.validateArrayLengths(),\n ...this.schemas(),\n ...this.previousHashes(),\n ...this.schema(),\n ...(await super.validate()),\n ]\n }\n\n validateArrayLengths(): Error[] {\n const errors: Error[] = []\n errors.push(...this.validatePayloadHashesLength())\n return errors\n }\n\n validatePayloadHashesLength(): Error[] {\n const errors: Error[] = []\n errors.push(...this.validateArrayLength('payload_hashes', 'payload_schemas'))\n return errors\n }\n\n private validateArrayLength(fieldName: string, compareArrayName: string): Error[] {\n const errors: Error[] = []\n\n const [array, arrayErrors] = validateType('array', this.stringKeyObj[fieldName] as [], true)\n const [compareArray, compareArrayErrors] = validateType('array', this.stringKeyObj[compareArrayName] as [], true)\n\n if (array?.length !== compareArray?.length) {\n errors.push(new Error(`${fieldName}/${compareArrayName} count mismatch [${array?.length} !== ${compareArray?.length}]`))\n }\n\n return [...arrayErrors, ...compareArrayErrors, ...errors]\n }\n}\n"],"mappings":";AAAA,SAAS,oBAAoB;AAC7B,SAAS,YAAY;AACrB,SAAS,oBAAoB;AAC7B,SAAS,gBAAgB;AACzB,SAAuB,0BAA0B;AACjD,SAAS,sBAAsB;AAC/B,SAAS,wBAAwB;AAEjC,IAAM,2BAA2B,CAAC,GAAc,GAAc,UAAU,4BAA4B;AAClG,SAAO,EAAE,UAAU,EAAE,SAAS,CAAC,IAAI,CAAC,IAAI,MAAM,GAAG,OAAO,KAAK,CAAC;AAChE;AAEO,IAAM,wBAAN,MAAM,+BAAyF,iBAAoB;AAAA,EACxH,IAAc,iBAAyB;AACrC,WAAO;AAAA,EACT;AAAA,EAEA,aAAa,kBAAkB,MAAmB,SAAsB,WAA2C;AACjH,QAAI,CAAC,WAAW;AACd,aAAO,CAAC,IAAI,MAAM,sBAAsB,OAAO,GAAG,CAAC;AAAA,IACrD;AACA,QAAI,CAAE,MAAM,SAAS,OAAO,MAAM,WAAW,OAAO,GAAI;AACtD,aAAO,CAAC,IAAI,MAAM,sBAAsB,OAAO,GAAG,CAAC;AAAA,IACrD;AACA,WAAO,CAAC;AAAA,EACV;AAAA,EAEA,YAAqB;AACnB,UAAM,SAAkB,CAAC;AAGzB,WAAO,KAAK,GAAG,KAAK,oBAAoB,CAAC;AACzC,WAAO;AAAA,EACT;AAAA,EAEA,sBAA+B;AAC7B,UAAM,SAAkB,CAAC;AACzB,UAAM,EAAE,UAAU,IAAI,KAAK;AAC3B,UAAM,gBAAgB,KAAK,SAAS;AACpC,
|
|
1
|
+
{"version":3,"sources":["../../src/Validator.ts"],"sourcesContent":["import { toUint8Array } from '@xylabs/arraybuffer'\nimport { uniq } from '@xylabs/lodash'\nimport { validateType } from '@xylabs/typeof'\nimport { Elliptic } from '@xyo-network/account'\nimport { BoundWitness, BoundWitnessSchema } from '@xyo-network/boundwitness-model'\nimport { PayloadBuilder } from '@xyo-network/payload'\nimport { PayloadValidator } from '@xyo-network/payload-validator'\n\nconst validateArraysSameLength = (a: unknown[], b: unknown[], message = 'Array length mismatch') => {\n return a.length == b.length ? [] : [new Error(`${message} []`)]\n}\n\nexport class BoundWitnessValidator<T extends BoundWitness<{ schema: string }> = BoundWitness> extends PayloadValidator<T> {\n protected get expectedSchema(): string {\n return BoundWitnessSchema\n }\n\n static async validateSignature(hash: ArrayBuffer, address: ArrayBuffer, signature?: ArrayBuffer): Promise<Error[]> {\n if (!signature) {\n return [new Error(`Missing signature [${address}]`)]\n }\n if (!(await Elliptic.verify(hash, signature, address))) {\n return [new Error(`Invalid signature [${address}]`)]\n }\n return []\n }\n\n addresses(): Error[] {\n const errors: Error[] = []\n // const { addresses } = this.obj\n // if (!addresses?.length) errors.push(new Error('addresses missing [at least one address required]'))\n errors.push(...this.addressesUniqueness())\n return errors\n }\n\n addressesUniqueness(): Error[] {\n const errors: Error[] = []\n const { addresses } = this.obj\n const uniqAddresses = uniq(addresses)\n if (addresses?.length !== uniqAddresses?.length) errors.push(new Error('addresses must be unique'))\n return errors\n }\n\n previousHashes() {\n const errors: Error[] = []\n return errors\n }\n\n schema(): Error[] {\n const errors: Error[] = []\n if (this.obj.schema !== this.expectedSchema) {\n errors.push(new Error(`invalid schema [${this.expectedSchema} !== ${this.obj.schema}]`))\n }\n return errors\n }\n\n schemas(): Error[] {\n const errors: Error[] = []\n const Schemas = this.obj.payload_schemas\n if (Schemas) {\n const schemaValidators = Schemas.map((schema: string) => {\n return PayloadValidator.schemaNameValidatorFactory?.(schema)\n })\n for (const validator of schemaValidators) {\n if (validator) {\n errors.push(...validator.all())\n }\n }\n }\n return errors\n }\n\n async signatures(): Promise<Error[]> {\n return [\n ...validateArraysSameLength(this.obj.$meta?.signatures ?? [], this.obj.addresses ?? [], 'Length mismatch: address/signature'),\n ...(\n await Promise.all(\n this.obj.addresses?.map<Promise<Error[]>>(async (address, index) =>\n BoundWitnessValidator.validateSignature(\n toUint8Array(await PayloadBuilder.dataHash(this.payload)),\n toUint8Array(address),\n toUint8Array(this.obj.$meta?.signatures?.[index]),\n ),\n ) ?? [],\n )\n ).flat(),\n ]\n }\n\n override async validate() {\n return [\n ...(await this.signatures()),\n ...this.addresses(),\n ...this.validateArrayLengths(),\n ...this.schemas(),\n ...this.previousHashes(),\n ...this.schema(),\n ...(await super.validate()),\n ]\n }\n\n validateArrayLengths(): Error[] {\n const errors: Error[] = []\n errors.push(...this.validatePayloadHashesLength())\n return errors\n }\n\n validatePayloadHashesLength(): Error[] {\n const errors: Error[] = []\n errors.push(...this.validateArrayLength('payload_hashes', 'payload_schemas'))\n return errors\n }\n\n private validateArrayLength(fieldName: string, compareArrayName: string): Error[] {\n const errors: Error[] = []\n\n const [array, arrayErrors] = validateType('array', this.stringKeyObj[fieldName] as [], true)\n const [compareArray, compareArrayErrors] = validateType('array', this.stringKeyObj[compareArrayName] as [], true)\n\n if (array?.length !== compareArray?.length) {\n errors.push(new Error(`${fieldName}/${compareArrayName} count mismatch [${array?.length} !== ${compareArray?.length}]`))\n }\n\n return [...arrayErrors, ...compareArrayErrors, ...errors]\n }\n}\n"],"mappings":"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","names":[]}
|
package/package.json
CHANGED
|
@@ -13,46 +13,27 @@
|
|
|
13
13
|
"@xylabs/arraybuffer": "^3.6.12",
|
|
14
14
|
"@xylabs/lodash": "^3.6.12",
|
|
15
15
|
"@xylabs/typeof": "^3.6.12",
|
|
16
|
-
"@xyo-network/account": "^
|
|
17
|
-
"@xyo-network/boundwitness-model": "^
|
|
18
|
-
"@xyo-network/payload": "^
|
|
19
|
-
"@xyo-network/payload-validator": "^
|
|
16
|
+
"@xyo-network/account": "^3.0.0",
|
|
17
|
+
"@xyo-network/boundwitness-model": "^3.0.0",
|
|
18
|
+
"@xyo-network/payload": "^3.0.0",
|
|
19
|
+
"@xyo-network/payload-validator": "^3.0.0"
|
|
20
20
|
},
|
|
21
21
|
"description": "Primary SDK for using XYO Protocol 2.0",
|
|
22
22
|
"devDependencies": {
|
|
23
|
-
"@xylabs/ts-scripts-yarn3": "
|
|
24
|
-
"@xylabs/tsconfig": "
|
|
25
|
-
"@xyo-network/boundwitness-builder": "^
|
|
26
|
-
"@xyo-network/schema-name-validator": "^
|
|
23
|
+
"@xylabs/ts-scripts-yarn3": "next",
|
|
24
|
+
"@xylabs/tsconfig": "next",
|
|
25
|
+
"@xyo-network/boundwitness-builder": "^3.0.0",
|
|
26
|
+
"@xyo-network/schema-name-validator": "^3.0.0",
|
|
27
27
|
"typescript": "^5.5.4"
|
|
28
28
|
},
|
|
29
29
|
"exports": {
|
|
30
30
|
".": {
|
|
31
|
-
"
|
|
32
|
-
|
|
33
|
-
"types": "./dist/browser/index.d.cts",
|
|
34
|
-
"default": "./dist/browser/index.cjs"
|
|
35
|
-
},
|
|
36
|
-
"import": {
|
|
37
|
-
"types": "./dist/browser/index.d.mts",
|
|
38
|
-
"default": "./dist/browser/index.mjs"
|
|
39
|
-
}
|
|
40
|
-
},
|
|
41
|
-
"node": {
|
|
42
|
-
"require": {
|
|
43
|
-
"types": "./dist/node/index.d.cts",
|
|
44
|
-
"default": "./dist/node/index.cjs"
|
|
45
|
-
},
|
|
46
|
-
"import": {
|
|
47
|
-
"types": "./dist/node/index.d.mts",
|
|
48
|
-
"default": "./dist/node/index.mjs"
|
|
49
|
-
}
|
|
50
|
-
}
|
|
31
|
+
"types": "./dist/neutral/index.d.ts",
|
|
32
|
+
"default": "./dist/neutral/index.mjs"
|
|
51
33
|
},
|
|
52
34
|
"./package.json": "./package.json"
|
|
53
35
|
},
|
|
54
|
-
"
|
|
55
|
-
"module": "dist/node/index.mjs",
|
|
36
|
+
"module": "dist/neutral/index.mjs",
|
|
56
37
|
"homepage": "https://xyo.network",
|
|
57
38
|
"license": "LGPL-3.0-only",
|
|
58
39
|
"publishConfig": {
|
|
@@ -63,7 +44,7 @@
|
|
|
63
44
|
"url": "https://github.com/XYOracleNetwork/sdk-xyo-client-js.git"
|
|
64
45
|
},
|
|
65
46
|
"sideEffects": false,
|
|
66
|
-
"types": "dist/
|
|
67
|
-
"version": "
|
|
47
|
+
"types": "dist/neutral/index.d.ts",
|
|
48
|
+
"version": "3.0.0",
|
|
68
49
|
"type": "module"
|
|
69
50
|
}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { BoundWitness } from '@xyo-network/boundwitness-model';
|
|
2
|
-
import { PayloadValidator } from '@xyo-network/payload-validator';
|
|
3
|
-
export declare class BoundWitnessValidator<T extends BoundWitness<{
|
|
4
|
-
schema: string;
|
|
5
|
-
}> = BoundWitness> extends PayloadValidator<T> {
|
|
6
|
-
protected get expectedSchema(): string;
|
|
7
|
-
static validateSignature(hash: ArrayBuffer, address: ArrayBuffer, signature?: ArrayBuffer): Promise<Error[]>;
|
|
8
|
-
addresses(): Error[];
|
|
9
|
-
addressesUniqueness(): Error[];
|
|
10
|
-
previousHashes(): Error[];
|
|
11
|
-
schema(): Error[];
|
|
12
|
-
schemas(): Error[];
|
|
13
|
-
signatures(): Promise<Error[]>;
|
|
14
|
-
validate(): Promise<Error[]>;
|
|
15
|
-
validateArrayLengths(): Error[];
|
|
16
|
-
validatePayloadHashesLength(): Error[];
|
|
17
|
-
private validateArrayLength;
|
|
18
|
-
}
|
|
19
|
-
//# sourceMappingURL=Validator.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Validator.d.ts","sourceRoot":"","sources":["../../src/Validator.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,YAAY,EAAsB,MAAM,iCAAiC,CAAA;AAElF,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAA;AAMjE,qBAAa,qBAAqB,CAAC,CAAC,SAAS,YAAY,CAAC;IAAE,MAAM,EAAE,MAAM,CAAA;CAAE,CAAC,GAAG,YAAY,CAAE,SAAQ,gBAAgB,CAAC,CAAC,CAAC;IACvH,SAAS,KAAK,cAAc,IAAI,MAAM,CAErC;WAEY,iBAAiB,CAAC,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,WAAW,EAAE,SAAS,CAAC,EAAE,WAAW,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;IAUlH,SAAS,IAAI,KAAK,EAAE;IAQpB,mBAAmB,IAAI,KAAK,EAAE;IAQ9B,cAAc;IAKd,MAAM,IAAI,KAAK,EAAE;IAQjB,OAAO,IAAI,KAAK,EAAE;IAgBZ,UAAU,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;IAiBrB,QAAQ;IAYvB,oBAAoB,IAAI,KAAK,EAAE;IAM/B,2BAA2B,IAAI,KAAK,EAAE;IAMtC,OAAO,CAAC,mBAAmB;CAY5B"}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { BoundWitness } from '@xyo-network/boundwitness-model';
|
|
2
|
-
import { PayloadValidator } from '@xyo-network/payload-validator';
|
|
3
|
-
export declare class BoundWitnessValidator<T extends BoundWitness<{
|
|
4
|
-
schema: string;
|
|
5
|
-
}> = BoundWitness> extends PayloadValidator<T> {
|
|
6
|
-
protected get expectedSchema(): string;
|
|
7
|
-
static validateSignature(hash: ArrayBuffer, address: ArrayBuffer, signature?: ArrayBuffer): Promise<Error[]>;
|
|
8
|
-
addresses(): Error[];
|
|
9
|
-
addressesUniqueness(): Error[];
|
|
10
|
-
previousHashes(): Error[];
|
|
11
|
-
schema(): Error[];
|
|
12
|
-
schemas(): Error[];
|
|
13
|
-
signatures(): Promise<Error[]>;
|
|
14
|
-
validate(): Promise<Error[]>;
|
|
15
|
-
validateArrayLengths(): Error[];
|
|
16
|
-
validatePayloadHashesLength(): Error[];
|
|
17
|
-
private validateArrayLength;
|
|
18
|
-
}
|
|
19
|
-
//# sourceMappingURL=Validator.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Validator.d.ts","sourceRoot":"","sources":["../../src/Validator.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,YAAY,EAAsB,MAAM,iCAAiC,CAAA;AAElF,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAA;AAMjE,qBAAa,qBAAqB,CAAC,CAAC,SAAS,YAAY,CAAC;IAAE,MAAM,EAAE,MAAM,CAAA;CAAE,CAAC,GAAG,YAAY,CAAE,SAAQ,gBAAgB,CAAC,CAAC,CAAC;IACvH,SAAS,KAAK,cAAc,IAAI,MAAM,CAErC;WAEY,iBAAiB,CAAC,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,WAAW,EAAE,SAAS,CAAC,EAAE,WAAW,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;IAUlH,SAAS,IAAI,KAAK,EAAE;IAQpB,mBAAmB,IAAI,KAAK,EAAE;IAQ9B,cAAc;IAKd,MAAM,IAAI,KAAK,EAAE;IAQjB,OAAO,IAAI,KAAK,EAAE;IAgBZ,UAAU,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;IAiBrB,QAAQ;IAYvB,oBAAoB,IAAI,KAAK,EAAE;IAM/B,2BAA2B,IAAI,KAAK,EAAE;IAMtC,OAAO,CAAC,mBAAmB;CAY5B"}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { BoundWitness } from '@xyo-network/boundwitness-model';
|
|
2
|
-
import { PayloadValidator } from '@xyo-network/payload-validator';
|
|
3
|
-
export declare class BoundWitnessValidator<T extends BoundWitness<{
|
|
4
|
-
schema: string;
|
|
5
|
-
}> = BoundWitness> extends PayloadValidator<T> {
|
|
6
|
-
protected get expectedSchema(): string;
|
|
7
|
-
static validateSignature(hash: ArrayBuffer, address: ArrayBuffer, signature?: ArrayBuffer): Promise<Error[]>;
|
|
8
|
-
addresses(): Error[];
|
|
9
|
-
addressesUniqueness(): Error[];
|
|
10
|
-
previousHashes(): Error[];
|
|
11
|
-
schema(): Error[];
|
|
12
|
-
schemas(): Error[];
|
|
13
|
-
signatures(): Promise<Error[]>;
|
|
14
|
-
validate(): Promise<Error[]>;
|
|
15
|
-
validateArrayLengths(): Error[];
|
|
16
|
-
validatePayloadHashesLength(): Error[];
|
|
17
|
-
private validateArrayLength;
|
|
18
|
-
}
|
|
19
|
-
//# sourceMappingURL=Validator.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Validator.d.ts","sourceRoot":"","sources":["../../src/Validator.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,YAAY,EAAsB,MAAM,iCAAiC,CAAA;AAElF,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAA;AAMjE,qBAAa,qBAAqB,CAAC,CAAC,SAAS,YAAY,CAAC;IAAE,MAAM,EAAE,MAAM,CAAA;CAAE,CAAC,GAAG,YAAY,CAAE,SAAQ,gBAAgB,CAAC,CAAC,CAAC;IACvH,SAAS,KAAK,cAAc,IAAI,MAAM,CAErC;WAEY,iBAAiB,CAAC,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,WAAW,EAAE,SAAS,CAAC,EAAE,WAAW,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;IAUlH,SAAS,IAAI,KAAK,EAAE;IAQpB,mBAAmB,IAAI,KAAK,EAAE;IAQ9B,cAAc;IAKd,MAAM,IAAI,KAAK,EAAE;IAQjB,OAAO,IAAI,KAAK,EAAE;IAgBZ,UAAU,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;IAiBrB,QAAQ;IAYvB,oBAAoB,IAAI,KAAK,EAAE;IAM/B,2BAA2B,IAAI,KAAK,EAAE;IAMtC,OAAO,CAAC,mBAAmB;CAY5B"}
|
package/dist/browser/index.cjs
DELETED
|
@@ -1,134 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
|
|
20
|
-
// src/index.ts
|
|
21
|
-
var src_exports = {};
|
|
22
|
-
__export(src_exports, {
|
|
23
|
-
BoundWitnessValidator: () => BoundWitnessValidator
|
|
24
|
-
});
|
|
25
|
-
module.exports = __toCommonJS(src_exports);
|
|
26
|
-
|
|
27
|
-
// src/Validator.ts
|
|
28
|
-
var import_arraybuffer = require("@xylabs/arraybuffer");
|
|
29
|
-
var import_lodash = require("@xylabs/lodash");
|
|
30
|
-
var import_typeof = require("@xylabs/typeof");
|
|
31
|
-
var import_account = require("@xyo-network/account");
|
|
32
|
-
var import_boundwitness_model = require("@xyo-network/boundwitness-model");
|
|
33
|
-
var import_payload = require("@xyo-network/payload");
|
|
34
|
-
var import_payload_validator = require("@xyo-network/payload-validator");
|
|
35
|
-
var validateArraysSameLength = (a, b, message = "Array length mismatch") => {
|
|
36
|
-
return a.length == b.length ? [] : [new Error(`${message} []`)];
|
|
37
|
-
};
|
|
38
|
-
var BoundWitnessValidator = class _BoundWitnessValidator extends import_payload_validator.PayloadValidator {
|
|
39
|
-
get expectedSchema() {
|
|
40
|
-
return import_boundwitness_model.BoundWitnessSchema;
|
|
41
|
-
}
|
|
42
|
-
static async validateSignature(hash, address, signature) {
|
|
43
|
-
if (!signature) {
|
|
44
|
-
return [new Error(`Missing signature [${address}]`)];
|
|
45
|
-
}
|
|
46
|
-
if (!await import_account.Elliptic.verify(hash, signature, address)) {
|
|
47
|
-
return [new Error(`Invalid signature [${address}]`)];
|
|
48
|
-
}
|
|
49
|
-
return [];
|
|
50
|
-
}
|
|
51
|
-
addresses() {
|
|
52
|
-
const errors = [];
|
|
53
|
-
errors.push(...this.addressesUniqueness());
|
|
54
|
-
return errors;
|
|
55
|
-
}
|
|
56
|
-
addressesUniqueness() {
|
|
57
|
-
const errors = [];
|
|
58
|
-
const { addresses } = this.obj;
|
|
59
|
-
const uniqAddresses = (0, import_lodash.uniq)(addresses);
|
|
60
|
-
if (addresses?.length !== uniqAddresses?.length) errors.push(new Error("addresses must be unique"));
|
|
61
|
-
return errors;
|
|
62
|
-
}
|
|
63
|
-
previousHashes() {
|
|
64
|
-
const errors = [];
|
|
65
|
-
return errors;
|
|
66
|
-
}
|
|
67
|
-
schema() {
|
|
68
|
-
const errors = [];
|
|
69
|
-
if (this.obj.schema !== this.expectedSchema) {
|
|
70
|
-
errors.push(new Error(`invalid schema [${this.expectedSchema} !== ${this.obj.schema}]`));
|
|
71
|
-
}
|
|
72
|
-
return errors;
|
|
73
|
-
}
|
|
74
|
-
schemas() {
|
|
75
|
-
const errors = [];
|
|
76
|
-
const Schemas = this.obj.payload_schemas;
|
|
77
|
-
if (Schemas) {
|
|
78
|
-
const schemaValidators = Schemas.map((schema) => {
|
|
79
|
-
return import_payload_validator.PayloadValidator.schemaNameValidatorFactory?.(schema);
|
|
80
|
-
});
|
|
81
|
-
for (const validator of schemaValidators) {
|
|
82
|
-
if (validator) {
|
|
83
|
-
errors.push(...validator.all());
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
return errors;
|
|
88
|
-
}
|
|
89
|
-
async signatures() {
|
|
90
|
-
return [
|
|
91
|
-
...validateArraysSameLength(this.obj.$meta?.signatures ?? [], this.obj.addresses ?? [], "Length mismatch: address/signature"),
|
|
92
|
-
...(await Promise.all(
|
|
93
|
-
this.obj.addresses?.map(
|
|
94
|
-
async (address, index) => _BoundWitnessValidator.validateSignature(
|
|
95
|
-
(0, import_arraybuffer.toUint8Array)(await import_payload.PayloadBuilder.dataHash(this.payload)),
|
|
96
|
-
(0, import_arraybuffer.toUint8Array)(address),
|
|
97
|
-
(0, import_arraybuffer.toUint8Array)(this.obj.$meta?.signatures?.[index])
|
|
98
|
-
)
|
|
99
|
-
) ?? []
|
|
100
|
-
)).flat()
|
|
101
|
-
];
|
|
102
|
-
}
|
|
103
|
-
async validate() {
|
|
104
|
-
return [
|
|
105
|
-
...await this.signatures(),
|
|
106
|
-
...this.addresses(),
|
|
107
|
-
...this.validateArrayLengths(),
|
|
108
|
-
...this.schemas(),
|
|
109
|
-
...this.previousHashes(),
|
|
110
|
-
...this.schema(),
|
|
111
|
-
...await super.validate()
|
|
112
|
-
];
|
|
113
|
-
}
|
|
114
|
-
validateArrayLengths() {
|
|
115
|
-
const errors = [];
|
|
116
|
-
errors.push(...this.validatePayloadHashesLength());
|
|
117
|
-
return errors;
|
|
118
|
-
}
|
|
119
|
-
validatePayloadHashesLength() {
|
|
120
|
-
const errors = [];
|
|
121
|
-
errors.push(...this.validateArrayLength("payload_hashes", "payload_schemas"));
|
|
122
|
-
return errors;
|
|
123
|
-
}
|
|
124
|
-
validateArrayLength(fieldName, compareArrayName) {
|
|
125
|
-
const errors = [];
|
|
126
|
-
const [array, arrayErrors] = (0, import_typeof.validateType)("array", this.stringKeyObj[fieldName], true);
|
|
127
|
-
const [compareArray, compareArrayErrors] = (0, import_typeof.validateType)("array", this.stringKeyObj[compareArrayName], true);
|
|
128
|
-
if (array?.length !== compareArray?.length) {
|
|
129
|
-
errors.push(new Error(`${fieldName}/${compareArrayName} count mismatch [${array?.length} !== ${compareArray?.length}]`));
|
|
130
|
-
}
|
|
131
|
-
return [...arrayErrors, ...compareArrayErrors, ...errors];
|
|
132
|
-
}
|
|
133
|
-
};
|
|
134
|
-
//# sourceMappingURL=index.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/Validator.ts"],"sourcesContent":["export * from './Validator.ts'\n","import { toUint8Array } from '@xylabs/arraybuffer'\nimport { uniq } from '@xylabs/lodash'\nimport { validateType } from '@xylabs/typeof'\nimport { Elliptic } from '@xyo-network/account'\nimport { BoundWitness, BoundWitnessSchema } from '@xyo-network/boundwitness-model'\nimport { PayloadBuilder } from '@xyo-network/payload'\nimport { PayloadValidator } from '@xyo-network/payload-validator'\n\nconst validateArraysSameLength = (a: unknown[], b: unknown[], message = 'Array length mismatch') => {\n return a.length == b.length ? [] : [new Error(`${message} []`)]\n}\n\nexport class BoundWitnessValidator<T extends BoundWitness<{ schema: string }> = BoundWitness> extends PayloadValidator<T> {\n protected get expectedSchema(): string {\n return BoundWitnessSchema\n }\n\n static async validateSignature(hash: ArrayBuffer, address: ArrayBuffer, signature?: ArrayBuffer): Promise<Error[]> {\n if (!signature) {\n return [new Error(`Missing signature [${address}]`)]\n }\n if (!(await Elliptic.verify(hash, signature, address))) {\n return [new Error(`Invalid signature [${address}]`)]\n }\n return []\n }\n\n addresses(): Error[] {\n const errors: Error[] = []\n // const { addresses } = this.obj\n // if (!addresses?.length) errors.push(new Error('addresses missing [at least one address required]'))\n errors.push(...this.addressesUniqueness())\n return errors\n }\n\n addressesUniqueness(): Error[] {\n const errors: Error[] = []\n const { addresses } = this.obj\n const uniqAddresses = uniq(addresses)\n if (addresses?.length !== uniqAddresses?.length) errors.push(new Error('addresses must be unique'))\n return errors\n }\n\n previousHashes() {\n const errors: Error[] = []\n return errors\n }\n\n schema(): Error[] {\n const errors: Error[] = []\n if (this.obj.schema !== this.expectedSchema) {\n errors.push(new Error(`invalid schema [${this.expectedSchema} !== ${this.obj.schema}]`))\n }\n return errors\n }\n\n schemas(): Error[] {\n const errors: Error[] = []\n const Schemas = this.obj.payload_schemas\n if (Schemas) {\n const schemaValidators = Schemas.map((schema: string) => {\n return PayloadValidator.schemaNameValidatorFactory?.(schema)\n })\n for (const validator of schemaValidators) {\n if (validator) {\n errors.push(...validator.all())\n }\n }\n }\n return errors\n }\n\n async signatures(): Promise<Error[]> {\n return [\n ...validateArraysSameLength(this.obj.$meta?.signatures ?? [], this.obj.addresses ?? [], 'Length mismatch: address/signature'),\n ...(\n await Promise.all(\n this.obj.addresses?.map<Promise<Error[]>>(async (address, index) =>\n BoundWitnessValidator.validateSignature(\n toUint8Array(await PayloadBuilder.dataHash(this.payload)),\n toUint8Array(address),\n toUint8Array(this.obj.$meta?.signatures?.[index]),\n ),\n ) ?? [],\n )\n ).flat(),\n ]\n }\n\n override async validate() {\n return [\n ...(await this.signatures()),\n ...this.addresses(),\n ...this.validateArrayLengths(),\n ...this.schemas(),\n ...this.previousHashes(),\n ...this.schema(),\n ...(await super.validate()),\n ]\n }\n\n validateArrayLengths(): Error[] {\n const errors: Error[] = []\n errors.push(...this.validatePayloadHashesLength())\n return errors\n }\n\n validatePayloadHashesLength(): Error[] {\n const errors: Error[] = []\n errors.push(...this.validateArrayLength('payload_hashes', 'payload_schemas'))\n return errors\n }\n\n private validateArrayLength(fieldName: string, compareArrayName: string): Error[] {\n const errors: Error[] = []\n\n const [array, arrayErrors] = validateType('array', this.stringKeyObj[fieldName] as [], true)\n const [compareArray, compareArrayErrors] = validateType('array', this.stringKeyObj[compareArrayName] as [], true)\n\n if (array?.length !== compareArray?.length) {\n errors.push(new Error(`${fieldName}/${compareArrayName} count mismatch [${array?.length} !== ${compareArray?.length}]`))\n }\n\n return [...arrayErrors, ...compareArrayErrors, ...errors]\n }\n}\n"],"mappings":"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","names":[]}
|
package/dist/browser/index.d.cts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAA"}
|
package/dist/browser/index.d.mts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAA"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAA"}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { BoundWitness } from '@xyo-network/boundwitness-model';
|
|
2
|
-
import { PayloadValidator } from '@xyo-network/payload-validator';
|
|
3
|
-
export declare class BoundWitnessValidator<T extends BoundWitness<{
|
|
4
|
-
schema: string;
|
|
5
|
-
}> = BoundWitness> extends PayloadValidator<T> {
|
|
6
|
-
protected get expectedSchema(): string;
|
|
7
|
-
static validateSignature(hash: ArrayBuffer, address: ArrayBuffer, signature?: ArrayBuffer): Promise<Error[]>;
|
|
8
|
-
addresses(): Error[];
|
|
9
|
-
addressesUniqueness(): Error[];
|
|
10
|
-
previousHashes(): Error[];
|
|
11
|
-
schema(): Error[];
|
|
12
|
-
schemas(): Error[];
|
|
13
|
-
signatures(): Promise<Error[]>;
|
|
14
|
-
validate(): Promise<Error[]>;
|
|
15
|
-
validateArrayLengths(): Error[];
|
|
16
|
-
validatePayloadHashesLength(): Error[];
|
|
17
|
-
private validateArrayLength;
|
|
18
|
-
}
|
|
19
|
-
//# sourceMappingURL=Validator.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Validator.d.ts","sourceRoot":"","sources":["../../src/Validator.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,YAAY,EAAsB,MAAM,iCAAiC,CAAA;AAElF,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAA;AAMjE,qBAAa,qBAAqB,CAAC,CAAC,SAAS,YAAY,CAAC;IAAE,MAAM,EAAE,MAAM,CAAA;CAAE,CAAC,GAAG,YAAY,CAAE,SAAQ,gBAAgB,CAAC,CAAC,CAAC;IACvH,SAAS,KAAK,cAAc,IAAI,MAAM,CAErC;WAEY,iBAAiB,CAAC,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,WAAW,EAAE,SAAS,CAAC,EAAE,WAAW,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;IAUlH,SAAS,IAAI,KAAK,EAAE;IAQpB,mBAAmB,IAAI,KAAK,EAAE;IAQ9B,cAAc;IAKd,MAAM,IAAI,KAAK,EAAE;IAQjB,OAAO,IAAI,KAAK,EAAE;IAgBZ,UAAU,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;IAiBrB,QAAQ;IAYvB,oBAAoB,IAAI,KAAK,EAAE;IAM/B,2BAA2B,IAAI,KAAK,EAAE;IAMtC,OAAO,CAAC,mBAAmB;CAY5B"}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { BoundWitness } from '@xyo-network/boundwitness-model';
|
|
2
|
-
import { PayloadValidator } from '@xyo-network/payload-validator';
|
|
3
|
-
export declare class BoundWitnessValidator<T extends BoundWitness<{
|
|
4
|
-
schema: string;
|
|
5
|
-
}> = BoundWitness> extends PayloadValidator<T> {
|
|
6
|
-
protected get expectedSchema(): string;
|
|
7
|
-
static validateSignature(hash: ArrayBuffer, address: ArrayBuffer, signature?: ArrayBuffer): Promise<Error[]>;
|
|
8
|
-
addresses(): Error[];
|
|
9
|
-
addressesUniqueness(): Error[];
|
|
10
|
-
previousHashes(): Error[];
|
|
11
|
-
schema(): Error[];
|
|
12
|
-
schemas(): Error[];
|
|
13
|
-
signatures(): Promise<Error[]>;
|
|
14
|
-
validate(): Promise<Error[]>;
|
|
15
|
-
validateArrayLengths(): Error[];
|
|
16
|
-
validatePayloadHashesLength(): Error[];
|
|
17
|
-
private validateArrayLength;
|
|
18
|
-
}
|
|
19
|
-
//# sourceMappingURL=Validator.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Validator.d.ts","sourceRoot":"","sources":["../../src/Validator.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,YAAY,EAAsB,MAAM,iCAAiC,CAAA;AAElF,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAA;AAMjE,qBAAa,qBAAqB,CAAC,CAAC,SAAS,YAAY,CAAC;IAAE,MAAM,EAAE,MAAM,CAAA;CAAE,CAAC,GAAG,YAAY,CAAE,SAAQ,gBAAgB,CAAC,CAAC,CAAC;IACvH,SAAS,KAAK,cAAc,IAAI,MAAM,CAErC;WAEY,iBAAiB,CAAC,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,WAAW,EAAE,SAAS,CAAC,EAAE,WAAW,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;IAUlH,SAAS,IAAI,KAAK,EAAE;IAQpB,mBAAmB,IAAI,KAAK,EAAE;IAQ9B,cAAc;IAKd,MAAM,IAAI,KAAK,EAAE;IAQjB,OAAO,IAAI,KAAK,EAAE;IAgBZ,UAAU,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;IAiBrB,QAAQ;IAYvB,oBAAoB,IAAI,KAAK,EAAE;IAM/B,2BAA2B,IAAI,KAAK,EAAE;IAMtC,OAAO,CAAC,mBAAmB;CAY5B"}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { BoundWitness } from '@xyo-network/boundwitness-model';
|
|
2
|
-
import { PayloadValidator } from '@xyo-network/payload-validator';
|
|
3
|
-
export declare class BoundWitnessValidator<T extends BoundWitness<{
|
|
4
|
-
schema: string;
|
|
5
|
-
}> = BoundWitness> extends PayloadValidator<T> {
|
|
6
|
-
protected get expectedSchema(): string;
|
|
7
|
-
static validateSignature(hash: ArrayBuffer, address: ArrayBuffer, signature?: ArrayBuffer): Promise<Error[]>;
|
|
8
|
-
addresses(): Error[];
|
|
9
|
-
addressesUniqueness(): Error[];
|
|
10
|
-
previousHashes(): Error[];
|
|
11
|
-
schema(): Error[];
|
|
12
|
-
schemas(): Error[];
|
|
13
|
-
signatures(): Promise<Error[]>;
|
|
14
|
-
validate(): Promise<Error[]>;
|
|
15
|
-
validateArrayLengths(): Error[];
|
|
16
|
-
validatePayloadHashesLength(): Error[];
|
|
17
|
-
private validateArrayLength;
|
|
18
|
-
}
|
|
19
|
-
//# sourceMappingURL=Validator.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Validator.d.ts","sourceRoot":"","sources":["../../src/Validator.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,YAAY,EAAsB,MAAM,iCAAiC,CAAA;AAElF,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAA;AAMjE,qBAAa,qBAAqB,CAAC,CAAC,SAAS,YAAY,CAAC;IAAE,MAAM,EAAE,MAAM,CAAA;CAAE,CAAC,GAAG,YAAY,CAAE,SAAQ,gBAAgB,CAAC,CAAC,CAAC;IACvH,SAAS,KAAK,cAAc,IAAI,MAAM,CAErC;WAEY,iBAAiB,CAAC,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,WAAW,EAAE,SAAS,CAAC,EAAE,WAAW,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;IAUlH,SAAS,IAAI,KAAK,EAAE;IAQpB,mBAAmB,IAAI,KAAK,EAAE;IAQ9B,cAAc;IAKd,MAAM,IAAI,KAAK,EAAE;IAQjB,OAAO,IAAI,KAAK,EAAE;IAgBZ,UAAU,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;IAiBrB,QAAQ;IAYvB,oBAAoB,IAAI,KAAK,EAAE;IAM/B,2BAA2B,IAAI,KAAK,EAAE;IAMtC,OAAO,CAAC,mBAAmB;CAY5B"}
|
package/dist/neutral/index.cjs
DELETED
|
@@ -1,134 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
|
|
20
|
-
// src/index.ts
|
|
21
|
-
var src_exports = {};
|
|
22
|
-
__export(src_exports, {
|
|
23
|
-
BoundWitnessValidator: () => BoundWitnessValidator
|
|
24
|
-
});
|
|
25
|
-
module.exports = __toCommonJS(src_exports);
|
|
26
|
-
|
|
27
|
-
// src/Validator.ts
|
|
28
|
-
var import_arraybuffer = require("@xylabs/arraybuffer");
|
|
29
|
-
var import_lodash = require("@xylabs/lodash");
|
|
30
|
-
var import_typeof = require("@xylabs/typeof");
|
|
31
|
-
var import_account = require("@xyo-network/account");
|
|
32
|
-
var import_boundwitness_model = require("@xyo-network/boundwitness-model");
|
|
33
|
-
var import_payload = require("@xyo-network/payload");
|
|
34
|
-
var import_payload_validator = require("@xyo-network/payload-validator");
|
|
35
|
-
var validateArraysSameLength = (a, b, message = "Array length mismatch") => {
|
|
36
|
-
return a.length == b.length ? [] : [new Error(`${message} []`)];
|
|
37
|
-
};
|
|
38
|
-
var BoundWitnessValidator = class _BoundWitnessValidator extends import_payload_validator.PayloadValidator {
|
|
39
|
-
get expectedSchema() {
|
|
40
|
-
return import_boundwitness_model.BoundWitnessSchema;
|
|
41
|
-
}
|
|
42
|
-
static async validateSignature(hash, address, signature) {
|
|
43
|
-
if (!signature) {
|
|
44
|
-
return [new Error(`Missing signature [${address}]`)];
|
|
45
|
-
}
|
|
46
|
-
if (!await import_account.Elliptic.verify(hash, signature, address)) {
|
|
47
|
-
return [new Error(`Invalid signature [${address}]`)];
|
|
48
|
-
}
|
|
49
|
-
return [];
|
|
50
|
-
}
|
|
51
|
-
addresses() {
|
|
52
|
-
const errors = [];
|
|
53
|
-
errors.push(...this.addressesUniqueness());
|
|
54
|
-
return errors;
|
|
55
|
-
}
|
|
56
|
-
addressesUniqueness() {
|
|
57
|
-
const errors = [];
|
|
58
|
-
const { addresses } = this.obj;
|
|
59
|
-
const uniqAddresses = (0, import_lodash.uniq)(addresses);
|
|
60
|
-
if (addresses?.length !== uniqAddresses?.length) errors.push(new Error("addresses must be unique"));
|
|
61
|
-
return errors;
|
|
62
|
-
}
|
|
63
|
-
previousHashes() {
|
|
64
|
-
const errors = [];
|
|
65
|
-
return errors;
|
|
66
|
-
}
|
|
67
|
-
schema() {
|
|
68
|
-
const errors = [];
|
|
69
|
-
if (this.obj.schema !== this.expectedSchema) {
|
|
70
|
-
errors.push(new Error(`invalid schema [${this.expectedSchema} !== ${this.obj.schema}]`));
|
|
71
|
-
}
|
|
72
|
-
return errors;
|
|
73
|
-
}
|
|
74
|
-
schemas() {
|
|
75
|
-
const errors = [];
|
|
76
|
-
const Schemas = this.obj.payload_schemas;
|
|
77
|
-
if (Schemas) {
|
|
78
|
-
const schemaValidators = Schemas.map((schema) => {
|
|
79
|
-
return import_payload_validator.PayloadValidator.schemaNameValidatorFactory?.(schema);
|
|
80
|
-
});
|
|
81
|
-
for (const validator of schemaValidators) {
|
|
82
|
-
if (validator) {
|
|
83
|
-
errors.push(...validator.all());
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
return errors;
|
|
88
|
-
}
|
|
89
|
-
async signatures() {
|
|
90
|
-
return [
|
|
91
|
-
...validateArraysSameLength(this.obj.$meta?.signatures ?? [], this.obj.addresses ?? [], "Length mismatch: address/signature"),
|
|
92
|
-
...(await Promise.all(
|
|
93
|
-
this.obj.addresses?.map(
|
|
94
|
-
async (address, index) => _BoundWitnessValidator.validateSignature(
|
|
95
|
-
(0, import_arraybuffer.toUint8Array)(await import_payload.PayloadBuilder.dataHash(this.payload)),
|
|
96
|
-
(0, import_arraybuffer.toUint8Array)(address),
|
|
97
|
-
(0, import_arraybuffer.toUint8Array)(this.obj.$meta?.signatures?.[index])
|
|
98
|
-
)
|
|
99
|
-
) ?? []
|
|
100
|
-
)).flat()
|
|
101
|
-
];
|
|
102
|
-
}
|
|
103
|
-
async validate() {
|
|
104
|
-
return [
|
|
105
|
-
...await this.signatures(),
|
|
106
|
-
...this.addresses(),
|
|
107
|
-
...this.validateArrayLengths(),
|
|
108
|
-
...this.schemas(),
|
|
109
|
-
...this.previousHashes(),
|
|
110
|
-
...this.schema(),
|
|
111
|
-
...await super.validate()
|
|
112
|
-
];
|
|
113
|
-
}
|
|
114
|
-
validateArrayLengths() {
|
|
115
|
-
const errors = [];
|
|
116
|
-
errors.push(...this.validatePayloadHashesLength());
|
|
117
|
-
return errors;
|
|
118
|
-
}
|
|
119
|
-
validatePayloadHashesLength() {
|
|
120
|
-
const errors = [];
|
|
121
|
-
errors.push(...this.validateArrayLength("payload_hashes", "payload_schemas"));
|
|
122
|
-
return errors;
|
|
123
|
-
}
|
|
124
|
-
validateArrayLength(fieldName, compareArrayName) {
|
|
125
|
-
const errors = [];
|
|
126
|
-
const [array, arrayErrors] = (0, import_typeof.validateType)("array", this.stringKeyObj[fieldName], true);
|
|
127
|
-
const [compareArray, compareArrayErrors] = (0, import_typeof.validateType)("array", this.stringKeyObj[compareArrayName], true);
|
|
128
|
-
if (array?.length !== compareArray?.length) {
|
|
129
|
-
errors.push(new Error(`${fieldName}/${compareArrayName} count mismatch [${array?.length} !== ${compareArray?.length}]`));
|
|
130
|
-
}
|
|
131
|
-
return [...arrayErrors, ...compareArrayErrors, ...errors];
|
|
132
|
-
}
|
|
133
|
-
};
|
|
134
|
-
//# sourceMappingURL=index.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/Validator.ts"],"sourcesContent":["export * from './Validator.ts'\n","import { toUint8Array } from '@xylabs/arraybuffer'\nimport { uniq } from '@xylabs/lodash'\nimport { validateType } from '@xylabs/typeof'\nimport { Elliptic } from '@xyo-network/account'\nimport { BoundWitness, BoundWitnessSchema } from '@xyo-network/boundwitness-model'\nimport { PayloadBuilder } from '@xyo-network/payload'\nimport { PayloadValidator } from '@xyo-network/payload-validator'\n\nconst validateArraysSameLength = (a: unknown[], b: unknown[], message = 'Array length mismatch') => {\n return a.length == b.length ? [] : [new Error(`${message} []`)]\n}\n\nexport class BoundWitnessValidator<T extends BoundWitness<{ schema: string }> = BoundWitness> extends PayloadValidator<T> {\n protected get expectedSchema(): string {\n return BoundWitnessSchema\n }\n\n static async validateSignature(hash: ArrayBuffer, address: ArrayBuffer, signature?: ArrayBuffer): Promise<Error[]> {\n if (!signature) {\n return [new Error(`Missing signature [${address}]`)]\n }\n if (!(await Elliptic.verify(hash, signature, address))) {\n return [new Error(`Invalid signature [${address}]`)]\n }\n return []\n }\n\n addresses(): Error[] {\n const errors: Error[] = []\n // const { addresses } = this.obj\n // if (!addresses?.length) errors.push(new Error('addresses missing [at least one address required]'))\n errors.push(...this.addressesUniqueness())\n return errors\n }\n\n addressesUniqueness(): Error[] {\n const errors: Error[] = []\n const { addresses } = this.obj\n const uniqAddresses = uniq(addresses)\n if (addresses?.length !== uniqAddresses?.length) errors.push(new Error('addresses must be unique'))\n return errors\n }\n\n previousHashes() {\n const errors: Error[] = []\n return errors\n }\n\n schema(): Error[] {\n const errors: Error[] = []\n if (this.obj.schema !== this.expectedSchema) {\n errors.push(new Error(`invalid schema [${this.expectedSchema} !== ${this.obj.schema}]`))\n }\n return errors\n }\n\n schemas(): Error[] {\n const errors: Error[] = []\n const Schemas = this.obj.payload_schemas\n if (Schemas) {\n const schemaValidators = Schemas.map((schema: string) => {\n return PayloadValidator.schemaNameValidatorFactory?.(schema)\n })\n for (const validator of schemaValidators) {\n if (validator) {\n errors.push(...validator.all())\n }\n }\n }\n return errors\n }\n\n async signatures(): Promise<Error[]> {\n return [\n ...validateArraysSameLength(this.obj.$meta?.signatures ?? [], this.obj.addresses ?? [], 'Length mismatch: address/signature'),\n ...(\n await Promise.all(\n this.obj.addresses?.map<Promise<Error[]>>(async (address, index) =>\n BoundWitnessValidator.validateSignature(\n toUint8Array(await PayloadBuilder.dataHash(this.payload)),\n toUint8Array(address),\n toUint8Array(this.obj.$meta?.signatures?.[index]),\n ),\n ) ?? [],\n )\n ).flat(),\n ]\n }\n\n override async validate() {\n return [\n ...(await this.signatures()),\n ...this.addresses(),\n ...this.validateArrayLengths(),\n ...this.schemas(),\n ...this.previousHashes(),\n ...this.schema(),\n ...(await super.validate()),\n ]\n }\n\n validateArrayLengths(): Error[] {\n const errors: Error[] = []\n errors.push(...this.validatePayloadHashesLength())\n return errors\n }\n\n validatePayloadHashesLength(): Error[] {\n const errors: Error[] = []\n errors.push(...this.validateArrayLength('payload_hashes', 'payload_schemas'))\n return errors\n }\n\n private validateArrayLength(fieldName: string, compareArrayName: string): Error[] {\n const errors: Error[] = []\n\n const [array, arrayErrors] = validateType('array', this.stringKeyObj[fieldName] as [], true)\n const [compareArray, compareArrayErrors] = validateType('array', this.stringKeyObj[compareArrayName] as [], true)\n\n if (array?.length !== compareArray?.length) {\n errors.push(new Error(`${fieldName}/${compareArrayName} count mismatch [${array?.length} !== ${compareArray?.length}]`))\n }\n\n return [...arrayErrors, ...compareArrayErrors, ...errors]\n }\n}\n"],"mappings":"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","names":[]}
|
package/dist/neutral/index.d.cts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAA"}
|
package/dist/neutral/index.d.mts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAA"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAA"}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { BoundWitness } from '@xyo-network/boundwitness-model';
|
|
2
|
-
import { PayloadValidator } from '@xyo-network/payload-validator';
|
|
3
|
-
export declare class BoundWitnessValidator<T extends BoundWitness<{
|
|
4
|
-
schema: string;
|
|
5
|
-
}> = BoundWitness> extends PayloadValidator<T> {
|
|
6
|
-
protected get expectedSchema(): string;
|
|
7
|
-
static validateSignature(hash: ArrayBuffer, address: ArrayBuffer, signature?: ArrayBuffer): Promise<Error[]>;
|
|
8
|
-
addresses(): Error[];
|
|
9
|
-
addressesUniqueness(): Error[];
|
|
10
|
-
previousHashes(): Error[];
|
|
11
|
-
schema(): Error[];
|
|
12
|
-
schemas(): Error[];
|
|
13
|
-
signatures(): Promise<Error[]>;
|
|
14
|
-
validate(): Promise<Error[]>;
|
|
15
|
-
validateArrayLengths(): Error[];
|
|
16
|
-
validatePayloadHashesLength(): Error[];
|
|
17
|
-
private validateArrayLength;
|
|
18
|
-
}
|
|
19
|
-
//# sourceMappingURL=Validator.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Validator.d.ts","sourceRoot":"","sources":["../../src/Validator.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,YAAY,EAAsB,MAAM,iCAAiC,CAAA;AAElF,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAA;AAMjE,qBAAa,qBAAqB,CAAC,CAAC,SAAS,YAAY,CAAC;IAAE,MAAM,EAAE,MAAM,CAAA;CAAE,CAAC,GAAG,YAAY,CAAE,SAAQ,gBAAgB,CAAC,CAAC,CAAC;IACvH,SAAS,KAAK,cAAc,IAAI,MAAM,CAErC;WAEY,iBAAiB,CAAC,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,WAAW,EAAE,SAAS,CAAC,EAAE,WAAW,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;IAUlH,SAAS,IAAI,KAAK,EAAE;IAQpB,mBAAmB,IAAI,KAAK,EAAE;IAQ9B,cAAc;IAKd,MAAM,IAAI,KAAK,EAAE;IAQjB,OAAO,IAAI,KAAK,EAAE;IAgBZ,UAAU,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;IAiBrB,QAAQ;IAYvB,oBAAoB,IAAI,KAAK,EAAE;IAM/B,2BAA2B,IAAI,KAAK,EAAE;IAMtC,OAAO,CAAC,mBAAmB;CAY5B"}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { BoundWitness } from '@xyo-network/boundwitness-model';
|
|
2
|
-
import { PayloadValidator } from '@xyo-network/payload-validator';
|
|
3
|
-
export declare class BoundWitnessValidator<T extends BoundWitness<{
|
|
4
|
-
schema: string;
|
|
5
|
-
}> = BoundWitness> extends PayloadValidator<T> {
|
|
6
|
-
protected get expectedSchema(): string;
|
|
7
|
-
static validateSignature(hash: ArrayBuffer, address: ArrayBuffer, signature?: ArrayBuffer): Promise<Error[]>;
|
|
8
|
-
addresses(): Error[];
|
|
9
|
-
addressesUniqueness(): Error[];
|
|
10
|
-
previousHashes(): Error[];
|
|
11
|
-
schema(): Error[];
|
|
12
|
-
schemas(): Error[];
|
|
13
|
-
signatures(): Promise<Error[]>;
|
|
14
|
-
validate(): Promise<Error[]>;
|
|
15
|
-
validateArrayLengths(): Error[];
|
|
16
|
-
validatePayloadHashesLength(): Error[];
|
|
17
|
-
private validateArrayLength;
|
|
18
|
-
}
|
|
19
|
-
//# sourceMappingURL=Validator.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Validator.d.ts","sourceRoot":"","sources":["../../src/Validator.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,YAAY,EAAsB,MAAM,iCAAiC,CAAA;AAElF,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAA;AAMjE,qBAAa,qBAAqB,CAAC,CAAC,SAAS,YAAY,CAAC;IAAE,MAAM,EAAE,MAAM,CAAA;CAAE,CAAC,GAAG,YAAY,CAAE,SAAQ,gBAAgB,CAAC,CAAC,CAAC;IACvH,SAAS,KAAK,cAAc,IAAI,MAAM,CAErC;WAEY,iBAAiB,CAAC,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,WAAW,EAAE,SAAS,CAAC,EAAE,WAAW,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;IAUlH,SAAS,IAAI,KAAK,EAAE;IAQpB,mBAAmB,IAAI,KAAK,EAAE;IAQ9B,cAAc;IAKd,MAAM,IAAI,KAAK,EAAE;IAQjB,OAAO,IAAI,KAAK,EAAE;IAgBZ,UAAU,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;IAiBrB,QAAQ;IAYvB,oBAAoB,IAAI,KAAK,EAAE;IAM/B,2BAA2B,IAAI,KAAK,EAAE;IAMtC,OAAO,CAAC,mBAAmB;CAY5B"}
|
package/dist/node/Validator.d.ts
DELETED
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import { BoundWitness } from '@xyo-network/boundwitness-model';
|
|
2
|
-
import { PayloadValidator } from '@xyo-network/payload-validator';
|
|
3
|
-
export declare class BoundWitnessValidator<T extends BoundWitness<{
|
|
4
|
-
schema: string;
|
|
5
|
-
}> = BoundWitness> extends PayloadValidator<T> {
|
|
6
|
-
protected get expectedSchema(): string;
|
|
7
|
-
static validateSignature(hash: ArrayBuffer, address: ArrayBuffer, signature?: ArrayBuffer): Promise<Error[]>;
|
|
8
|
-
addresses(): Error[];
|
|
9
|
-
addressesUniqueness(): Error[];
|
|
10
|
-
previousHashes(): Error[];
|
|
11
|
-
schema(): Error[];
|
|
12
|
-
schemas(): Error[];
|
|
13
|
-
signatures(): Promise<Error[]>;
|
|
14
|
-
validate(): Promise<Error[]>;
|
|
15
|
-
validateArrayLengths(): Error[];
|
|
16
|
-
validatePayloadHashesLength(): Error[];
|
|
17
|
-
private validateArrayLength;
|
|
18
|
-
}
|
|
19
|
-
//# sourceMappingURL=Validator.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Validator.d.ts","sourceRoot":"","sources":["../../src/Validator.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,YAAY,EAAsB,MAAM,iCAAiC,CAAA;AAElF,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAA;AAMjE,qBAAa,qBAAqB,CAAC,CAAC,SAAS,YAAY,CAAC;IAAE,MAAM,EAAE,MAAM,CAAA;CAAE,CAAC,GAAG,YAAY,CAAE,SAAQ,gBAAgB,CAAC,CAAC,CAAC;IACvH,SAAS,KAAK,cAAc,IAAI,MAAM,CAErC;WAEY,iBAAiB,CAAC,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,WAAW,EAAE,SAAS,CAAC,EAAE,WAAW,GAAG,OAAO,CAAC,KAAK,EAAE,CAAC;IAUlH,SAAS,IAAI,KAAK,EAAE;IAQpB,mBAAmB,IAAI,KAAK,EAAE;IAQ9B,cAAc;IAKd,MAAM,IAAI,KAAK,EAAE;IAQjB,OAAO,IAAI,KAAK,EAAE;IAgBZ,UAAU,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;IAiBrB,QAAQ;IAYvB,oBAAoB,IAAI,KAAK,EAAE;IAM/B,2BAA2B,IAAI,KAAK,EAAE;IAMtC,OAAO,CAAC,mBAAmB;CAY5B"}
|
package/dist/node/index.cjs
DELETED
|
@@ -1,143 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __defProp = Object.defineProperty;
|
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
-
var __export = (target, all) => {
|
|
7
|
-
for (var name in all)
|
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
-
};
|
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
-
for (let key of __getOwnPropNames(from))
|
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
-
}
|
|
16
|
-
return to;
|
|
17
|
-
};
|
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
-
|
|
20
|
-
// src/index.ts
|
|
21
|
-
var src_exports = {};
|
|
22
|
-
__export(src_exports, {
|
|
23
|
-
BoundWitnessValidator: () => BoundWitnessValidator
|
|
24
|
-
});
|
|
25
|
-
module.exports = __toCommonJS(src_exports);
|
|
26
|
-
|
|
27
|
-
// src/Validator.ts
|
|
28
|
-
var import_arraybuffer = require("@xylabs/arraybuffer");
|
|
29
|
-
var import_lodash = require("@xylabs/lodash");
|
|
30
|
-
var import_typeof = require("@xylabs/typeof");
|
|
31
|
-
var import_account = require("@xyo-network/account");
|
|
32
|
-
var import_boundwitness_model = require("@xyo-network/boundwitness-model");
|
|
33
|
-
var import_payload = require("@xyo-network/payload");
|
|
34
|
-
var import_payload_validator = require("@xyo-network/payload-validator");
|
|
35
|
-
var validateArraysSameLength = (a, b, message = "Array length mismatch") => {
|
|
36
|
-
return a.length == b.length ? [] : [new Error(`${message} []`)];
|
|
37
|
-
};
|
|
38
|
-
var BoundWitnessValidator = class _BoundWitnessValidator extends import_payload_validator.PayloadValidator {
|
|
39
|
-
get expectedSchema() {
|
|
40
|
-
return import_boundwitness_model.BoundWitnessSchema;
|
|
41
|
-
}
|
|
42
|
-
static async validateSignature(hash, address, signature) {
|
|
43
|
-
if (!signature) {
|
|
44
|
-
return [new Error(`Missing signature [${address}]`)];
|
|
45
|
-
}
|
|
46
|
-
if (!await import_account.Elliptic.verify(hash, signature, address)) {
|
|
47
|
-
return [new Error(`Invalid signature [${address}]`)];
|
|
48
|
-
}
|
|
49
|
-
return [];
|
|
50
|
-
}
|
|
51
|
-
addresses() {
|
|
52
|
-
const errors = [];
|
|
53
|
-
errors.push(...this.addressesUniqueness());
|
|
54
|
-
return errors;
|
|
55
|
-
}
|
|
56
|
-
addressesUniqueness() {
|
|
57
|
-
const errors = [];
|
|
58
|
-
const { addresses } = this.obj;
|
|
59
|
-
const uniqAddresses = (0, import_lodash.uniq)(addresses);
|
|
60
|
-
if ((addresses == null ? void 0 : addresses.length) !== (uniqAddresses == null ? void 0 : uniqAddresses.length)) errors.push(new Error("addresses must be unique"));
|
|
61
|
-
return errors;
|
|
62
|
-
}
|
|
63
|
-
previousHashes() {
|
|
64
|
-
const errors = [];
|
|
65
|
-
return errors;
|
|
66
|
-
}
|
|
67
|
-
schema() {
|
|
68
|
-
const errors = [];
|
|
69
|
-
if (this.obj.schema !== this.expectedSchema) {
|
|
70
|
-
errors.push(new Error(`invalid schema [${this.expectedSchema} !== ${this.obj.schema}]`));
|
|
71
|
-
}
|
|
72
|
-
return errors;
|
|
73
|
-
}
|
|
74
|
-
schemas() {
|
|
75
|
-
const errors = [];
|
|
76
|
-
const Schemas = this.obj.payload_schemas;
|
|
77
|
-
if (Schemas) {
|
|
78
|
-
const schemaValidators = Schemas.map((schema) => {
|
|
79
|
-
var _a, _b;
|
|
80
|
-
return (_b = (_a = import_payload_validator.PayloadValidator).schemaNameValidatorFactory) == null ? void 0 : _b.call(_a, schema);
|
|
81
|
-
});
|
|
82
|
-
for (const validator of schemaValidators) {
|
|
83
|
-
if (validator) {
|
|
84
|
-
errors.push(...validator.all());
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
return errors;
|
|
89
|
-
}
|
|
90
|
-
async signatures() {
|
|
91
|
-
var _a, _b;
|
|
92
|
-
return [
|
|
93
|
-
...validateArraysSameLength(((_a = this.obj.$meta) == null ? void 0 : _a.signatures) ?? [], this.obj.addresses ?? [], "Length mismatch: address/signature"),
|
|
94
|
-
...(await Promise.all(
|
|
95
|
-
((_b = this.obj.addresses) == null ? void 0 : _b.map(
|
|
96
|
-
async (address, index) => {
|
|
97
|
-
var _a2, _b2;
|
|
98
|
-
return _BoundWitnessValidator.validateSignature(
|
|
99
|
-
(0, import_arraybuffer.toUint8Array)(await import_payload.PayloadBuilder.dataHash(this.payload)),
|
|
100
|
-
(0, import_arraybuffer.toUint8Array)(address),
|
|
101
|
-
(0, import_arraybuffer.toUint8Array)((_b2 = (_a2 = this.obj.$meta) == null ? void 0 : _a2.signatures) == null ? void 0 : _b2[index])
|
|
102
|
-
);
|
|
103
|
-
}
|
|
104
|
-
)) ?? []
|
|
105
|
-
)).flat()
|
|
106
|
-
];
|
|
107
|
-
}
|
|
108
|
-
async validate() {
|
|
109
|
-
return [
|
|
110
|
-
...await this.signatures(),
|
|
111
|
-
...this.addresses(),
|
|
112
|
-
...this.validateArrayLengths(),
|
|
113
|
-
...this.schemas(),
|
|
114
|
-
...this.previousHashes(),
|
|
115
|
-
...this.schema(),
|
|
116
|
-
...await super.validate()
|
|
117
|
-
];
|
|
118
|
-
}
|
|
119
|
-
validateArrayLengths() {
|
|
120
|
-
const errors = [];
|
|
121
|
-
errors.push(...this.validatePayloadHashesLength());
|
|
122
|
-
return errors;
|
|
123
|
-
}
|
|
124
|
-
validatePayloadHashesLength() {
|
|
125
|
-
const errors = [];
|
|
126
|
-
errors.push(...this.validateArrayLength("payload_hashes", "payload_schemas"));
|
|
127
|
-
return errors;
|
|
128
|
-
}
|
|
129
|
-
validateArrayLength(fieldName, compareArrayName) {
|
|
130
|
-
const errors = [];
|
|
131
|
-
const [array, arrayErrors] = (0, import_typeof.validateType)("array", this.stringKeyObj[fieldName], true);
|
|
132
|
-
const [compareArray, compareArrayErrors] = (0, import_typeof.validateType)("array", this.stringKeyObj[compareArrayName], true);
|
|
133
|
-
if ((array == null ? void 0 : array.length) !== (compareArray == null ? void 0 : compareArray.length)) {
|
|
134
|
-
errors.push(new Error(`${fieldName}/${compareArrayName} count mismatch [${array == null ? void 0 : array.length} !== ${compareArray == null ? void 0 : compareArray.length}]`));
|
|
135
|
-
}
|
|
136
|
-
return [...arrayErrors, ...compareArrayErrors, ...errors];
|
|
137
|
-
}
|
|
138
|
-
};
|
|
139
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
140
|
-
0 && (module.exports = {
|
|
141
|
-
BoundWitnessValidator
|
|
142
|
-
});
|
|
143
|
-
//# sourceMappingURL=index.cjs.map
|
package/dist/node/index.cjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/Validator.ts"],"sourcesContent":["export * from './Validator.ts'\n","import { toUint8Array } from '@xylabs/arraybuffer'\nimport { uniq } from '@xylabs/lodash'\nimport { validateType } from '@xylabs/typeof'\nimport { Elliptic } from '@xyo-network/account'\nimport { BoundWitness, BoundWitnessSchema } from '@xyo-network/boundwitness-model'\nimport { PayloadBuilder } from '@xyo-network/payload'\nimport { PayloadValidator } from '@xyo-network/payload-validator'\n\nconst validateArraysSameLength = (a: unknown[], b: unknown[], message = 'Array length mismatch') => {\n return a.length == b.length ? [] : [new Error(`${message} []`)]\n}\n\nexport class BoundWitnessValidator<T extends BoundWitness<{ schema: string }> = BoundWitness> extends PayloadValidator<T> {\n protected get expectedSchema(): string {\n return BoundWitnessSchema\n }\n\n static async validateSignature(hash: ArrayBuffer, address: ArrayBuffer, signature?: ArrayBuffer): Promise<Error[]> {\n if (!signature) {\n return [new Error(`Missing signature [${address}]`)]\n }\n if (!(await Elliptic.verify(hash, signature, address))) {\n return [new Error(`Invalid signature [${address}]`)]\n }\n return []\n }\n\n addresses(): Error[] {\n const errors: Error[] = []\n // const { addresses } = this.obj\n // if (!addresses?.length) errors.push(new Error('addresses missing [at least one address required]'))\n errors.push(...this.addressesUniqueness())\n return errors\n }\n\n addressesUniqueness(): Error[] {\n const errors: Error[] = []\n const { addresses } = this.obj\n const uniqAddresses = uniq(addresses)\n if (addresses?.length !== uniqAddresses?.length) errors.push(new Error('addresses must be unique'))\n return errors\n }\n\n previousHashes() {\n const errors: Error[] = []\n return errors\n }\n\n schema(): Error[] {\n const errors: Error[] = []\n if (this.obj.schema !== this.expectedSchema) {\n errors.push(new Error(`invalid schema [${this.expectedSchema} !== ${this.obj.schema}]`))\n }\n return errors\n }\n\n schemas(): Error[] {\n const errors: Error[] = []\n const Schemas = this.obj.payload_schemas\n if (Schemas) {\n const schemaValidators = Schemas.map((schema: string) => {\n return PayloadValidator.schemaNameValidatorFactory?.(schema)\n })\n for (const validator of schemaValidators) {\n if (validator) {\n errors.push(...validator.all())\n }\n }\n }\n return errors\n }\n\n async signatures(): Promise<Error[]> {\n return [\n ...validateArraysSameLength(this.obj.$meta?.signatures ?? [], this.obj.addresses ?? [], 'Length mismatch: address/signature'),\n ...(\n await Promise.all(\n this.obj.addresses?.map<Promise<Error[]>>(async (address, index) =>\n BoundWitnessValidator.validateSignature(\n toUint8Array(await PayloadBuilder.dataHash(this.payload)),\n toUint8Array(address),\n toUint8Array(this.obj.$meta?.signatures?.[index]),\n ),\n ) ?? [],\n )\n ).flat(),\n ]\n }\n\n override async validate() {\n return [\n ...(await this.signatures()),\n ...this.addresses(),\n ...this.validateArrayLengths(),\n ...this.schemas(),\n ...this.previousHashes(),\n ...this.schema(),\n ...(await super.validate()),\n ]\n }\n\n validateArrayLengths(): Error[] {\n const errors: Error[] = []\n errors.push(...this.validatePayloadHashesLength())\n return errors\n }\n\n validatePayloadHashesLength(): Error[] {\n const errors: Error[] = []\n errors.push(...this.validateArrayLength('payload_hashes', 'payload_schemas'))\n return errors\n }\n\n private validateArrayLength(fieldName: string, compareArrayName: string): Error[] {\n const errors: Error[] = []\n\n const [array, arrayErrors] = validateType('array', this.stringKeyObj[fieldName] as [], true)\n const [compareArray, compareArrayErrors] = validateType('array', this.stringKeyObj[compareArrayName] as [], true)\n\n if (array?.length !== compareArray?.length) {\n errors.push(new Error(`${fieldName}/${compareArrayName} count mismatch [${array?.length} !== ${compareArray?.length}]`))\n }\n\n return [...arrayErrors, ...compareArrayErrors, ...errors]\n }\n}\n"],"mappings":"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","names":["_a","_b"]}
|
package/dist/node/index.d.cts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAA"}
|
package/dist/node/index.d.mts
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAA"}
|
package/dist/node/index.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAA"}
|