@xyo-network/core 2.20.17
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +165 -0
- package/README.md +79 -0
- package/babel.config.json +5 -0
- package/dist/cjs/BoundWitness/Builder/Builder.d.ts +22 -0
- package/dist/cjs/BoundWitness/Builder/Builder.js +68 -0
- package/dist/cjs/BoundWitness/Builder/Builder.js.map +1 -0
- package/dist/cjs/BoundWitness/Builder/index.d.ts +1 -0
- package/dist/cjs/BoundWitness/Builder/index.js +5 -0
- package/dist/cjs/BoundWitness/Builder/index.js.map +1 -0
- package/dist/cjs/BoundWitness/Validator/BodyValidator.d.ts +18 -0
- package/dist/cjs/BoundWitness/Validator/BodyValidator.js +91 -0
- package/dist/cjs/BoundWitness/Validator/BodyValidator.js.map +1 -0
- package/dist/cjs/BoundWitness/Validator/MetaValidator.d.ts +14 -0
- package/dist/cjs/BoundWitness/Validator/MetaValidator.js +70 -0
- package/dist/cjs/BoundWitness/Validator/MetaValidator.js.map +1 -0
- package/dist/cjs/BoundWitness/Validator/Validator.d.ts +12 -0
- package/dist/cjs/BoundWitness/Validator/Validator.js +46 -0
- package/dist/cjs/BoundWitness/Validator/Validator.js.map +1 -0
- package/dist/cjs/BoundWitness/Validator/index.d.ts +3 -0
- package/dist/cjs/BoundWitness/Validator/index.js +7 -0
- package/dist/cjs/BoundWitness/Validator/index.js.map +1 -0
- package/dist/cjs/BoundWitness/Validator/ip-regex.d.ts +9 -0
- package/dist/cjs/BoundWitness/Validator/ip-regex.js +31 -0
- package/dist/cjs/BoundWitness/Validator/ip-regex.js.map +1 -0
- package/dist/cjs/BoundWitness/Validator/is-ip.d.ts +4 -0
- package/dist/cjs/BoundWitness/Validator/is-ip.js +21 -0
- package/dist/cjs/BoundWitness/Validator/is-ip.js.map +1 -0
- package/dist/cjs/BoundWitness/Wrapper/Wrapper.d.ts +13 -0
- package/dist/cjs/BoundWitness/Wrapper/Wrapper.js +30 -0
- package/dist/cjs/BoundWitness/Wrapper/Wrapper.js.map +1 -0
- package/dist/cjs/BoundWitness/Wrapper/index.d.ts +1 -0
- package/dist/cjs/BoundWitness/Wrapper/index.js +5 -0
- package/dist/cjs/BoundWitness/Wrapper/index.js.map +1 -0
- package/dist/cjs/BoundWitness/index.d.ts +4 -0
- package/dist/cjs/BoundWitness/index.js +8 -0
- package/dist/cjs/BoundWitness/index.js.map +1 -0
- package/dist/cjs/BoundWitness/models/Body/XyoBoundWitnessBody.d.ts +11 -0
- package/dist/cjs/BoundWitness/models/Body/XyoBoundWitnessBody.js +3 -0
- package/dist/cjs/BoundWitness/models/Body/XyoBoundWitnessBody.js.map +1 -0
- package/dist/cjs/BoundWitness/models/Body/XyoBoundWitnessBodySchema.d.ts +37 -0
- package/dist/cjs/BoundWitness/models/Body/XyoBoundWitnessBodySchema.js +20 -0
- package/dist/cjs/BoundWitness/models/Body/XyoBoundWitnessBodySchema.js.map +1 -0
- package/dist/cjs/BoundWitness/models/Body/index.d.ts +2 -0
- package/dist/cjs/BoundWitness/models/Body/index.js +6 -0
- package/dist/cjs/BoundWitness/models/Body/index.js.map +1 -0
- package/dist/cjs/BoundWitness/models/Meta/XyoBoundWitnessMeta.d.ts +13 -0
- package/dist/cjs/BoundWitness/models/Meta/XyoBoundWitnessMeta.js +3 -0
- package/dist/cjs/BoundWitness/models/Meta/XyoBoundWitnessMeta.js.map +1 -0
- package/dist/cjs/BoundWitness/models/Meta/XyoBoundWitnessMetaSchema.d.ts +85 -0
- package/dist/cjs/BoundWitness/models/Meta/XyoBoundWitnessMetaSchema.js +28 -0
- package/dist/cjs/BoundWitness/models/Meta/XyoBoundWitnessMetaSchema.js.map +1 -0
- package/dist/cjs/BoundWitness/models/Meta/index.d.ts +2 -0
- package/dist/cjs/BoundWitness/models/Meta/index.js +6 -0
- package/dist/cjs/BoundWitness/models/Meta/index.js.map +1 -0
- package/dist/cjs/BoundWitness/models/WithXyoBoundWitnessMeta.d.ts +4 -0
- package/dist/cjs/BoundWitness/models/WithXyoBoundWitnessMeta.js +3 -0
- package/dist/cjs/BoundWitness/models/WithXyoBoundWitnessMeta.js.map +1 -0
- package/dist/cjs/BoundWitness/models/XyoBoundWitness.d.ts +5 -0
- package/dist/cjs/BoundWitness/models/XyoBoundWitness.js +3 -0
- package/dist/cjs/BoundWitness/models/XyoBoundWitness.js.map +1 -0
- package/dist/cjs/BoundWitness/models/XyoBoundWitnessSchema.d.ts +75 -0
- package/dist/cjs/BoundWitness/models/XyoBoundWitnessSchema.js +17 -0
- package/dist/cjs/BoundWitness/models/XyoBoundWitnessSchema.js.map +1 -0
- package/dist/cjs/BoundWitness/models/index.d.ts +5 -0
- package/dist/cjs/BoundWitness/models/index.js +9 -0
- package/dist/cjs/BoundWitness/models/index.js.map +1 -0
- package/dist/cjs/Hasher/XyoHasher.d.ts +8 -0
- package/dist/cjs/Hasher/XyoHasher.js +29 -0
- package/dist/cjs/Hasher/XyoHasher.js.map +1 -0
- package/dist/cjs/Hasher/index.d.ts +4 -0
- package/dist/cjs/Hasher/index.js +8 -0
- package/dist/cjs/Hasher/index.js.map +1 -0
- package/dist/cjs/Hasher/removeEmptyFields.d.ts +1 -0
- package/dist/cjs/Hasher/removeEmptyFields.js +20 -0
- package/dist/cjs/Hasher/removeEmptyFields.js.map +1 -0
- package/dist/cjs/Hasher/removeFields.d.ts +6 -0
- package/dist/cjs/Hasher/removeFields.js +29 -0
- package/dist/cjs/Hasher/removeFields.js.map +1 -0
- package/dist/cjs/Hasher/sortFields.d.ts +1 -0
- package/dist/cjs/Hasher/sortFields.js +27 -0
- package/dist/cjs/Hasher/sortFields.js.map +1 -0
- package/dist/cjs/Huri/Huri.d.ts +26 -0
- package/dist/cjs/Huri/Huri.js +101 -0
- package/dist/cjs/Huri/Huri.js.map +1 -0
- package/dist/cjs/Huri/index.d.ts +1 -0
- package/dist/cjs/Huri/index.js +5 -0
- package/dist/cjs/Huri/index.js.map +1 -0
- package/dist/cjs/Payload/Builder/Builder.d.ts +14 -0
- package/dist/cjs/Payload/Builder/Builder.js +31 -0
- package/dist/cjs/Payload/Builder/Builder.js.map +1 -0
- package/dist/cjs/Payload/Builder/index.d.ts +1 -0
- package/dist/cjs/Payload/Builder/index.js +5 -0
- package/dist/cjs/Payload/Builder/index.js.map +1 -0
- package/dist/cjs/Payload/Validator/BodyValidator.d.ts +11 -0
- package/dist/cjs/Payload/Validator/BodyValidator.js +31 -0
- package/dist/cjs/Payload/Validator/BodyValidator.js.map +1 -0
- package/dist/cjs/Payload/Validator/MetaValidator.d.ts +9 -0
- package/dist/cjs/Payload/Validator/MetaValidator.js +37 -0
- package/dist/cjs/Payload/Validator/MetaValidator.js.map +1 -0
- package/dist/cjs/Payload/Validator/Validator.d.ts +11 -0
- package/dist/cjs/Payload/Validator/Validator.js +19 -0
- package/dist/cjs/Payload/Validator/Validator.js.map +1 -0
- package/dist/cjs/Payload/Validator/index.d.ts +3 -0
- package/dist/cjs/Payload/Validator/index.js +7 -0
- package/dist/cjs/Payload/Validator/index.js.map +1 -0
- package/dist/cjs/Payload/Wrapper/Validator.d.ts +9 -0
- package/dist/cjs/Payload/Wrapper/Validator.js +19 -0
- package/dist/cjs/Payload/Wrapper/Validator.js.map +1 -0
- package/dist/cjs/Payload/Wrapper/Wrapper.d.ts +9 -0
- package/dist/cjs/Payload/Wrapper/Wrapper.js +18 -0
- package/dist/cjs/Payload/Wrapper/Wrapper.js.map +1 -0
- package/dist/cjs/Payload/Wrapper/index.d.ts +2 -0
- package/dist/cjs/Payload/Wrapper/index.js +6 -0
- package/dist/cjs/Payload/Wrapper/index.js.map +1 -0
- package/dist/cjs/Payload/index.d.ts +4 -0
- package/dist/cjs/Payload/index.js +8 -0
- package/dist/cjs/Payload/index.js.map +1 -0
- package/dist/cjs/Payload/models/Body.d.ts +6 -0
- package/dist/cjs/Payload/models/Body.js +3 -0
- package/dist/cjs/Payload/models/Body.js.map +1 -0
- package/dist/cjs/Payload/models/Meta.d.ts +10 -0
- package/dist/cjs/Payload/models/Meta.js +3 -0
- package/dist/cjs/Payload/models/Meta.js.map +1 -0
- package/dist/cjs/Payload/models/WithXyoPayloadMeta.d.ts +4 -0
- package/dist/cjs/Payload/models/WithXyoPayloadMeta.js +3 -0
- package/dist/cjs/Payload/models/WithXyoPayloadMeta.js.map +1 -0
- package/dist/cjs/Payload/models/XyoPayload.d.ts +4 -0
- package/dist/cjs/Payload/models/XyoPayload.js +3 -0
- package/dist/cjs/Payload/models/XyoPayload.js.map +1 -0
- package/dist/cjs/Payload/models/index.d.ts +5 -0
- package/dist/cjs/Payload/models/index.js +3 -0
- package/dist/cjs/Payload/models/index.js.map +1 -0
- package/dist/cjs/Schema/Payload.d.ts +9 -0
- package/dist/cjs/Schema/Payload.js +3 -0
- package/dist/cjs/Schema/Payload.js.map +1 -0
- package/dist/cjs/Schema/index.d.ts +1 -0
- package/dist/cjs/Schema/index.js +5 -0
- package/dist/cjs/Schema/index.js.map +1 -0
- package/dist/cjs/SchemaNameValidator.d.ts +73 -0
- package/dist/cjs/SchemaNameValidator.js +135 -0
- package/dist/cjs/SchemaNameValidator.js.map +1 -0
- package/dist/cjs/Test/index.d.ts +2 -0
- package/dist/cjs/Test/index.js +6 -0
- package/dist/cjs/Test/index.js.map +1 -0
- package/dist/cjs/Test/testBoundWitness.d.ts +3 -0
- package/dist/cjs/Test/testBoundWitness.js +17 -0
- package/dist/cjs/Test/testBoundWitness.js.map +1 -0
- package/dist/cjs/Test/testPayload.d.ts +4 -0
- package/dist/cjs/Test/testPayload.js +19 -0
- package/dist/cjs/Test/testPayload.js.map +1 -0
- package/dist/cjs/Wallet/Account/Account.d.ts +36 -0
- package/dist/cjs/Wallet/Account/Account.js +79 -0
- package/dist/cjs/Wallet/Account/Account.js.map +1 -0
- package/dist/cjs/Wallet/Account/Key/Data/AbstractData.d.ts +12 -0
- package/dist/cjs/Wallet/Account/Key/Data/AbstractData.js +16 -0
- package/dist/cjs/Wallet/Account/Key/Data/AbstractData.js.map +1 -0
- package/dist/cjs/Wallet/Account/Key/Data/Data.d.ts +15 -0
- package/dist/cjs/Wallet/Account/Key/Data/Data.js +40 -0
- package/dist/cjs/Wallet/Account/Key/Data/Data.js.map +1 -0
- package/dist/cjs/Wallet/Account/Key/Data/XyoDataLike.d.ts +4 -0
- package/dist/cjs/Wallet/Account/Key/Data/XyoDataLike.js +3 -0
- package/dist/cjs/Wallet/Account/Key/Data/XyoDataLike.js.map +1 -0
- package/dist/cjs/Wallet/Account/Key/Data/index.d.ts +4 -0
- package/dist/cjs/Wallet/Account/Key/Data/index.js +8 -0
- package/dist/cjs/Wallet/Account/Key/Data/index.js.map +1 -0
- package/dist/cjs/Wallet/Account/Key/Data/toUint8Array.d.ts +3 -0
- package/dist/cjs/Wallet/Account/Key/Data/toUint8Array.js +33 -0
- package/dist/cjs/Wallet/Account/Key/Data/toUint8Array.js.map +1 -0
- package/dist/cjs/Wallet/Account/Key/XyoAddressValue.d.ts +11 -0
- package/dist/cjs/Wallet/Account/Key/XyoAddressValue.js +49 -0
- package/dist/cjs/Wallet/Account/Key/XyoAddressValue.js.map +1 -0
- package/dist/cjs/Wallet/Account/Key/XyoEllipticKey.d.ts +5 -0
- package/dist/cjs/Wallet/Account/Key/XyoEllipticKey.js +13 -0
- package/dist/cjs/Wallet/Account/Key/XyoEllipticKey.js.map +1 -0
- package/dist/cjs/Wallet/Account/Key/XyoKeyPair.d.ts +10 -0
- package/dist/cjs/Wallet/Account/Key/XyoKeyPair.js +23 -0
- package/dist/cjs/Wallet/Account/Key/XyoKeyPair.js.map +1 -0
- package/dist/cjs/Wallet/Account/Key/XyoPrivateKey.d.ts +14 -0
- package/dist/cjs/Wallet/Account/Key/XyoPrivateKey.js +56 -0
- package/dist/cjs/Wallet/Account/Key/XyoPrivateKey.js.map +1 -0
- package/dist/cjs/Wallet/Account/Key/XyoPublicKey.d.ts +10 -0
- package/dist/cjs/Wallet/Account/Key/XyoPublicKey.js +22 -0
- package/dist/cjs/Wallet/Account/Key/XyoPublicKey.js.map +1 -0
- package/dist/cjs/Wallet/Account/Key/index.d.ts +5 -0
- package/dist/cjs/Wallet/Account/Key/index.js +9 -0
- package/dist/cjs/Wallet/Account/Key/index.js.map +1 -0
- package/dist/cjs/Wallet/Account/index.d.ts +2 -0
- package/dist/cjs/Wallet/Account/index.js +6 -0
- package/dist/cjs/Wallet/Account/index.js.map +1 -0
- package/dist/cjs/Wallet/Base/Base.d.ts +8 -0
- package/dist/cjs/Wallet/Base/Base.js +37 -0
- package/dist/cjs/Wallet/Base/Base.js.map +1 -0
- package/dist/cjs/Wallet/Base/Words.d.ts +2 -0
- package/dist/cjs/Wallet/Base/Words.js +2644 -0
- package/dist/cjs/Wallet/Base/Words.js.map +1 -0
- package/dist/cjs/Wallet/Base/WordsPayload.d.ts +4 -0
- package/dist/cjs/Wallet/Base/WordsPayload.js +3 -0
- package/dist/cjs/Wallet/Base/WordsPayload.js.map +1 -0
- package/dist/cjs/Wallet/Base/index.d.ts +1 -0
- package/dist/cjs/Wallet/Base/index.js +5 -0
- package/dist/cjs/Wallet/Base/index.js.map +1 -0
- package/dist/cjs/Wallet/index.d.ts +2 -0
- package/dist/cjs/Wallet/index.js +6 -0
- package/dist/cjs/Wallet/index.js.map +1 -0
- package/dist/cjs/Witness/Witness.d.ts +14 -0
- package/dist/cjs/Witness/Witness.js +24 -0
- package/dist/cjs/Witness/Witness.js.map +1 -0
- package/dist/cjs/Witness/index.d.ts +1 -0
- package/dist/cjs/Witness/index.js +5 -0
- package/dist/cjs/Witness/index.js.map +1 -0
- package/dist/cjs/browser/core/Wallet/Web.d.ts +5 -0
- package/dist/cjs/browser/core/Wallet/Web.js +15 -0
- package/dist/cjs/browser/core/Wallet/Web.js.map +1 -0
- package/dist/cjs/browser/core/Wallet/index.d.ts +1 -0
- package/dist/cjs/browser/core/Wallet/index.js +5 -0
- package/dist/cjs/browser/core/Wallet/index.js.map +1 -0
- package/dist/cjs/browser/core/index.d.ts +1 -0
- package/dist/cjs/browser/core/index.js +5 -0
- package/dist/cjs/browser/core/index.js.map +1 -0
- package/dist/cjs/browser/index.d.ts +1 -0
- package/dist/cjs/browser/index.js +5 -0
- package/dist/cjs/browser/index.js.map +1 -0
- package/dist/cjs/browserIndex.d.ts +2 -0
- package/dist/cjs/browserIndex.js +6 -0
- package/dist/cjs/browserIndex.js.map +1 -0
- package/dist/cjs/index.d.ts +2 -0
- package/dist/cjs/index.js +6 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/lib/dns/DnsRecordType.d.ts +14 -0
- package/dist/cjs/lib/dns/DnsRecordType.js +19 -0
- package/dist/cjs/lib/dns/DnsRecordType.js.map +1 -0
- package/dist/cjs/lib/dns/DnsReturnCode.d.ts +13 -0
- package/dist/cjs/lib/dns/DnsReturnCode.js +18 -0
- package/dist/cjs/lib/dns/DnsReturnCode.js.map +1 -0
- package/dist/cjs/lib/dns/GoogleDnsResult.d.ts +16 -0
- package/dist/cjs/lib/dns/GoogleDnsResult.js +3 -0
- package/dist/cjs/lib/dns/GoogleDnsResult.js.map +1 -0
- package/dist/cjs/lib/dns/GoogleDnsResultAnswer.d.ts +7 -0
- package/dist/cjs/lib/dns/GoogleDnsResultAnswer.js +3 -0
- package/dist/cjs/lib/dns/GoogleDnsResultAnswer.js.map +1 -0
- package/dist/cjs/lib/dns/GoogleDnsResultQuestion.d.ts +10 -0
- package/dist/cjs/lib/dns/GoogleDnsResultQuestion.js +3 -0
- package/dist/cjs/lib/dns/GoogleDnsResultQuestion.js.map +1 -0
- package/dist/cjs/lib/dns/domainExists.d.ts +7 -0
- package/dist/cjs/lib/dns/domainExists.js +19 -0
- package/dist/cjs/lib/dns/domainExists.js.map +1 -0
- package/dist/cjs/lib/dns/domainResolve.d.ts +8 -0
- package/dist/cjs/lib/dns/domainResolve.js +19 -0
- package/dist/cjs/lib/dns/domainResolve.js.map +1 -0
- package/dist/cjs/lib/dns/googleDnsOverHttps.d.ts +4 -0
- package/dist/cjs/lib/dns/googleDnsOverHttps.js +11 -0
- package/dist/cjs/lib/dns/googleDnsOverHttps.js.map +1 -0
- package/dist/cjs/lib/dns/index.d.ts +8 -0
- package/dist/cjs/lib/dns/index.js +12 -0
- package/dist/cjs/lib/dns/index.js.map +1 -0
- package/dist/cjs/lib/dumpErrors.d.ts +2 -0
- package/dist/cjs/lib/dumpErrors.js +10 -0
- package/dist/cjs/lib/dumpErrors.js.map +1 -0
- package/dist/cjs/lib/index.d.ts +4 -0
- package/dist/cjs/lib/index.js +8 -0
- package/dist/cjs/lib/index.js.map +1 -0
- package/dist/cjs/lib/isBrowser.d.ts +1 -0
- package/dist/cjs/lib/isBrowser.js +8 -0
- package/dist/cjs/lib/isBrowser.js.map +1 -0
- package/dist/cjs/lib/typeOf/TypeOfTypes.d.ts +1 -0
- package/dist/cjs/lib/typeOf/TypeOfTypes.js +3 -0
- package/dist/cjs/lib/typeOf/TypeOfTypes.js.map +1 -0
- package/dist/cjs/lib/typeOf/ifDefined.d.ts +1 -0
- package/dist/cjs/lib/typeOf/ifDefined.js +16 -0
- package/dist/cjs/lib/typeOf/ifDefined.js.map +1 -0
- package/dist/cjs/lib/typeOf/ifTypeOf.d.ts +2 -0
- package/dist/cjs/lib/typeOf/ifTypeOf.js +12 -0
- package/dist/cjs/lib/typeOf/ifTypeOf.js.map +1 -0
- package/dist/cjs/lib/typeOf/index.d.ts +5 -0
- package/dist/cjs/lib/typeOf/index.js +9 -0
- package/dist/cjs/lib/typeOf/index.js.map +1 -0
- package/dist/cjs/lib/typeOf/typeOf.d.ts +2 -0
- package/dist/cjs/lib/typeOf/typeOf.js +8 -0
- package/dist/cjs/lib/typeOf/typeOf.js.map +1 -0
- package/dist/cjs/lib/typeOf/validateType.d.ts +2 -0
- package/dist/cjs/lib/typeOf/validateType.js +18 -0
- package/dist/cjs/lib/typeOf/validateType.js.map +1 -0
- package/dist/cjs/models/WithStringIndex.d.ts +1 -0
- package/dist/cjs/models/WithStringIndex.js +3 -0
- package/dist/cjs/models/WithStringIndex.js.map +1 -0
- package/dist/cjs/models/index.d.ts +1 -0
- package/dist/cjs/models/index.js +5 -0
- package/dist/cjs/models/index.js.map +1 -0
- package/dist/cjs/nodeIndex.d.ts +1 -0
- package/dist/cjs/nodeIndex.js +5 -0
- package/dist/cjs/nodeIndex.js.map +1 -0
- package/dist/cjs/shared.d.ts +10 -0
- package/dist/cjs/shared.js +14 -0
- package/dist/cjs/shared.js.map +1 -0
- package/dist/docs.json +21601 -0
- package/dist/esm/BoundWitness/Builder/Builder.d.ts +22 -0
- package/dist/esm/BoundWitness/Builder/Builder.js +66 -0
- package/dist/esm/BoundWitness/Builder/Builder.js.map +1 -0
- package/dist/esm/BoundWitness/Builder/index.d.ts +1 -0
- package/dist/esm/BoundWitness/Builder/index.js +2 -0
- package/dist/esm/BoundWitness/Builder/index.js.map +1 -0
- package/dist/esm/BoundWitness/Validator/BodyValidator.d.ts +18 -0
- package/dist/esm/BoundWitness/Validator/BodyValidator.js +86 -0
- package/dist/esm/BoundWitness/Validator/BodyValidator.js.map +1 -0
- package/dist/esm/BoundWitness/Validator/MetaValidator.d.ts +14 -0
- package/dist/esm/BoundWitness/Validator/MetaValidator.js +66 -0
- package/dist/esm/BoundWitness/Validator/MetaValidator.js.map +1 -0
- package/dist/esm/BoundWitness/Validator/Validator.d.ts +12 -0
- package/dist/esm/BoundWitness/Validator/Validator.js +41 -0
- package/dist/esm/BoundWitness/Validator/Validator.js.map +1 -0
- package/dist/esm/BoundWitness/Validator/index.d.ts +3 -0
- package/dist/esm/BoundWitness/Validator/index.js +4 -0
- package/dist/esm/BoundWitness/Validator/index.js.map +1 -0
- package/dist/esm/BoundWitness/Validator/ip-regex.d.ts +9 -0
- package/dist/esm/BoundWitness/Validator/ip-regex.js +27 -0
- package/dist/esm/BoundWitness/Validator/ip-regex.js.map +1 -0
- package/dist/esm/BoundWitness/Validator/is-ip.d.ts +4 -0
- package/dist/esm/BoundWitness/Validator/is-ip.js +14 -0
- package/dist/esm/BoundWitness/Validator/is-ip.js.map +1 -0
- package/dist/esm/BoundWitness/Wrapper/Wrapper.d.ts +13 -0
- package/dist/esm/BoundWitness/Wrapper/Wrapper.js +24 -0
- package/dist/esm/BoundWitness/Wrapper/Wrapper.js.map +1 -0
- package/dist/esm/BoundWitness/Wrapper/index.d.ts +1 -0
- package/dist/esm/BoundWitness/Wrapper/index.js +2 -0
- package/dist/esm/BoundWitness/Wrapper/index.js.map +1 -0
- package/dist/esm/BoundWitness/index.d.ts +4 -0
- package/dist/esm/BoundWitness/index.js +5 -0
- package/dist/esm/BoundWitness/index.js.map +1 -0
- package/dist/esm/BoundWitness/models/Body/XyoBoundWitnessBody.d.ts +11 -0
- package/dist/esm/BoundWitness/models/Body/XyoBoundWitnessBody.js +2 -0
- package/dist/esm/BoundWitness/models/Body/XyoBoundWitnessBody.js.map +1 -0
- package/dist/esm/BoundWitness/models/Body/XyoBoundWitnessBodySchema.d.ts +37 -0
- package/dist/esm/BoundWitness/models/Body/XyoBoundWitnessBodySchema.js +17 -0
- package/dist/esm/BoundWitness/models/Body/XyoBoundWitnessBodySchema.js.map +1 -0
- package/dist/esm/BoundWitness/models/Body/index.d.ts +2 -0
- package/dist/esm/BoundWitness/models/Body/index.js +3 -0
- package/dist/esm/BoundWitness/models/Body/index.js.map +1 -0
- package/dist/esm/BoundWitness/models/Meta/XyoBoundWitnessMeta.d.ts +13 -0
- package/dist/esm/BoundWitness/models/Meta/XyoBoundWitnessMeta.js +2 -0
- package/dist/esm/BoundWitness/models/Meta/XyoBoundWitnessMeta.js.map +1 -0
- package/dist/esm/BoundWitness/models/Meta/XyoBoundWitnessMetaSchema.d.ts +85 -0
- package/dist/esm/BoundWitness/models/Meta/XyoBoundWitnessMetaSchema.js +23 -0
- package/dist/esm/BoundWitness/models/Meta/XyoBoundWitnessMetaSchema.js.map +1 -0
- package/dist/esm/BoundWitness/models/Meta/index.d.ts +2 -0
- package/dist/esm/BoundWitness/models/Meta/index.js +3 -0
- package/dist/esm/BoundWitness/models/Meta/index.js.map +1 -0
- package/dist/esm/BoundWitness/models/WithXyoBoundWitnessMeta.d.ts +4 -0
- package/dist/esm/BoundWitness/models/WithXyoBoundWitnessMeta.js +2 -0
- package/dist/esm/BoundWitness/models/WithXyoBoundWitnessMeta.js.map +1 -0
- package/dist/esm/BoundWitness/models/XyoBoundWitness.d.ts +5 -0
- package/dist/esm/BoundWitness/models/XyoBoundWitness.js +2 -0
- package/dist/esm/BoundWitness/models/XyoBoundWitness.js.map +1 -0
- package/dist/esm/BoundWitness/models/XyoBoundWitnessSchema.d.ts +75 -0
- package/dist/esm/BoundWitness/models/XyoBoundWitnessSchema.js +21 -0
- package/dist/esm/BoundWitness/models/XyoBoundWitnessSchema.js.map +1 -0
- package/dist/esm/BoundWitness/models/index.d.ts +5 -0
- package/dist/esm/BoundWitness/models/index.js +6 -0
- package/dist/esm/BoundWitness/models/index.js.map +1 -0
- package/dist/esm/Hasher/XyoHasher.d.ts +8 -0
- package/dist/esm/Hasher/XyoHasher.js +24 -0
- package/dist/esm/Hasher/XyoHasher.js.map +1 -0
- package/dist/esm/Hasher/index.d.ts +4 -0
- package/dist/esm/Hasher/index.js +5 -0
- package/dist/esm/Hasher/index.js.map +1 -0
- package/dist/esm/Hasher/removeEmptyFields.d.ts +1 -0
- package/dist/esm/Hasher/removeEmptyFields.js +16 -0
- package/dist/esm/Hasher/removeEmptyFields.js.map +1 -0
- package/dist/esm/Hasher/removeFields.d.ts +6 -0
- package/dist/esm/Hasher/removeFields.js +22 -0
- package/dist/esm/Hasher/removeFields.js.map +1 -0
- package/dist/esm/Hasher/sortFields.d.ts +1 -0
- package/dist/esm/Hasher/sortFields.js +23 -0
- package/dist/esm/Hasher/sortFields.js.map +1 -0
- package/dist/esm/Huri/Huri.d.ts +26 -0
- package/dist/esm/Huri/Huri.js +90 -0
- package/dist/esm/Huri/Huri.js.map +1 -0
- package/dist/esm/Huri/index.d.ts +1 -0
- package/dist/esm/Huri/index.js +2 -0
- package/dist/esm/Huri/index.js.map +1 -0
- package/dist/esm/Payload/Builder/Builder.d.ts +14 -0
- package/dist/esm/Payload/Builder/Builder.js +30 -0
- package/dist/esm/Payload/Builder/Builder.js.map +1 -0
- package/dist/esm/Payload/Builder/index.d.ts +1 -0
- package/dist/esm/Payload/Builder/index.js +2 -0
- package/dist/esm/Payload/Builder/index.js.map +1 -0
- package/dist/esm/Payload/Validator/BodyValidator.d.ts +11 -0
- package/dist/esm/Payload/Validator/BodyValidator.js +27 -0
- package/dist/esm/Payload/Validator/BodyValidator.js.map +1 -0
- package/dist/esm/Payload/Validator/MetaValidator.d.ts +9 -0
- package/dist/esm/Payload/Validator/MetaValidator.js +34 -0
- package/dist/esm/Payload/Validator/MetaValidator.js.map +1 -0
- package/dist/esm/Payload/Validator/Validator.d.ts +11 -0
- package/dist/esm/Payload/Validator/Validator.js +16 -0
- package/dist/esm/Payload/Validator/Validator.js.map +1 -0
- package/dist/esm/Payload/Validator/index.d.ts +3 -0
- package/dist/esm/Payload/Validator/index.js +4 -0
- package/dist/esm/Payload/Validator/index.js.map +1 -0
- package/dist/esm/Payload/Wrapper/Validator.d.ts +9 -0
- package/dist/esm/Payload/Wrapper/Validator.js +15 -0
- package/dist/esm/Payload/Wrapper/Validator.js.map +1 -0
- package/dist/esm/Payload/Wrapper/Wrapper.d.ts +9 -0
- package/dist/esm/Payload/Wrapper/Wrapper.js +15 -0
- package/dist/esm/Payload/Wrapper/Wrapper.js.map +1 -0
- package/dist/esm/Payload/Wrapper/index.d.ts +2 -0
- package/dist/esm/Payload/Wrapper/index.js +3 -0
- package/dist/esm/Payload/Wrapper/index.js.map +1 -0
- package/dist/esm/Payload/index.d.ts +4 -0
- package/dist/esm/Payload/index.js +5 -0
- package/dist/esm/Payload/index.js.map +1 -0
- package/dist/esm/Payload/models/Body.d.ts +6 -0
- package/dist/esm/Payload/models/Body.js +2 -0
- package/dist/esm/Payload/models/Body.js.map +1 -0
- package/dist/esm/Payload/models/Meta.d.ts +10 -0
- package/dist/esm/Payload/models/Meta.js +2 -0
- package/dist/esm/Payload/models/Meta.js.map +1 -0
- package/dist/esm/Payload/models/WithXyoPayloadMeta.d.ts +4 -0
- package/dist/esm/Payload/models/WithXyoPayloadMeta.js +2 -0
- package/dist/esm/Payload/models/WithXyoPayloadMeta.js.map +1 -0
- package/dist/esm/Payload/models/XyoPayload.d.ts +4 -0
- package/dist/esm/Payload/models/XyoPayload.js +2 -0
- package/dist/esm/Payload/models/XyoPayload.js.map +1 -0
- package/dist/esm/Payload/models/index.d.ts +5 -0
- package/dist/esm/Payload/models/index.js +2 -0
- package/dist/esm/Payload/models/index.js.map +1 -0
- package/dist/esm/Schema/Payload.d.ts +9 -0
- package/dist/esm/Schema/Payload.js +2 -0
- package/dist/esm/Schema/Payload.js.map +1 -0
- package/dist/esm/Schema/index.d.ts +1 -0
- package/dist/esm/Schema/index.js +2 -0
- package/dist/esm/Schema/index.js.map +1 -0
- package/dist/esm/SchemaNameValidator.d.ts +73 -0
- package/dist/esm/SchemaNameValidator.js +117 -0
- package/dist/esm/SchemaNameValidator.js.map +1 -0
- package/dist/esm/Test/index.d.ts +2 -0
- package/dist/esm/Test/index.js +3 -0
- package/dist/esm/Test/index.js.map +1 -0
- package/dist/esm/Test/testBoundWitness.d.ts +3 -0
- package/dist/esm/Test/testBoundWitness.js +14 -0
- package/dist/esm/Test/testBoundWitness.js.map +1 -0
- package/dist/esm/Test/testPayload.d.ts +4 -0
- package/dist/esm/Test/testPayload.js +15 -0
- package/dist/esm/Test/testPayload.js.map +1 -0
- package/dist/esm/Wallet/Account/Account.d.ts +36 -0
- package/dist/esm/Wallet/Account/Account.js +71 -0
- package/dist/esm/Wallet/Account/Account.js.map +1 -0
- package/dist/esm/Wallet/Account/Key/Data/AbstractData.d.ts +12 -0
- package/dist/esm/Wallet/Account/Key/Data/AbstractData.js +12 -0
- package/dist/esm/Wallet/Account/Key/Data/AbstractData.js.map +1 -0
- package/dist/esm/Wallet/Account/Key/Data/Data.d.ts +15 -0
- package/dist/esm/Wallet/Account/Key/Data/Data.js +35 -0
- package/dist/esm/Wallet/Account/Key/Data/Data.js.map +1 -0
- package/dist/esm/Wallet/Account/Key/Data/XyoDataLike.d.ts +4 -0
- package/dist/esm/Wallet/Account/Key/Data/XyoDataLike.js +2 -0
- package/dist/esm/Wallet/Account/Key/Data/XyoDataLike.js.map +1 -0
- package/dist/esm/Wallet/Account/Key/Data/index.d.ts +4 -0
- package/dist/esm/Wallet/Account/Key/Data/index.js +5 -0
- package/dist/esm/Wallet/Account/Key/Data/index.js.map +1 -0
- package/dist/esm/Wallet/Account/Key/Data/toUint8Array.d.ts +3 -0
- package/dist/esm/Wallet/Account/Key/Data/toUint8Array.js +31 -0
- package/dist/esm/Wallet/Account/Key/Data/toUint8Array.js.map +1 -0
- package/dist/esm/Wallet/Account/Key/XyoAddressValue.d.ts +11 -0
- package/dist/esm/Wallet/Account/Key/XyoAddressValue.js +45 -0
- package/dist/esm/Wallet/Account/Key/XyoAddressValue.js.map +1 -0
- package/dist/esm/Wallet/Account/Key/XyoEllipticKey.d.ts +5 -0
- package/dist/esm/Wallet/Account/Key/XyoEllipticKey.js +8 -0
- package/dist/esm/Wallet/Account/Key/XyoEllipticKey.js.map +1 -0
- package/dist/esm/Wallet/Account/Key/XyoKeyPair.d.ts +10 -0
- package/dist/esm/Wallet/Account/Key/XyoKeyPair.js +18 -0
- package/dist/esm/Wallet/Account/Key/XyoKeyPair.js.map +1 -0
- package/dist/esm/Wallet/Account/Key/XyoPrivateKey.d.ts +14 -0
- package/dist/esm/Wallet/Account/Key/XyoPrivateKey.js +50 -0
- package/dist/esm/Wallet/Account/Key/XyoPrivateKey.js.map +1 -0
- package/dist/esm/Wallet/Account/Key/XyoPublicKey.d.ts +10 -0
- package/dist/esm/Wallet/Account/Key/XyoPublicKey.js +18 -0
- package/dist/esm/Wallet/Account/Key/XyoPublicKey.js.map +1 -0
- package/dist/esm/Wallet/Account/Key/index.d.ts +5 -0
- package/dist/esm/Wallet/Account/Key/index.js +6 -0
- package/dist/esm/Wallet/Account/Key/index.js.map +1 -0
- package/dist/esm/Wallet/Account/index.d.ts +2 -0
- package/dist/esm/Wallet/Account/index.js +3 -0
- package/dist/esm/Wallet/Account/index.js.map +1 -0
- package/dist/esm/Wallet/Base/Base.d.ts +8 -0
- package/dist/esm/Wallet/Base/Base.js +30 -0
- package/dist/esm/Wallet/Base/Base.js.map +1 -0
- package/dist/esm/Wallet/Base/Words.d.ts +2 -0
- package/dist/esm/Wallet/Base/Words.js +2641 -0
- package/dist/esm/Wallet/Base/Words.js.map +1 -0
- package/dist/esm/Wallet/Base/WordsPayload.d.ts +4 -0
- package/dist/esm/Wallet/Base/WordsPayload.js +2 -0
- package/dist/esm/Wallet/Base/WordsPayload.js.map +1 -0
- package/dist/esm/Wallet/Base/index.d.ts +1 -0
- package/dist/esm/Wallet/Base/index.js +2 -0
- package/dist/esm/Wallet/Base/index.js.map +1 -0
- package/dist/esm/Wallet/index.d.ts +2 -0
- package/dist/esm/Wallet/index.js +3 -0
- package/dist/esm/Wallet/index.js.map +1 -0
- package/dist/esm/Witness/Witness.d.ts +14 -0
- package/dist/esm/Witness/Witness.js +16 -0
- package/dist/esm/Witness/Witness.js.map +1 -0
- package/dist/esm/Witness/index.d.ts +1 -0
- package/dist/esm/Witness/index.js +2 -0
- package/dist/esm/Witness/index.js.map +1 -0
- package/dist/esm/browser/core/Wallet/Web.d.ts +5 -0
- package/dist/esm/browser/core/Wallet/Web.js +11 -0
- package/dist/esm/browser/core/Wallet/Web.js.map +1 -0
- package/dist/esm/browser/core/Wallet/index.d.ts +1 -0
- package/dist/esm/browser/core/Wallet/index.js +2 -0
- package/dist/esm/browser/core/Wallet/index.js.map +1 -0
- package/dist/esm/browser/core/index.d.ts +1 -0
- package/dist/esm/browser/core/index.js +2 -0
- package/dist/esm/browser/core/index.js.map +1 -0
- package/dist/esm/browser/index.d.ts +1 -0
- package/dist/esm/browser/index.js +2 -0
- package/dist/esm/browser/index.js.map +1 -0
- package/dist/esm/browserIndex.d.ts +2 -0
- package/dist/esm/browserIndex.js +3 -0
- package/dist/esm/browserIndex.js.map +1 -0
- package/dist/esm/index.d.ts +2 -0
- package/dist/esm/index.js +3 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/lib/dns/DnsRecordType.d.ts +14 -0
- package/dist/esm/lib/dns/DnsRecordType.js +16 -0
- package/dist/esm/lib/dns/DnsRecordType.js.map +1 -0
- package/dist/esm/lib/dns/DnsReturnCode.d.ts +13 -0
- package/dist/esm/lib/dns/DnsReturnCode.js +15 -0
- package/dist/esm/lib/dns/DnsReturnCode.js.map +1 -0
- package/dist/esm/lib/dns/GoogleDnsResult.d.ts +16 -0
- package/dist/esm/lib/dns/GoogleDnsResult.js +2 -0
- package/dist/esm/lib/dns/GoogleDnsResult.js.map +1 -0
- package/dist/esm/lib/dns/GoogleDnsResultAnswer.d.ts +7 -0
- package/dist/esm/lib/dns/GoogleDnsResultAnswer.js +2 -0
- package/dist/esm/lib/dns/GoogleDnsResultAnswer.js.map +1 -0
- package/dist/esm/lib/dns/GoogleDnsResultQuestion.d.ts +10 -0
- package/dist/esm/lib/dns/GoogleDnsResultQuestion.js +2 -0
- package/dist/esm/lib/dns/GoogleDnsResultQuestion.js.map +1 -0
- package/dist/esm/lib/dns/domainExists.d.ts +7 -0
- package/dist/esm/lib/dns/domainExists.js +15 -0
- package/dist/esm/lib/dns/domainExists.js.map +1 -0
- package/dist/esm/lib/dns/domainResolve.d.ts +8 -0
- package/dist/esm/lib/dns/domainResolve.js +15 -0
- package/dist/esm/lib/dns/domainResolve.js.map +1 -0
- package/dist/esm/lib/dns/googleDnsOverHttps.d.ts +4 -0
- package/dist/esm/lib/dns/googleDnsOverHttps.js +7 -0
- package/dist/esm/lib/dns/googleDnsOverHttps.js.map +1 -0
- package/dist/esm/lib/dns/index.d.ts +8 -0
- package/dist/esm/lib/dns/index.js +9 -0
- package/dist/esm/lib/dns/index.js.map +1 -0
- package/dist/esm/lib/dumpErrors.d.ts +2 -0
- package/dist/esm/lib/dumpErrors.js +7 -0
- package/dist/esm/lib/dumpErrors.js.map +1 -0
- package/dist/esm/lib/index.d.ts +4 -0
- package/dist/esm/lib/index.js +5 -0
- package/dist/esm/lib/index.js.map +1 -0
- package/dist/esm/lib/isBrowser.d.ts +1 -0
- package/dist/esm/lib/isBrowser.js +4 -0
- package/dist/esm/lib/isBrowser.js.map +1 -0
- package/dist/esm/lib/typeOf/TypeOfTypes.d.ts +1 -0
- package/dist/esm/lib/typeOf/TypeOfTypes.js +2 -0
- package/dist/esm/lib/typeOf/TypeOfTypes.js.map +1 -0
- package/dist/esm/lib/typeOf/ifDefined.d.ts +1 -0
- package/dist/esm/lib/typeOf/ifDefined.js +12 -0
- package/dist/esm/lib/typeOf/ifDefined.js.map +1 -0
- package/dist/esm/lib/typeOf/ifTypeOf.d.ts +2 -0
- package/dist/esm/lib/typeOf/ifTypeOf.js +8 -0
- package/dist/esm/lib/typeOf/ifTypeOf.js.map +1 -0
- package/dist/esm/lib/typeOf/index.d.ts +5 -0
- package/dist/esm/lib/typeOf/index.js +6 -0
- package/dist/esm/lib/typeOf/index.js.map +1 -0
- package/dist/esm/lib/typeOf/typeOf.d.ts +2 -0
- package/dist/esm/lib/typeOf/typeOf.js +4 -0
- package/dist/esm/lib/typeOf/typeOf.js.map +1 -0
- package/dist/esm/lib/typeOf/validateType.d.ts +2 -0
- package/dist/esm/lib/typeOf/validateType.js +14 -0
- package/dist/esm/lib/typeOf/validateType.js.map +1 -0
- package/dist/esm/models/WithStringIndex.d.ts +1 -0
- package/dist/esm/models/WithStringIndex.js +2 -0
- package/dist/esm/models/WithStringIndex.js.map +1 -0
- package/dist/esm/models/index.d.ts +1 -0
- package/dist/esm/models/index.js +2 -0
- package/dist/esm/models/index.js.map +1 -0
- package/dist/esm/nodeIndex.d.ts +1 -0
- package/dist/esm/nodeIndex.js +2 -0
- package/dist/esm/nodeIndex.js.map +1 -0
- package/dist/esm/shared.d.ts +10 -0
- package/dist/esm/shared.js +11 -0
- package/dist/esm/shared.js.map +1 -0
- package/jest.config.cjs +25 -0
- package/package.json +117 -0
- package/rollup.config.js +5 -0
- package/src/BoundWitness/Builder/Builder.spec.ts +86 -0
- package/src/BoundWitness/Builder/Builder.ts +83 -0
- package/src/BoundWitness/Builder/index.ts +1 -0
- package/src/BoundWitness/Validator/BodyValidator.spec.ts +10 -0
- package/src/BoundWitness/Validator/BodyValidator.ts +104 -0
- package/src/BoundWitness/Validator/MetaValidator.spec.ts +55 -0
- package/src/BoundWitness/Validator/MetaValidator.ts +75 -0
- package/src/BoundWitness/Validator/Validator.spec.ts +10 -0
- package/src/BoundWitness/Validator/Validator.ts +51 -0
- package/src/BoundWitness/Validator/index.ts +3 -0
- package/src/BoundWitness/Validator/ip-regex.ts +39 -0
- package/src/BoundWitness/Validator/is-ip.ts +17 -0
- package/src/BoundWitness/Wrapper/Wrapper.ts +34 -0
- package/src/BoundWitness/Wrapper/index.ts +1 -0
- package/src/BoundWitness/index.ts +4 -0
- package/src/BoundWitness/models/Body/XyoBoundWitnessBody.ts +13 -0
- package/src/BoundWitness/models/Body/XyoBoundWitnessBodySchema.ts +17 -0
- package/src/BoundWitness/models/Body/index.ts +2 -0
- package/src/BoundWitness/models/Meta/XyoBoundWitnessMeta.ts +15 -0
- package/src/BoundWitness/models/Meta/XyoBoundWitnessMetaSchema.ts +24 -0
- package/src/BoundWitness/models/Meta/index.ts +2 -0
- package/src/BoundWitness/models/WithXyoBoundWitnessMeta.ts +6 -0
- package/src/BoundWitness/models/XyoBoundWitness.ts +7 -0
- package/src/BoundWitness/models/XyoBoundWitnessSchema.ts +23 -0
- package/src/BoundWitness/models/index.ts +5 -0
- package/src/Hasher/XyoHasher.ts +30 -0
- package/src/Hasher/index.ts +4 -0
- package/src/Hasher/removeEmptyFields.spec.ts +23 -0
- package/src/Hasher/removeEmptyFields.ts +15 -0
- package/src/Hasher/removeFields.ts +26 -0
- package/src/Hasher/sortFields.ts +24 -0
- package/src/Huri/Huri.spec.ts +93 -0
- package/src/Huri/Huri.ts +143 -0
- package/src/Huri/index.ts +1 -0
- package/src/Payload/Builder/Builder.spec.ts +37 -0
- package/src/Payload/Builder/Builder.ts +42 -0
- package/src/Payload/Builder/index.ts +1 -0
- package/src/Payload/Validator/BodyValidator.spec.ts +10 -0
- package/src/Payload/Validator/BodyValidator.ts +34 -0
- package/src/Payload/Validator/MetaValidator.spec.ts +10 -0
- package/src/Payload/Validator/MetaValidator.ts +38 -0
- package/src/Payload/Validator/Validator.spec.ts +62 -0
- package/src/Payload/Validator/Validator.ts +22 -0
- package/src/Payload/Validator/index.ts +3 -0
- package/src/Payload/Wrapper/Validator.ts +20 -0
- package/src/Payload/Wrapper/Wrapper.ts +20 -0
- package/src/Payload/Wrapper/index.ts +2 -0
- package/src/Payload/index.ts +4 -0
- package/src/Payload/models/Body.ts +7 -0
- package/src/Payload/models/Meta.ts +11 -0
- package/src/Payload/models/WithXyoPayloadMeta.ts +6 -0
- package/src/Payload/models/XyoPayload.ts +6 -0
- package/src/Payload/models/index.ts +6 -0
- package/src/Schema/Payload.ts +10 -0
- package/src/Schema/index.ts +1 -0
- package/src/SchemaNameValidator.ts +128 -0
- package/src/Test/index.ts +2 -0
- package/src/Test/testBoundWitness.ts +16 -0
- package/src/Test/testPayload.ts +17 -0
- package/src/Wallet/Account/Account.spec.ts +91 -0
- package/src/Wallet/Account/Account.ts +96 -0
- package/src/Wallet/Account/Key/Data/AbstractData.ts +22 -0
- package/src/Wallet/Account/Key/Data/Data.ts +45 -0
- package/src/Wallet/Account/Key/Data/XyoDataLike.ts +5 -0
- package/src/Wallet/Account/Key/Data/index.ts +4 -0
- package/src/Wallet/Account/Key/Data/toUint8Array.spec.ts +19 -0
- package/src/Wallet/Account/Key/Data/toUint8Array.ts +41 -0
- package/src/Wallet/Account/Key/XyoAddressValue.ts +51 -0
- package/src/Wallet/Account/Key/XyoEllipticKey.ts +9 -0
- package/src/Wallet/Account/Key/XyoKeyPair.ts +23 -0
- package/src/Wallet/Account/Key/XyoPrivateKey.ts +60 -0
- package/src/Wallet/Account/Key/XyoPublicKey.ts +21 -0
- package/src/Wallet/Account/Key/index.ts +5 -0
- package/src/Wallet/Account/index.ts +2 -0
- package/src/Wallet/Base/Base.spec.ts +10 -0
- package/src/Wallet/Base/Base.ts +35 -0
- package/src/Wallet/Base/Words.ts +2643 -0
- package/src/Wallet/Base/WordsPayload.ts +5 -0
- package/src/Wallet/Base/index.ts +1 -0
- package/src/Wallet/index.ts +2 -0
- package/src/Witness/Witness.spec.ts +13 -0
- package/src/Witness/Witness.ts +28 -0
- package/src/Witness/index.ts +1 -0
- package/src/browser/core/Wallet/Web.spec.ts +9 -0
- package/src/browser/core/Wallet/Web.ts +13 -0
- package/src/browser/core/Wallet/index.ts +1 -0
- package/src/browser/core/index.ts +1 -0
- package/src/browser/index.ts +1 -0
- package/src/browserIndex.ts +2 -0
- package/src/index.ts +2 -0
- package/src/lib/dns/DnsRecordType.ts +14 -0
- package/src/lib/dns/DnsReturnCode.ts +14 -0
- package/src/lib/dns/GoogleDnsResult.ts +17 -0
- package/src/lib/dns/GoogleDnsResultAnswer.ts +8 -0
- package/src/lib/dns/GoogleDnsResultQuestion.ts +11 -0
- package/src/lib/dns/domainExists.ts +15 -0
- package/src/lib/dns/domainResolve.ts +16 -0
- package/src/lib/dns/googleDnsOverHttps.ts +10 -0
- package/src/lib/dns/index.ts +8 -0
- package/src/lib/dumpErrors.ts +7 -0
- package/src/lib/index.ts +4 -0
- package/src/lib/isBrowser.ts +3 -0
- package/src/lib/typeOf/TypeOfTypes.ts +1 -0
- package/src/lib/typeOf/ifDefined.ts +12 -0
- package/src/lib/typeOf/ifTypeOf.ts +9 -0
- package/src/lib/typeOf/index.ts +5 -0
- package/src/lib/typeOf/typeOf.ts +5 -0
- package/src/lib/typeOf/validateType.ts +15 -0
- package/src/models/WithStringIndex.ts +1 -0
- package/src/models/index.ts +1 -0
- package/src/nodeIndex.ts +1 -0
- package/src/shared.ts +10 -0
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { assertEx } from '@xylabs/sdk-js'
|
|
2
|
+
|
|
3
|
+
import { XyoAddressValue } from '../../Wallet'
|
|
4
|
+
import { XyoBoundWitness } from '../models'
|
|
5
|
+
import { XyoBoundWitnessBodyValidator } from './BodyValidator'
|
|
6
|
+
import { XyoBoundWitnessMetaValidator } from './MetaValidator'
|
|
7
|
+
|
|
8
|
+
const validateArraysSameLength = (a: unknown[], b: unknown[], message = 'Array length mismatch') => {
|
|
9
|
+
return a.length != b.length ? [Error(`${message} []`)] : []
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
const validateSignature = (hash: string, address: string, signature?: string) => {
|
|
13
|
+
if (!signature) {
|
|
14
|
+
return [Error(`Missing signature [${address}]`)]
|
|
15
|
+
}
|
|
16
|
+
if (!new XyoAddressValue(address).verify(hash, signature)) {
|
|
17
|
+
return [Error(`Invalid signature [${address}] [${signature}]`)]
|
|
18
|
+
}
|
|
19
|
+
return []
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
class XyoBoundWitnessValidator {
|
|
23
|
+
private bw: XyoBoundWitness
|
|
24
|
+
public body: XyoBoundWitnessBodyValidator
|
|
25
|
+
public meta: XyoBoundWitnessMetaValidator
|
|
26
|
+
constructor(bw: XyoBoundWitness) {
|
|
27
|
+
this.bw = bw
|
|
28
|
+
this.body = new XyoBoundWitnessBodyValidator(bw, bw._payloads)
|
|
29
|
+
this.meta = new XyoBoundWitnessMetaValidator(bw)
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
public signatures() {
|
|
33
|
+
const hash = assertEx(this.bw._hash, 'Missing _hash')
|
|
34
|
+
return [
|
|
35
|
+
...validateArraysSameLength(this.bw._signatures ?? [], this.bw.addresses, 'Length mismatch: address/_signature'),
|
|
36
|
+
...this.bw.addresses.reduce<Error[]>((errors, address, index) => {
|
|
37
|
+
errors.push(...validateSignature(hash, address, this.bw._signatures?.[index]))
|
|
38
|
+
return errors
|
|
39
|
+
}, []),
|
|
40
|
+
]
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
public all() {
|
|
44
|
+
const errors: Error[] = []
|
|
45
|
+
errors.push(...this.meta.all(), ...this.body.all())
|
|
46
|
+
errors.push(...this.signatures())
|
|
47
|
+
return errors
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
export { XyoBoundWitnessValidator }
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
const word = '[a-fA-F\\d:]'
|
|
2
|
+
|
|
3
|
+
export interface Options {
|
|
4
|
+
readonly exact?: boolean
|
|
5
|
+
readonly includeBoundaries?: boolean
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
const boundry = (options: Options) => (options && options.includeBoundaries ? `(?:(?<=\\s|^)(?=${word})|(?<=${word})(?=\\s|$))` : '')
|
|
9
|
+
|
|
10
|
+
const v4 = '(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)(?:\\.(?:25[0-5]|2[0-4]\\d|1\\d\\d|[1-9]\\d|\\d)){3}'
|
|
11
|
+
|
|
12
|
+
const v6segment = '[a-fA-F\\d]{1,4}'
|
|
13
|
+
|
|
14
|
+
const v6 = `
|
|
15
|
+
(?:
|
|
16
|
+
(?:${v6segment}:){7}(?:${v6segment}|:)| // 1:2:3:4:5:6:7:: 1:2:3:4:5:6:7:8
|
|
17
|
+
(?:${v6segment}:){6}(?:${v4}|:${v6segment}|:)| // 1:2:3:4:5:6:: 1:2:3:4:5:6::8 1:2:3:4:5:6::8 1:2:3:4:5:6::1.2.3.4
|
|
18
|
+
(?:${v6segment}:){5}(?::${v4}|(?::${v6segment}){1,2}|:)| // 1:2:3:4:5:: 1:2:3:4:5::7:8 1:2:3:4:5::8 1:2:3:4:5::7:1.2.3.4
|
|
19
|
+
(?:${v6segment}:){4}(?:(?::${v6segment}){0,1}:${v4}|(?::${v6segment}){1,3}|:)| // 1:2:3:4:: 1:2:3:4::6:7:8 1:2:3:4::8 1:2:3:4::6:7:1.2.3.4
|
|
20
|
+
(?:${v6segment}:){3}(?:(?::${v6segment}){0,2}:${v4}|(?::${v6segment}){1,4}|:)| // 1:2:3:: 1:2:3::5:6:7:8 1:2:3::8 1:2:3::5:6:7:1.2.3.4
|
|
21
|
+
(?:${v6segment}:){2}(?:(?::${v6segment}){0,3}:${v4}|(?::${v6segment}){1,5}|:)| // 1:2:: 1:2::4:5:6:7:8 1:2::8 1:2::4:5:6:7:1.2.3.4
|
|
22
|
+
(?:${v6segment}:){1}(?:(?::${v6segment}){0,4}:${v4}|(?::${v6segment}){1,6}|:)| // 1:: 1::3:4:5:6:7:8 1::8 1::3:4:5:6:7:1.2.3.4
|
|
23
|
+
(?::(?:(?::${v6segment}){0,5}:${v4}|(?::${v6segment}){1,7}|:)) // ::2:3:4:5:6:7:8 ::2:3:4:5:6:7:8 ::8 ::1.2.3.4
|
|
24
|
+
)(?:%[0-9a-zA-Z]{1,})? // %eth0 %1
|
|
25
|
+
`
|
|
26
|
+
.replace(/\s*\/\/.*$/gm, '')
|
|
27
|
+
.replace(/\n/g, '')
|
|
28
|
+
.trim()
|
|
29
|
+
|
|
30
|
+
// Pre-compile only the exact regexes because adding a global flag make regexes stateful
|
|
31
|
+
const v46Exact = new RegExp(`(?:^${v4}$)|(?:^${v6}$)`)
|
|
32
|
+
const v4exact = new RegExp(`^${v4}$`)
|
|
33
|
+
const v6exact = new RegExp(`^${v6}$`)
|
|
34
|
+
|
|
35
|
+
export const ipRegex = (options: Options) =>
|
|
36
|
+
options && options.exact ? v46Exact : new RegExp(`(?:${boundry(options)}${v4}${boundry(options)})|(?:${boundry(options)}${v6}${boundry(options)})`, 'g')
|
|
37
|
+
|
|
38
|
+
ipRegex.v4 = (options: Options) => (options && options.exact ? v4exact : new RegExp(`${boundry(options)}${v4}${boundry(options)}`, 'g'))
|
|
39
|
+
ipRegex.v6 = (options: Options) => (options && options.exact ? v6exact : new RegExp(`${boundry(options)}${v6}${boundry(options)}`, 'g'))
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { ipRegex } from './ip-regex'
|
|
2
|
+
|
|
3
|
+
export function isIP(value: string) {
|
|
4
|
+
return ipRegex({ exact: true }).test(value)
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
export function isIPv6(value: string) {
|
|
8
|
+
return ipRegex.v6({ exact: true }).test(value)
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
export function isIPv4(value: string) {
|
|
12
|
+
return ipRegex.v4({ exact: true }).test(value)
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export function ipVersion(value: string) {
|
|
16
|
+
return isIP(value) ? (isIPv6(value) ? 6 : 4) : undefined
|
|
17
|
+
}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import pick from 'lodash/pick'
|
|
2
|
+
import { UAParser } from 'ua-parser-js'
|
|
3
|
+
|
|
4
|
+
import { XyoHasher } from '../../Hasher'
|
|
5
|
+
import { XyoBoundWitness } from '../models'
|
|
6
|
+
import { XyoBoundWitnessValidator } from '../Validator'
|
|
7
|
+
|
|
8
|
+
const scrubbedFields = ['_archive', '_client', '_hash', '_signatures', '_timestamp', '_user_agent', 'addresses', 'payload_schemas', 'previous_hashes', 'payload_hashes', 'schema']
|
|
9
|
+
|
|
10
|
+
class XyoBoundWitnessWrapper<T extends XyoBoundWitness> extends XyoHasher<T> {
|
|
11
|
+
public readonly bw: T
|
|
12
|
+
constructor(bw: T) {
|
|
13
|
+
super(bw)
|
|
14
|
+
this.bw = bw
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
get scrubbedFields() {
|
|
18
|
+
return pick(this.bw, scrubbedFields)
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
private _validator?: XyoBoundWitnessValidator
|
|
22
|
+
get validator() {
|
|
23
|
+
this._validator = this._validator ?? new XyoBoundWitnessValidator(this.bw)
|
|
24
|
+
return this._validator
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
private _userAgent?: UAParser
|
|
28
|
+
get userAgent() {
|
|
29
|
+
this._userAgent = this._userAgent ?? new UAParser(this.bw._user_agent)
|
|
30
|
+
return this._userAgent
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
export { XyoBoundWitnessWrapper }
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './Wrapper'
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { XyoPayloadBody } from '../../../Payload'
|
|
2
|
+
|
|
3
|
+
interface XyoBoundWitnessBody extends XyoPayloadBody {
|
|
4
|
+
[key: string]: unknown
|
|
5
|
+
addresses: string[]
|
|
6
|
+
previous_hash?: string
|
|
7
|
+
payload_hashes: string[]
|
|
8
|
+
payload_schemas: string[]
|
|
9
|
+
previous_hashes: (string | null)[]
|
|
10
|
+
schema: string
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
export type { XyoBoundWitnessBody }
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
//Should type as JSONSchemaType<XyoBoundWitnessBody> once ajv/eslint issue is fixed
|
|
2
|
+
//https://github.com/microsoft/TypeScript/issues/44851
|
|
3
|
+
const XyoBoundWitnessBodySchema = {
|
|
4
|
+
$id: 'https://schemas.xyo.network/2.0/boundwitness/body',
|
|
5
|
+
additionalProperties: false,
|
|
6
|
+
properties: {
|
|
7
|
+
addresses: { items: { type: 'string' }, type: 'array' },
|
|
8
|
+
payload_hashes: { items: { type: 'string' }, type: 'array' },
|
|
9
|
+
payload_schemas: { items: { type: 'string' }, type: 'array' },
|
|
10
|
+
previous_hashes: { items: { nullable: true, type: 'string' }, type: 'array' },
|
|
11
|
+
schema: { type: 'string' },
|
|
12
|
+
},
|
|
13
|
+
required: ['addresses', 'payload_hashes', 'payload_schemas', 'previous_hashes', 'schema'],
|
|
14
|
+
type: 'object',
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
export { XyoBoundWitnessBodySchema }
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { XyoPayloadBody } from '../../../Payload'
|
|
2
|
+
|
|
3
|
+
interface XyoBoundWitnessMeta {
|
|
4
|
+
[key: string]: unknown
|
|
5
|
+
_client?: string
|
|
6
|
+
_hash?: string
|
|
7
|
+
_archive?: string
|
|
8
|
+
_payloads?: XyoPayloadBody[]
|
|
9
|
+
_signatures?: string[]
|
|
10
|
+
_timestamp?: number
|
|
11
|
+
_source_ip?: string
|
|
12
|
+
_user_agent?: string
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export type { XyoBoundWitnessMeta }
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
//Should type as JSONSchemaType<XyoBoundWitnessMeta> once ajv/eslint issue is fixed
|
|
2
|
+
//https://github.com/microsoft/TypeScript/issues/44851
|
|
3
|
+
|
|
4
|
+
export const XyoBoundWitnessMetaSchemaProperties = () => {
|
|
5
|
+
return {
|
|
6
|
+
_archive: { nullable: true, type: 'string' },
|
|
7
|
+
_client: { nullable: true, type: 'string' },
|
|
8
|
+
_hash: { nullable: true, type: 'string' },
|
|
9
|
+
_payloads: { items: { type: 'object' }, nullable: true, type: 'array' },
|
|
10
|
+
_signatures: { items: { type: 'string' }, nullable: true, type: 'array' },
|
|
11
|
+
_source_ip: { nullable: true, type: 'string' },
|
|
12
|
+
_timestamp: { nullable: true, type: 'number' },
|
|
13
|
+
_user_agent: { nullable: true, type: 'string' },
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
export const XyoBoundWitnessMetaSchema = () => {
|
|
18
|
+
return {
|
|
19
|
+
$id: 'https://schemas.xyo.network/2.0/boundwitness/meta',
|
|
20
|
+
additionalProperties: false,
|
|
21
|
+
properties: XyoBoundWitnessMetaSchemaProperties,
|
|
22
|
+
type: 'object',
|
|
23
|
+
}
|
|
24
|
+
}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { XyoPayload } from '../../Payload'
|
|
2
|
+
import { XyoBoundWitnessBody } from './Body'
|
|
3
|
+
import { WithXyoBoundWitnessMeta } from './WithXyoBoundWitnessMeta'
|
|
4
|
+
|
|
5
|
+
type XyoBoundWitness = WithXyoBoundWitnessMeta<XyoBoundWitnessBody & XyoPayload>
|
|
6
|
+
|
|
7
|
+
export type { XyoBoundWitness }
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
//Should type as JSONSchemaType<XyoBoundWitness> once ajv/eslint issue is fixed
|
|
2
|
+
//https://github.com/microsoft/TypeScript/issues/44851
|
|
3
|
+
|
|
4
|
+
import { XyoBoundWitnessMetaSchemaProperties } from './Meta'
|
|
5
|
+
|
|
6
|
+
const XyoBoundWitnessSchema = () => {
|
|
7
|
+
return {
|
|
8
|
+
$id: 'https://schemas.xyo.network/2.0/boundwitness',
|
|
9
|
+
additionalProperties: false,
|
|
10
|
+
properties: {
|
|
11
|
+
...XyoBoundWitnessMetaSchemaProperties(),
|
|
12
|
+
addresses: { items: { type: 'string' }, type: 'array' },
|
|
13
|
+
payload_hashes: { items: { type: 'string' }, type: 'array' },
|
|
14
|
+
payload_schemas: { items: { type: 'string' }, type: 'array' },
|
|
15
|
+
previous_hashes: { items: { nullable: true, type: 'string' }, type: 'array' },
|
|
16
|
+
schema: { type: 'string' },
|
|
17
|
+
},
|
|
18
|
+
required: ['addresses', 'payload_hashes', 'payload_schemas', 'previous_hashes', 'schema'],
|
|
19
|
+
type: 'object',
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
export { XyoBoundWitnessSchema }
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import shajs from 'sha.js'
|
|
2
|
+
|
|
3
|
+
import { removeEmptyFields } from './removeEmptyFields'
|
|
4
|
+
import { deepOmitUnderscoreFields } from './removeFields'
|
|
5
|
+
import { sortFields } from './sortFields'
|
|
6
|
+
|
|
7
|
+
export class XyoHasher<T extends Record<string, unknown>> {
|
|
8
|
+
public readonly obj: T
|
|
9
|
+
constructor(obj: T) {
|
|
10
|
+
this.obj = obj
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
get hashFields() {
|
|
14
|
+
return removeEmptyFields(deepOmitUnderscoreFields(this.obj))
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
public sortedStringify() {
|
|
18
|
+
const sortedEntry = sortFields(this.hashFields)
|
|
19
|
+
return JSON.stringify(sortedEntry)
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
public sortedHash() {
|
|
23
|
+
return this.sortedHashData().toString('hex')
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
private sortedHashData() {
|
|
27
|
+
const stringObject = this.sortedStringify()
|
|
28
|
+
return shajs('sha256').update(stringObject).digest()
|
|
29
|
+
}
|
|
30
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { removeEmptyFields } from './removeEmptyFields'
|
|
2
|
+
|
|
3
|
+
describe('removeEmptyFields', () => {
|
|
4
|
+
test('deep', () => {
|
|
5
|
+
const testObject = {
|
|
6
|
+
testArray: [1, 2, 3],
|
|
7
|
+
testBoolean: true,
|
|
8
|
+
testNull: null,
|
|
9
|
+
testNullObject: { t: null, x: undefined },
|
|
10
|
+
testNumber: 5,
|
|
11
|
+
testObject: { t: 1 },
|
|
12
|
+
testSomeNullObject: { s: 1, t: null, x: undefined },
|
|
13
|
+
testString: 'hi',
|
|
14
|
+
testUndefined: undefined,
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
const result = removeEmptyFields(testObject)
|
|
18
|
+
|
|
19
|
+
expect(Object.keys(result).length).toBe(8)
|
|
20
|
+
expect(Object.keys(result.testSomeNullObject as object).length).toBe(2)
|
|
21
|
+
expect(Object.keys(result.testNullObject as object).length).toBe(1)
|
|
22
|
+
})
|
|
23
|
+
})
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { typeOf } from '../lib'
|
|
2
|
+
|
|
3
|
+
export const removeEmptyFields = (obj: Record<string, unknown>) => {
|
|
4
|
+
if (obj === null || Array.isArray(obj)) return obj
|
|
5
|
+
|
|
6
|
+
const newObject: Record<string, unknown> = {}
|
|
7
|
+
Object.entries(obj).forEach(([key, value]) => {
|
|
8
|
+
if (typeOf(value) === 'object') {
|
|
9
|
+
newObject[key] = removeEmptyFields(value as Record<string, unknown>)
|
|
10
|
+
} else if (value !== undefined) {
|
|
11
|
+
newObject[key] = value
|
|
12
|
+
}
|
|
13
|
+
})
|
|
14
|
+
return newObject
|
|
15
|
+
}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
// eslint-disable-next-line no-restricted-imports
|
|
2
|
+
import { ValueKeyIteratee } from 'lodash'
|
|
3
|
+
import assign from 'lodash/assign'
|
|
4
|
+
import isObject from 'lodash/isObject'
|
|
5
|
+
import mapValues from 'lodash/mapValues'
|
|
6
|
+
import omitBy from 'lodash/omitBy'
|
|
7
|
+
import pickBy from 'lodash/pickBy'
|
|
8
|
+
|
|
9
|
+
export const deepBy = <T>(obj: T, predicate: ValueKeyIteratee<T>, func: typeof omitBy | typeof pickBy) => {
|
|
10
|
+
if (Array.isArray(obj)) {
|
|
11
|
+
return obj
|
|
12
|
+
}
|
|
13
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
14
|
+
const onlyObjects = pickBy<T>(obj as any, isObject)
|
|
15
|
+
const processedObjects = mapValues<T>(onlyObjects, (obj: T) => deepBy(obj, predicate, func))
|
|
16
|
+
const addBackValues = assign(processedObjects, omitBy(obj, isObject))
|
|
17
|
+
return omitBy(addBackValues, predicate) as T
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
export const deepOmitUnderscoreFields = <T>(obj: T) => {
|
|
21
|
+
return deepBy(obj, (_, key) => key.startsWith('_'), omitBy)
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export const deepPickUnderscoreFields = <T>(obj: T) => {
|
|
25
|
+
return deepBy(obj, (_, key) => key.startsWith('_'), pickBy)
|
|
26
|
+
}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { typeOf } from '../lib'
|
|
2
|
+
|
|
3
|
+
//if an object, subsort
|
|
4
|
+
const subSort = (value: unknown) => {
|
|
5
|
+
switch (typeOf(value)) {
|
|
6
|
+
case 'object':
|
|
7
|
+
return sortFields(value as Record<string, unknown>)
|
|
8
|
+
default:
|
|
9
|
+
return value
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
export const sortFields = <T extends Record<string, unknown>>(obj: T) => {
|
|
14
|
+
if (obj === null) {
|
|
15
|
+
return null
|
|
16
|
+
}
|
|
17
|
+
const result: Record<string, unknown> = {} as Record<string, unknown>
|
|
18
|
+
Object.keys(obj)
|
|
19
|
+
.sort()
|
|
20
|
+
.forEach((key) => {
|
|
21
|
+
result[key] = subSort(obj[key])
|
|
22
|
+
})
|
|
23
|
+
return result as T
|
|
24
|
+
}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
import { delay } from '@xylabs/sdk-js'
|
|
2
|
+
|
|
3
|
+
import { XyoPayload } from '../Payload'
|
|
4
|
+
import { Huri } from './Huri'
|
|
5
|
+
|
|
6
|
+
const hash = 'fb3606d71dcdd49a0aacc9d234e412684d577803c8a9ed9399a9d3776cc88e24'
|
|
7
|
+
|
|
8
|
+
const valid = [
|
|
9
|
+
`https://${hash}`,
|
|
10
|
+
`https://api.archivist.xyo.network/temp/${hash}`,
|
|
11
|
+
`https://api.archivist.xyo.network/${hash}`,
|
|
12
|
+
`http://api.archivist.xyo.network/${hash}`,
|
|
13
|
+
`/api.archivist.xyo.network/${hash}`,
|
|
14
|
+
`//${hash}`,
|
|
15
|
+
`/${hash}`,
|
|
16
|
+
`${hash}`,
|
|
17
|
+
]
|
|
18
|
+
|
|
19
|
+
const validWithTempArchive = [
|
|
20
|
+
`https://api.archivist.xyo.network/temp/${hash}`,
|
|
21
|
+
`https://api.archivist.xyo.network/temp/${hash}`,
|
|
22
|
+
`http://api.archivist.xyo.network/temp/${hash}`,
|
|
23
|
+
`/api.archivist.xyo.network/temp/${hash}`,
|
|
24
|
+
]
|
|
25
|
+
|
|
26
|
+
const invalid = [`https:///api.archivist.xyo.network/${hash}`, `https://api.archivist.xyo.network//${hash}`]
|
|
27
|
+
|
|
28
|
+
describe('Huri', () => {
|
|
29
|
+
describe('Valid Items', () => {
|
|
30
|
+
valid.map((item) => {
|
|
31
|
+
test(`valid [${item}]`, () => {
|
|
32
|
+
try {
|
|
33
|
+
const huri = new Huri(item)
|
|
34
|
+
expect(huri.hash).toBe(hash)
|
|
35
|
+
} catch (ex) {
|
|
36
|
+
console.error(`Valid Huri failed: [${item}]`)
|
|
37
|
+
console.error(ex)
|
|
38
|
+
}
|
|
39
|
+
})
|
|
40
|
+
})
|
|
41
|
+
})
|
|
42
|
+
describe('Valid Items w/archive', () => {
|
|
43
|
+
validWithTempArchive.map((item) => {
|
|
44
|
+
test(`valid w/archive [${item}]`, () => {
|
|
45
|
+
try {
|
|
46
|
+
const huri = new Huri(item)
|
|
47
|
+
expect(huri.hash).toBe(hash)
|
|
48
|
+
expect(huri.archive).toBe('temp')
|
|
49
|
+
} catch (ex) {
|
|
50
|
+
console.error(`Valid Huri w/archive failed: [${item}]`)
|
|
51
|
+
console.error(ex)
|
|
52
|
+
}
|
|
53
|
+
})
|
|
54
|
+
})
|
|
55
|
+
})
|
|
56
|
+
describe('Invalid Items', () => {
|
|
57
|
+
invalid.map((item) => {
|
|
58
|
+
test(`invalid [${item}]`, () => {
|
|
59
|
+
expect(() => new Huri(item)).toThrowError()
|
|
60
|
+
})
|
|
61
|
+
})
|
|
62
|
+
})
|
|
63
|
+
describe('Api Fetch', () => {
|
|
64
|
+
it('Valid Huri', async () => {
|
|
65
|
+
const huri = new Huri('https://beta.api.archivist.xyo.network/18f97b3e85f5bede65e7c0a85d74aee896de58ead8bc4b1b3d7300646c653057')
|
|
66
|
+
const result = await huri.fetch()
|
|
67
|
+
expect(result?.schema).toBe('network.xyo.schema')
|
|
68
|
+
})
|
|
69
|
+
it('Invalid Huri', async () => {
|
|
70
|
+
const huri = new Huri('https://beta.api.archivist.xyo.network/18f97b3e85f5bede65e7c0a85d74aee896de58ead8bc4b1b3d7300646c653bad')
|
|
71
|
+
await expect(huri.fetch()).rejects.toThrow()
|
|
72
|
+
})
|
|
73
|
+
})
|
|
74
|
+
describe('Fetch Override', () => {
|
|
75
|
+
invalid.map((item) => {
|
|
76
|
+
test(`invalid [${item}]`, async () => {
|
|
77
|
+
const oldFetch = Huri.fetch
|
|
78
|
+
Huri.fetch = async (huri: Huri) => {
|
|
79
|
+
await delay(0)
|
|
80
|
+
const payload: XyoPayload = {
|
|
81
|
+
schema: huri.hash,
|
|
82
|
+
}
|
|
83
|
+
console.log(`Payload: ${JSON.stringify(payload, null, 2)}`)
|
|
84
|
+
return payload
|
|
85
|
+
}
|
|
86
|
+
const huri = new Huri('https://beta.api.archivist.xyo.network/18f97b3e85f5bede65e7c0a85d74aee896de58ead8bc4b1b3d7300646c653057')
|
|
87
|
+
const result = await huri.fetch()
|
|
88
|
+
Huri.fetch = oldFetch
|
|
89
|
+
expect(result?.schema).toBe('18f97b3e85f5bede65e7c0a85d74aee896de58ead8bc4b1b3d7300646c653057')
|
|
90
|
+
})
|
|
91
|
+
})
|
|
92
|
+
})
|
|
93
|
+
})
|
package/src/Huri/Huri.ts
ADDED
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
import { assertEx } from '@xylabs/sdk-js'
|
|
2
|
+
import axios from 'axios'
|
|
3
|
+
|
|
4
|
+
import { XyoPayload } from '../Payload'
|
|
5
|
+
|
|
6
|
+
export type XyoObjectCategory = 'block' | 'payload'
|
|
7
|
+
|
|
8
|
+
export type HuriFetchFunction = (huri: Huri) => Promise<XyoPayload | undefined>
|
|
9
|
+
|
|
10
|
+
/*
|
|
11
|
+
Valid Huri:
|
|
12
|
+
|
|
13
|
+
[<protocol>://][<archivist>/[<archive>/]]<hash>
|
|
14
|
+
|
|
15
|
+
defaults:
|
|
16
|
+
protocol: https
|
|
17
|
+
archivist: api.archivist.xyo.network
|
|
18
|
+
*/
|
|
19
|
+
|
|
20
|
+
export interface HuriOptions {
|
|
21
|
+
archivistUri?: string
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export interface XyoFetchedPayload<T extends XyoPayload = XyoPayload> {
|
|
25
|
+
payload: T
|
|
26
|
+
huri?: Huri
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
export class Huri {
|
|
30
|
+
public originalHref: string
|
|
31
|
+
public protocol?: string
|
|
32
|
+
public archivist?: string
|
|
33
|
+
public archive?: string
|
|
34
|
+
public hash: string
|
|
35
|
+
|
|
36
|
+
constructor(huri: string, { archivistUri }: HuriOptions = {}) {
|
|
37
|
+
this.originalHref = huri
|
|
38
|
+
|
|
39
|
+
const protocol = Huri.parseProtocol(huri)
|
|
40
|
+
this.protocol = protocol ?? 'https'
|
|
41
|
+
|
|
42
|
+
const path = assertEx(Huri.parsePath(huri), 'Missing path')
|
|
43
|
+
this.hash = this.parsePath(path, protocol !== undefined)
|
|
44
|
+
|
|
45
|
+
//if archivistUri sent, overwrite protocol and archivist
|
|
46
|
+
if (archivistUri) {
|
|
47
|
+
const archivistUriParts = archivistUri.split('://')
|
|
48
|
+
this.protocol = archivistUriParts[0]
|
|
49
|
+
this.archivist = archivistUriParts[1]
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
this.validateParse()
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
private parsePath(path: string, hasProtocol: boolean) {
|
|
56
|
+
const pathParts = path.split('/')
|
|
57
|
+
|
|
58
|
+
//if the protocal was found, then there is not allowed to be a leading /
|
|
59
|
+
assertEx(!(hasProtocol && pathParts[0].length === 0), 'Invalid protocol seperator')
|
|
60
|
+
|
|
61
|
+
//remove leading '/' if needed
|
|
62
|
+
pathParts[0].length === 0 ? pathParts.shift() : null
|
|
63
|
+
|
|
64
|
+
//hash is assumed to be the last part
|
|
65
|
+
const hash = assertEx(pathParts.pop(), 'No hash specified')
|
|
66
|
+
|
|
67
|
+
//archivist is assumed to be the first part
|
|
68
|
+
this.archivist = pathParts.shift() ?? 'api.archivist.xyo.network'
|
|
69
|
+
|
|
70
|
+
//the archive is whatever is left
|
|
71
|
+
this.archive = pathParts.pop()
|
|
72
|
+
|
|
73
|
+
//after we pull off all the path parts, there should be nothing left
|
|
74
|
+
assertEx(pathParts.length === 0, 'Too many path parts')
|
|
75
|
+
|
|
76
|
+
return hash
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
private validateParse() {
|
|
80
|
+
//the archivist should not be zero length
|
|
81
|
+
assertEx(this.archivist?.length !== 0, 'Invalid archivist length')
|
|
82
|
+
|
|
83
|
+
//the archivist should not be zero length (can be undefined)
|
|
84
|
+
assertEx(this.archive?.length !== 0, 'Invalid archive length')
|
|
85
|
+
|
|
86
|
+
//the archive should not be set if the archivist is not set
|
|
87
|
+
assertEx(!(this.archive && !this.archivist), 'If specifying archive, archivist is also required')
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
/*
|
|
91
|
+
The full href or the hash
|
|
92
|
+
*/
|
|
93
|
+
|
|
94
|
+
public get href() {
|
|
95
|
+
const parts: string[] = []
|
|
96
|
+
if (this.protocol) {
|
|
97
|
+
parts.push(`${this.protocol}:/`)
|
|
98
|
+
}
|
|
99
|
+
if (this.archive) {
|
|
100
|
+
parts.push(`${this.archive}`)
|
|
101
|
+
}
|
|
102
|
+
if (this.archivist) {
|
|
103
|
+
parts.push(`${this.archivist}`)
|
|
104
|
+
}
|
|
105
|
+
parts.push(this.hash)
|
|
106
|
+
return parts.join('/')
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
public toString() {
|
|
110
|
+
return this.href
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
public async fetch() {
|
|
114
|
+
return await Huri.fetch(this)
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
static async fetch(huri: Huri): Promise<XyoPayload | undefined> {
|
|
118
|
+
return (await axios.get<XyoPayload>(huri.href)).data
|
|
119
|
+
}
|
|
120
|
+
|
|
121
|
+
private static parseProtocol(huri: string) {
|
|
122
|
+
const protocolSplit = huri.split('//')
|
|
123
|
+
assertEx(protocolSplit.length <= 2, `Invalid second protocol [${protocolSplit[2]}]`)
|
|
124
|
+
const rawProtocol = protocolSplit.length === 2 ? protocolSplit.shift() : undefined
|
|
125
|
+
if (rawProtocol) {
|
|
126
|
+
const protocolParts = rawProtocol?.split(':')
|
|
127
|
+
assertEx(protocolParts.length === 2, `Invalid protocol format [${rawProtocol}]`)
|
|
128
|
+
assertEx(protocolParts[1].length === 0, `Invalid protocol format (post :) [${rawProtocol}]`)
|
|
129
|
+
return protocolParts.shift()
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
private static parsePath(huri: string) {
|
|
134
|
+
const protocolSplit = huri.split('//')
|
|
135
|
+
assertEx(protocolSplit.length <= 2, `Invalid format [${huri}]`)
|
|
136
|
+
if (protocolSplit.length === 1) {
|
|
137
|
+
return huri
|
|
138
|
+
}
|
|
139
|
+
if (protocolSplit.length === 2) {
|
|
140
|
+
return protocolSplit[1]
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './Huri'
|