@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,96 @@
|
|
|
1
|
+
import shajs from 'sha.js'
|
|
2
|
+
|
|
3
|
+
import { toUint8Array, XyoData, XyoDataLike, XyoKeyPair, XyoPublicKey } from './Key'
|
|
4
|
+
|
|
5
|
+
export const ethMessagePrefix = '\x19Ethereum Signed Message:\n'
|
|
6
|
+
|
|
7
|
+
export interface XyoAccountConfig {
|
|
8
|
+
privateKey?: XyoDataLike
|
|
9
|
+
phrase?: string
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
export class XyoAccount extends XyoKeyPair {
|
|
13
|
+
private _isXyoWallet = true
|
|
14
|
+
private _previousHash?: XyoData
|
|
15
|
+
|
|
16
|
+
constructor({ privateKey, phrase }: XyoAccountConfig = {}) {
|
|
17
|
+
const privateKeyToUse = privateKey ? toUint8Array(privateKey) : phrase ? toUint8Array(shajs('sha256').update(phrase).digest('hex')) : undefined
|
|
18
|
+
super(privateKeyToUse)
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
/** @deprecated use addressValue instead */
|
|
22
|
+
public get address() {
|
|
23
|
+
return this.public.address.hex
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
public get addressValue() {
|
|
27
|
+
return this.public.address
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
public get previousHash() {
|
|
31
|
+
return this._previousHash
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
/** @deprecated use private instead */
|
|
35
|
+
public get privateKey() {
|
|
36
|
+
return this.private
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
/** @deprecated use public instead */
|
|
40
|
+
public get publicKey() {
|
|
41
|
+
return this.public
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
public sign(hash: Uint8Array | string) {
|
|
45
|
+
this._previousHash = new XyoData(32, hash)
|
|
46
|
+
return this.private.sign(hash)
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
public verify(msg: Uint8Array | string, signature: Uint8Array | string) {
|
|
50
|
+
return this.public.address.verify(msg, signature)
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
static fromPhrase(phrase: string) {
|
|
54
|
+
const privateKey = shajs('sha256').update(phrase).digest('hex')
|
|
55
|
+
return XyoAccount.fromPrivateKey(privateKey)
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
static fromPrivateKey(key: Uint8Array | string) {
|
|
59
|
+
const privateKey = toUint8Array(key)
|
|
60
|
+
return new XyoAccount({ privateKey })
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
static random() {
|
|
64
|
+
return new XyoAccount()
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
static isXyoWallet(value: unknown) {
|
|
68
|
+
return (value as XyoAccount)._isXyoWallet
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
/** @deprecated use XyoWallet instead */
|
|
73
|
+
export class XyoAddress extends XyoAccount {
|
|
74
|
+
public get previousHashString() {
|
|
75
|
+
return this.previousHash?.hex
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
static fromPhrase(phrase: string) {
|
|
79
|
+
return XyoAccount.fromPhrase(phrase)
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
static fromPrivateKey(key: Uint8Array | string) {
|
|
83
|
+
return XyoAccount.fromPrivateKey(key)
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
static random() {
|
|
87
|
+
return XyoAccount.random()
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
static verifyAddress(msg: Uint8Array | string, signature: Uint8Array | string, address: XyoDataLike) {
|
|
91
|
+
return new XyoPublicKey(address).verify(msg, signature)
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
/** @deprecated use XyoAccount instead */
|
|
96
|
+
export class XyoWallet extends XyoAccount {}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { BigNumber, Buffer } from '@xylabs/sdk-js'
|
|
2
|
+
|
|
3
|
+
export abstract class XyoAbstractData {
|
|
4
|
+
private _isXyoData = true
|
|
5
|
+
public abstract get hex(): string
|
|
6
|
+
|
|
7
|
+
public abstract get buffer(): Buffer
|
|
8
|
+
|
|
9
|
+
public abstract get bn(): BigNumber
|
|
10
|
+
|
|
11
|
+
public abstract get bytes(): Uint8Array
|
|
12
|
+
|
|
13
|
+
public abstract get keccak256(): Buffer
|
|
14
|
+
|
|
15
|
+
public get length() {
|
|
16
|
+
return this.bytes.length
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
public static isXyoData(value: unknown) {
|
|
20
|
+
return (value as XyoAbstractData)._isXyoData
|
|
21
|
+
}
|
|
22
|
+
}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { assertEx, BigNumber, Buffer, bufferPolyfill } from '@xylabs/sdk-js'
|
|
2
|
+
import keccak256 from 'keccak256'
|
|
3
|
+
|
|
4
|
+
import { XyoAbstractData } from './AbstractData'
|
|
5
|
+
import { toUint8ArrayOptional } from './toUint8Array'
|
|
6
|
+
import { XyoDataLike } from './XyoDataLike'
|
|
7
|
+
|
|
8
|
+
export class XyoData extends XyoAbstractData {
|
|
9
|
+
private _bytes?: Uint8Array
|
|
10
|
+
private _length: number
|
|
11
|
+
constructor(length: number, bytes?: XyoDataLike) {
|
|
12
|
+
super()
|
|
13
|
+
this._bytes = toUint8ArrayOptional(bytes)
|
|
14
|
+
this._length = length
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
private checkLength() {
|
|
18
|
+
assertEx(this.bytes.length === this._length, `Length Mismatch: ${this.bytes.length} !== ${this._length}`)
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
public get hex() {
|
|
22
|
+
this.checkLength()
|
|
23
|
+
return Buffer.from(this.bytes).toString('hex').toLowerCase()
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
public get buffer() {
|
|
27
|
+
this.checkLength()
|
|
28
|
+
return Buffer.from(this.bytes)
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
public get bn() {
|
|
32
|
+
this.checkLength()
|
|
33
|
+
return new BigNumber(this.bytes)
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
public get bytes() {
|
|
37
|
+
return assertEx(this._bytes, 'XyoData uninitialized')
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
public get keccak256() {
|
|
41
|
+
bufferPolyfill()
|
|
42
|
+
this.checkLength()
|
|
43
|
+
return Buffer.from(keccak256(`0x${this.buffer.toString('hex')}`))
|
|
44
|
+
}
|
|
45
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { Buffer } from 'buffer'
|
|
2
|
+
|
|
3
|
+
import { toUint8Array } from './toUint8Array'
|
|
4
|
+
|
|
5
|
+
describe('toUint8Array', () => {
|
|
6
|
+
test('Uint8Array Round Trip', () => {
|
|
7
|
+
const testArray = Uint8Array.from([0, 1, 2, 3])
|
|
8
|
+
const testArrayPrime = toUint8Array(testArray)
|
|
9
|
+
expect(testArray.length).toBe(testArrayPrime.length)
|
|
10
|
+
for (let i = 0; i < testArray.length; i++) {
|
|
11
|
+
expect(testArray[i]).toBe(testArrayPrime[i])
|
|
12
|
+
}
|
|
13
|
+
})
|
|
14
|
+
test('Hex Round Trip', () => {
|
|
15
|
+
const testHex = '1a2b3c'
|
|
16
|
+
const testHexPrime = Buffer.from(toUint8Array(testHex)).toString('hex')
|
|
17
|
+
expect(testHex).toBe(testHexPrime)
|
|
18
|
+
})
|
|
19
|
+
})
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { assertEx, BigNumber, Buffer } from '@xylabs/sdk-js'
|
|
2
|
+
|
|
3
|
+
import { ifTypeOf } from '../../../../lib'
|
|
4
|
+
import { XyoAbstractData } from './AbstractData'
|
|
5
|
+
import { XyoDataLike } from './XyoDataLike'
|
|
6
|
+
|
|
7
|
+
const stringToUint8Array = (value: string) => {
|
|
8
|
+
return bufferToUint8Array(Buffer.from(value.startsWith('0x') ? value.slice(2) : value, 'hex'))
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
const bigNumberToUint8Array = (value: BigNumber) => {
|
|
12
|
+
return bufferToUint8Array(Buffer.from(value.toBuffer()))
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
const bufferToUint8Array = (value: Buffer) => {
|
|
16
|
+
return Uint8Array.from(value)
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
const xyoDataToUint8Array = (value: XyoAbstractData) => {
|
|
20
|
+
return value.bytes
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
export const toUint8ArrayOptional = (value?: XyoDataLike, padLength?: number): Uint8Array | undefined => {
|
|
24
|
+
return value ? toUint8Array(value, padLength) : undefined
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
export const toUint8Array = (value: XyoDataLike, padLength?: number): Uint8Array => {
|
|
28
|
+
let result: Uint8Array | undefined =
|
|
29
|
+
ifTypeOf<string, Uint8Array>('string', value as string, stringToUint8Array) ??
|
|
30
|
+
ifTypeOf<BigNumber, Uint8Array | undefined>('object', value as BigNumber, bigNumberToUint8Array, BigNumber.isBN) ??
|
|
31
|
+
ifTypeOf<Buffer, Uint8Array | undefined>('object', value as Buffer, bufferToUint8Array, Buffer.isBuffer) ??
|
|
32
|
+
ifTypeOf<XyoAbstractData, Uint8Array | undefined>('object', value as Buffer, xyoDataToUint8Array, XyoAbstractData.isXyoData) ??
|
|
33
|
+
(value as Uint8Array)
|
|
34
|
+
|
|
35
|
+
if (padLength && result.length < padLength) {
|
|
36
|
+
result = new Uint8Array([...new Uint8Array(padLength - result.length), ...result])
|
|
37
|
+
assertEx(result?.length <= padLength, 'Resulting length is greater than padLength')
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
return result
|
|
41
|
+
}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { toUint8Array, XyoData, XyoDataLike } from './Data'
|
|
2
|
+
import { XyoEllipticKey } from './XyoEllipticKey'
|
|
3
|
+
|
|
4
|
+
export class XyoAddressValue extends XyoEllipticKey {
|
|
5
|
+
private _isXyoAddress = true
|
|
6
|
+
constructor(address: XyoDataLike) {
|
|
7
|
+
super(20, XyoAddressValue.addressFromAddressOrPublicKey(address))
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
public verify(msg: Uint8Array | string, signature: Uint8Array | string) {
|
|
11
|
+
return XyoAddressValue.verify(msg, signature, this.bytes)
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
//there has to be a better way to do this other than trying all four numbers
|
|
15
|
+
//maybe we can get the number from the address more easily
|
|
16
|
+
public static verify(msg: Uint8Array | string, signature: Uint8Array | string, address: XyoDataLike) {
|
|
17
|
+
let valid = false
|
|
18
|
+
const sigArray = toUint8Array(signature)
|
|
19
|
+
const r = sigArray.slice(0, 32)
|
|
20
|
+
const s = sigArray.slice(32, 64)
|
|
21
|
+
|
|
22
|
+
const expectedAddress = new XyoAddressValue(address).hex
|
|
23
|
+
|
|
24
|
+
for (let i = 0; i < 4; i++) {
|
|
25
|
+
try {
|
|
26
|
+
const publicKey = XyoAddressValue.ecContext
|
|
27
|
+
.keyFromPublic(XyoAddressValue.ecContext.recoverPubKey(toUint8Array(msg), { r, s }, i))
|
|
28
|
+
.getPublic('hex')
|
|
29
|
+
.slice(2)
|
|
30
|
+
const recoveredAddress = XyoAddressValue.addressFromPublicKey(publicKey)
|
|
31
|
+
valid = valid || recoveredAddress === expectedAddress
|
|
32
|
+
} catch (ex) {
|
|
33
|
+
null
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
return valid
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
public static addressFromPublicKey(key: XyoDataLike) {
|
|
40
|
+
return new XyoData(64, key).keccak256.slice(12).toString('hex').padStart(40, '0')
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
public static addressFromAddressOrPublicKey(bytes: XyoDataLike) {
|
|
44
|
+
const bytesArray = toUint8Array(bytes)
|
|
45
|
+
return bytesArray.length === 20 ? bytesArray : XyoAddressValue.addressFromPublicKey(bytesArray)
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
public static isXyoAddress(value: unknown) {
|
|
49
|
+
return (value as XyoAddressValue)._isXyoAddress
|
|
50
|
+
}
|
|
51
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import EC from 'elliptic'
|
|
2
|
+
|
|
3
|
+
import { XyoData } from './Data'
|
|
4
|
+
|
|
5
|
+
export class XyoEllipticKey extends XyoData {
|
|
6
|
+
// we do this to allow node to import without problem
|
|
7
|
+
// eslint-disable-next-line import/no-named-as-default-member
|
|
8
|
+
protected static ecContext = new EC.ec('secp256k1')
|
|
9
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { XyoDataLike } from './Data'
|
|
2
|
+
import { XyoPrivateKey } from './XyoPrivateKey'
|
|
3
|
+
|
|
4
|
+
export class XyoKeyPair {
|
|
5
|
+
private _private?: XyoPrivateKey
|
|
6
|
+
private _isXyoKeyPair = true
|
|
7
|
+
constructor(privateKeyData?: XyoDataLike) {
|
|
8
|
+
this._private = new XyoPrivateKey(privateKeyData)
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
public get private() {
|
|
12
|
+
this._private = this._private ?? new XyoPrivateKey()
|
|
13
|
+
return this._private
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
public get public() {
|
|
17
|
+
return this.private.public
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
public static isXyoKeyPair(value: unknown) {
|
|
21
|
+
return (value as XyoKeyPair)._isXyoKeyPair
|
|
22
|
+
}
|
|
23
|
+
}
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import EC from 'elliptic'
|
|
2
|
+
|
|
3
|
+
import { toUint8Array, XyoDataLike } from './Data'
|
|
4
|
+
import { XyoEllipticKey } from './XyoEllipticKey'
|
|
5
|
+
import { XyoPublicKey } from './XyoPublicKey'
|
|
6
|
+
|
|
7
|
+
export class XyoPrivateKey extends XyoEllipticKey {
|
|
8
|
+
private _isXyoPrivateKey = true
|
|
9
|
+
private _keyPair: EC.ec.KeyPair
|
|
10
|
+
private _public?: XyoPublicKey
|
|
11
|
+
|
|
12
|
+
constructor(value?: XyoDataLike) {
|
|
13
|
+
super(32)
|
|
14
|
+
if (value) {
|
|
15
|
+
this._keyPair = XyoPrivateKey.ecContext.keyFromPrivate(toUint8Array(value))
|
|
16
|
+
} else {
|
|
17
|
+
this._keyPair = XyoPrivateKey.ecContext.genKeyPair()
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
public override get bytes() {
|
|
22
|
+
return toUint8Array(this._keyPair?.getPrivate())
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
public get public() {
|
|
26
|
+
this._public = this._public ?? new XyoPublicKey(this._keyPair.getPublic('hex').slice(2))
|
|
27
|
+
return this._public
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
public sign(hash: XyoDataLike) {
|
|
31
|
+
const arrayHash = toUint8Array(hash)
|
|
32
|
+
const signature = this._keyPair.sign(arrayHash)
|
|
33
|
+
return toUint8Array(signature.r.toString('hex', 64) + signature.s.toString('hex', 64))
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
public verify(msg: Uint8Array | string, signature: Uint8Array | string) {
|
|
37
|
+
return this.public.address.verify(msg, signature)
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
/*
|
|
41
|
+
public signKeccakMessage(message: string) {
|
|
42
|
+
const prefixBuffer = Buffer.from(messagePrefix)
|
|
43
|
+
const messageLengthBuffer = Buffer.from([0x20])
|
|
44
|
+
const messageBuffer = Buffer.from(message)
|
|
45
|
+
const signingBuffer = keccak256(
|
|
46
|
+
Buffer.concat([
|
|
47
|
+
prefixBuffer,
|
|
48
|
+
messageLengthBuffer,
|
|
49
|
+
keccak256(Buffer.concat([messageBuffer, Buffer.from(toUint8Array(this.address))])),
|
|
50
|
+
])
|
|
51
|
+
)
|
|
52
|
+
const signature = this._key.sign(signingBuffer)
|
|
53
|
+
return signature.toDER('hex').substring(2)
|
|
54
|
+
}
|
|
55
|
+
*/
|
|
56
|
+
|
|
57
|
+
public static isXyoPrivateKey(value: unknown) {
|
|
58
|
+
return (value as XyoPrivateKey)._isXyoPrivateKey
|
|
59
|
+
}
|
|
60
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { XyoDataLike } from './Data'
|
|
2
|
+
import { XyoAddressValue } from './XyoAddressValue'
|
|
3
|
+
import { XyoEllipticKey } from './XyoEllipticKey'
|
|
4
|
+
|
|
5
|
+
export class XyoPublicKey extends XyoEllipticKey {
|
|
6
|
+
private _isXyoPublicKey = true
|
|
7
|
+
constructor(bytes: XyoDataLike) {
|
|
8
|
+
super(64, bytes)
|
|
9
|
+
}
|
|
10
|
+
public get address() {
|
|
11
|
+
return new XyoAddressValue(this.keccak256.slice(12).toString('hex').padStart(40, '0'))
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
public verify(msg: Uint8Array | string, signature: Uint8Array | string) {
|
|
15
|
+
return this.address.verify(msg, signature)
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
public static isXyoPublicKey(value: unknown) {
|
|
19
|
+
return (value as XyoPublicKey)._isXyoPublicKey
|
|
20
|
+
}
|
|
21
|
+
}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { XyoWalletBase } from './Base'
|
|
2
|
+
|
|
3
|
+
test('all', () => {
|
|
4
|
+
const wallet = new XyoWalletBase('test phrase')
|
|
5
|
+
const account = wallet.getAccount(10)
|
|
6
|
+
|
|
7
|
+
expect(account).toBeDefined()
|
|
8
|
+
expect(account.addressValue.length).toBe(20)
|
|
9
|
+
expect(account.public.address.hex).toBe('8ce36d609316943d9825501eb88b1af1fe4586a0')
|
|
10
|
+
})
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { delay } from '@xylabs/sdk-js'
|
|
2
|
+
import shajs from 'sha.js'
|
|
3
|
+
|
|
4
|
+
import { XyoAccount } from '../Account'
|
|
5
|
+
import { Words } from './Words'
|
|
6
|
+
|
|
7
|
+
export class XyoWalletBase {
|
|
8
|
+
protected _phrase: string
|
|
9
|
+
protected _name: string
|
|
10
|
+
constructor(phrase: string, name = 'xyoWallet') {
|
|
11
|
+
this._name = name
|
|
12
|
+
this._phrase = phrase
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
public getAccount(index: number) {
|
|
16
|
+
let counter = index
|
|
17
|
+
let hash = shajs('sha256').update(this._phrase).digest().toString('hex')
|
|
18
|
+
while (counter) {
|
|
19
|
+
hash = shajs('sha256').update(hash).digest().toString('hex')
|
|
20
|
+
counter--
|
|
21
|
+
}
|
|
22
|
+
return new XyoAccount({ privateKey: hash })
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
public static async generate() {
|
|
26
|
+
//delay is here to prep for archivist load
|
|
27
|
+
await delay(0)
|
|
28
|
+
const wordList: string[] = []
|
|
29
|
+
while (wordList.length < 16) {
|
|
30
|
+
const index = Math.floor(Math.random() * Words.words.length)
|
|
31
|
+
wordList.push(Words.words[index])
|
|
32
|
+
}
|
|
33
|
+
return new XyoWalletBase(wordList.join(' '))
|
|
34
|
+
}
|
|
35
|
+
}
|