@witnet/sdk 1.0.0-beta.5 → 1.0.1

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.
Files changed (40) hide show
  1. package/dist/package.json +3 -1
  2. package/dist/src/bin/helpers.d.ts +1 -0
  3. package/dist/src/bin/helpers.d.ts.map +1 -1
  4. package/dist/src/bin/helpers.js +11 -1
  5. package/dist/src/lib/crypto/interfaces.d.ts +7 -0
  6. package/dist/src/lib/crypto/interfaces.d.ts.map +1 -1
  7. package/dist/src/lib/crypto/interfaces.js +1 -1
  8. package/dist/src/lib/crypto/payloads.d.ts.map +1 -1
  9. package/dist/src/lib/crypto/payloads.js +1 -12
  10. package/dist/src/lib/crypto/signer.d.ts +8 -1
  11. package/dist/src/lib/crypto/signer.d.ts.map +1 -1
  12. package/dist/src/lib/crypto/signer.js +23 -2
  13. package/dist/src/lib/crypto/types.d.ts +2 -2
  14. package/dist/src/lib/crypto/types.d.ts.map +1 -1
  15. package/dist/src/lib/crypto/types.js +4 -5
  16. package/dist/src/lib/crypto/utils.d.ts +2 -1
  17. package/dist/src/lib/crypto/utils.d.ts.map +1 -1
  18. package/dist/src/lib/crypto/utils.js +6 -1
  19. package/dist/src/lib/crypto/wallet.d.ts.map +1 -1
  20. package/dist/src/lib/crypto/wallet.js +1 -4
  21. package/dist/src/lib/utils.d.ts +3 -2
  22. package/dist/src/lib/utils.d.ts.map +1 -1
  23. package/dist/src/lib/utils.js +16 -9
  24. package/dist/witnet/assets/index.d.ts +6 -6
  25. package/dist/witnet/assets/modals/index.d.ts +10 -11
  26. package/dist/witnet/assets/modals/index.js +2 -12
  27. package/dist/witnet/assets/modals/web3/ipfs.d.ts +5 -0
  28. package/dist/witnet/assets/modals/web3/ipfs.d.ts.map +1 -0
  29. package/dist/witnet/assets/modals/web3/ipfs.js +16 -0
  30. package/dist/witnet/assets/modals/web3/wit.d.ts +1 -1
  31. package/dist/witnet/assets/modals/web3/wit.js +4 -4
  32. package/dist/witnet/assets/requests.js +1 -1
  33. package/package.json +3 -1
  34. package/src/bin/cli/radon.js +3 -3
  35. package/src/bin/cli/wallet.js +124 -30
  36. package/src/bin/helpers.js +12 -1
  37. package/witnet/assets/modals/index.js +1 -17
  38. package/witnet/assets/modals/web3/ipfs.js +19 -0
  39. package/witnet/assets/modals/web3/wit.js +3 -3
  40. package/witnet/assets/requests.js +1 -0
@@ -17,7 +17,6 @@ class TransactionPayload {
17
17
  get bytecode() {
18
18
  // make toProtobuf return Protobuf's deserialized message
19
19
  const obj = this.toProtobuf();
20
- // console.log("TransactionPayload<Specs>.bytecode() =>", obj)
21
20
  if (!obj)
22
21
  return undefined;
23
22
  const err = this._protoType.verify(obj);
@@ -81,8 +80,6 @@ class TransactionPayloadMultiSig extends TransactionPayload {
81
80
  }
82
81
  const prepared = this.prepared;
83
82
  if (!this.covered) {
84
- // console.log(ledger.constructor.name, "cacheInfo =>", ledger.pkh, ledger.cacheInfo)
85
- // console.log(await ledger.getUtxos())
86
83
  // consume utxos as to cover this.value, at least
87
84
  const utxos = await ledger.selectUtxos({
88
85
  value: types_1.Coins.fromPedros(this.value.pedros - this._covered),
@@ -93,22 +90,16 @@ class TransactionPayloadMultiSig extends TransactionPayload {
93
90
  ledger.consumeUtxos(...utxos);
94
91
  // try to cover fees only if this.value is covered first
95
92
  if (this._covered >= this.value.pedros) {
96
- // console.log(this._inputs)
97
- // console.log("remaining utxos =>", await ledger.getUtxos())
98
93
  if (this._target?.fees instanceof types_1.Coins) {
99
94
  this._fees = this._target.fees.pedros;
100
- // console.log(this._covered, this.value.pedros, this._fees, this._covered < this.value.pedros + this._fees)
101
95
  if (this._covered < this.value.pedros + this._fees) {
102
- // console.log("more utxos required...")
103
96
  const extras = await ledger.selectUtxos({
104
97
  value: types_1.Coins.fromPedros(this.value.pedros + this._fees - this._covered),
105
98
  });
106
99
  ledger.consumeUtxos(...extras);
107
- this._covered += extras.map(utxo => utxo.value).reduce((prev, curr) => prev + curr);
108
100
  this._inputs.push(...extras);
109
101
  }
110
102
  this._change = this._covered - (this.value.pedros + this._fees);
111
- // console.log(this._change)
112
103
  }
113
104
  else {
114
105
  const priority = this._target?.fees || types_1.TransactionPriority.Opulent;
@@ -141,8 +132,6 @@ class TransactionPayloadMultiSig extends TransactionPayload {
141
132
  }
142
133
  // prepare outputs, only if value and fees got fully covered for the first time:
143
134
  if (this._change >= 0 && !prepared) {
144
- // console.log('-'.repeat(80))
145
- // console.log(this._inputs)
146
135
  this.prepareOutputs({ value: this._change, pkh: ledger.changePkh });
147
136
  }
148
137
  return this._change;
@@ -167,4 +156,4 @@ class TransactionPayloadMultiSig extends TransactionPayload {
167
156
  }
168
157
  }
169
158
  exports.TransactionPayloadMultiSig = TransactionPayloadMultiSig;
170
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"payloads.js","sourceRoot":"","sources":["../../../../src/lib/crypto/payloads.ts"],"names":[],"mappings":"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","sourcesContent":["import { Type as ProtoType, Root as ProtoRoot } from \"protobufjs\"\r\nconst protoRoot = ProtoRoot.fromJSON(require(\"../../../witnet/witnet.proto.json\"))\r\n\r\nimport { Hash, NetworkPriorities, ValueTransferOutput } from \"../types\"\r\nimport { toHexString } from \"../utils\"\r\n\r\nimport { ILedger, IJsonRpcProvider, ITransactionPayload, ITransactionPayloadMultiSig } from \"./interfaces\"\r\nimport { sha256 } from \"./utils\"\r\nimport { Coins, PublicKeyHashString, TransactionPriority, Utxo } from \"./types\";\r\n\r\nexport abstract class TransactionPayload<Specs> implements ITransactionPayload<Specs> {\r\n \r\n    protected _change: bigint;\r\n    protected _covered: bigint;\r\n    protected _fees: bigint;\r\n    protected _priorities?: NetworkPriorities;\r\n    protected _protoType: ProtoType;\r\n    protected _target?: Specs;\r\n    \r\n    constructor(protoTypeName: string, initialTarget?: Specs) {\r\n        this._protoType = protoRoot.lookupType(protoTypeName)\r\n        this._target = this.validateTarget(initialTarget)\r\n        this._change = 0n\r\n        this._covered = 0n\r\n        this._fees = 0n\r\n    }\r\n\r\n    public get bytecode(): Uint8Array | undefined {\r\n        // make toProtobuf return Protobuf's deserialized message\r\n        const obj = this.toProtobuf()\r\n        // console.log(\"TransactionPayload<Specs>.bytecode() =>\", obj)\r\n        if (!obj) return undefined\r\n\r\n        const err = this._protoType.verify(obj)\r\n        if (err) {\r\n            throw TypeError(err)\r\n        } else {\r\n            // console.log(\"\\nobj =>\", JSON.stringify(obj))\r\n            const message = this._protoType.fromObject(obj)\r\n            // console.log(\"\\nmessage =>\", JSON.stringify(message))\r\n            const bytecode = this._protoType.encode(message).finish()\r\n            // console.log(\"\\nbytecode =>\", toHexString(bytecode))\r\n            return bytecode\r\n        }\r\n    }\r\n\r\n    public get change(): Coins | undefined {\r\n        return this._change > 0 ? Coins.fromPedros(this._change) : undefined\r\n    }\r\n\r\n    public get covered(): boolean {\r\n        return (\r\n            !!this.fees\r\n                && this._covered >= this.value.pedros + this.fees.pedros\r\n        )\r\n    }\r\n\r\n    public get fees(): Coins | undefined {\r\n        return this._fees > 0 ? Coins.fromPedros(this._fees) : undefined\r\n    }\r\n\r\n    public get hash(): Hash | undefined {\r\n        const _bytecode = this.bytecode\r\n        if (_bytecode instanceof Uint8Array) {\r\n            return toHexString(sha256(_bytecode))\r\n        } else {\r\n            return undefined\r\n        }\r\n    }\r\n\r\n    public intoReceipt(target: Specs): any {\r\n        return {\r\n            ...target\r\n        }\r\n    }\r\n\r\n    abstract consumeUtxos(ledger: ILedger): Promise<bigint>;\r\n    abstract prepareOutputs(change?: { value: bigint, pkh: PublicKeyHashString }, params?: any): any;\r\n    abstract resetTarget(target: Specs): any;\r\n    abstract toJSON(humanize: boolean): any;\r\n    abstract toProtobuf(): any;\r\n    abstract validateTarget(target?: any): Specs | undefined;\r\n\r\n    abstract get outputs(): Array<ValueTransferOutput>;\r\n    abstract get maxWeight(): number;\r\n    abstract get prepared(): boolean;\r\n    abstract get value(): Coins;\r\n    abstract get weight(): number;\r\n\r\n    protected abstract _cleanTargetExtras(params?: any): any;\r\n    protected abstract _estimateNetworkFees(provider: IJsonRpcProvider, priority?: TransactionPriority): Promise<bigint>;\r\n}\r\n\r\nexport abstract class TransactionPayloadMultiSig<Specs> \r\n    extends TransactionPayload<Specs>\r\n    implements ITransactionPayloadMultiSig<Specs>\r\n{\r\n    protected _inputs: Array<Utxo>\r\n    protected _outputs: Array<ValueTransferOutput>\r\n    \r\n    constructor(protoTypeName: string, initialTarget?: Specs) {\r\n        super(protoTypeName, initialTarget)\r\n        this._inputs = []\r\n        this._outputs = []\r\n    }\r\n\r\n    public get inputs(): Array<Utxo> {\r\n        return this._inputs\r\n    }\r\n\r\n    public get outputs(): Array<ValueTransferOutput> {\r\n        return this._outputs\r\n    }\r\n\r\n    public get prepared(): boolean {\r\n        return (\r\n            this._inputs.length > 0 \r\n                && this._outputs.length > 0\r\n        )\r\n    }\r\n\r\n    public async consumeUtxos(ledger: ILedger, reload?: boolean): Promise<bigint> {\r\n        if (!this._target) {\r\n            throw new Error(`${this.constructor.name}: internal error: no in-flight params.`)\r\n        } \r\n        const prepared = this.prepared\r\n        if (!this.covered) {\r\n            // console.log(ledger.constructor.name, \"cacheInfo =>\", ledger.pkh, ledger.cacheInfo)\r\n            // console.log(await ledger.getUtxos())\r\n            \r\n            // consume utxos as to cover this.value, at least\r\n            const utxos = await ledger.selectUtxos({ \r\n                value: Coins.fromPedros(this.value.pedros - this._covered), \r\n                reload,\r\n            })\r\n            this._covered += utxos.map(utxo => utxo.value).reduce((prev, curr) => prev + curr, 0n)\r\n            this._inputs.push(...utxos)\r\n            ledger.consumeUtxos(...utxos)\r\n\r\n            // try to cover fees only if this.value is covered first\r\n            if (this._covered >= this.value.pedros) {\r\n                // console.log(this._inputs)\r\n                // console.log(\"remaining utxos =>\", await ledger.getUtxos())\r\n                if ((this._target as any)?.fees instanceof Coins) {\r\n                    this._fees = (this._target as any).fees.pedros;\r\n                    // console.log(this._covered, this.value.pedros, this._fees, this._covered < this.value.pedros + this._fees)\r\n                    if (this._covered < this.value.pedros + this._fees) {\r\n                        // console.log(\"more utxos required...\")\r\n                        const extras = await ledger.selectUtxos({ \r\n                            value: Coins.fromPedros(this.value.pedros + this._fees  - this._covered),\r\n                        })\r\n                        ledger.consumeUtxos(...extras)\r\n                        this._covered += extras.map(utxo => utxo.value).reduce((prev, curr) => prev + curr)\r\n                        this._inputs.push(...extras)\r\n                    }\r\n                    this._change = this._covered - (this.value.pedros + this._fees)\r\n                    // console.log(this._change)\r\n                } else {\r\n                    const priority = (this._target as any)?.fees as TransactionPriority || TransactionPriority.Opulent\r\n                    let estimatedFees = await this._estimateNetworkFees(ledger.provider, priority);\r\n                    while (this._fees < estimatedFees) {\r\n                        this._fees = estimatedFees\r\n                        this._outputs = []\r\n                        // add more utxos only if the ones selected for covering the value and the estimate fees don't suffice:\r\n                        if (this._covered < this.value.pedros + this._fees) {\r\n                            const extras = await ledger.selectUtxos({ \r\n                                value: Coins.fromPedros(this.value.pedros + this._fees - this._covered)\r\n                            })\r\n                            ledger.consumeUtxos(...extras)\r\n                            this._covered += extras.map(utxo => utxo.value).reduce((prev, curr) => prev + curr)\r\n                            this._inputs.push(...extras)\r\n                        }\r\n                        this._change = this._covered - (this.value.pedros + this._fees)\r\n                        if (this._change < 0) {\r\n                            // insufficient funds ...\r\n                            break\r\n                        } else {\r\n                            this.prepareOutputs({ value: this._change, pkh: ledger.changePkh })\r\n                            // iterate until actual fees match estimated fees\r\n                            estimatedFees = await this._estimateNetworkFees(ledger.provider, priority)\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n        }\r\n        // prepare outputs, only if value and fees got fully covered for the first time:\r\n        if (this._change >= 0 && !prepared) {\r\n            // console.log('-'.repeat(80))\r\n            // console.log(this._inputs)\r\n            this.prepareOutputs({ value: this._change, pkh: ledger.changePkh })\r\n        }\r\n        return this._change\r\n    }\r\n\r\n    public prepareOutputs(change?: { value: bigint, pkh: PublicKeyHashString }): any {\r\n        if (change?.value) {\r\n            this._outputs.push({\r\n                pkh: change.pkh,\r\n                value: change.value,\r\n                time_lock: 0,\r\n            })\r\n        }\r\n    }\r\n\r\n    public resetTarget(target: Specs): any {\r\n        this._change = 0n\r\n        this._covered = 0n\r\n        this._fees = 0n\r\n        this._inputs = []\r\n        this._outputs = []\r\n        this._target = target\r\n        delete this._priorities\r\n    }\r\n\r\n    abstract toJSON(humanize: boolean): any;\r\n    abstract toProtobuf(): any;\r\n    abstract validateTarget(target?: any): Specs | undefined;\r\n\r\n    abstract get maxWeight(): number;\r\n    abstract get value(): Coins;\r\n    abstract get weight(): number;\r\n    \r\n    protected abstract _cleanTargetExtras(params?: any): any;\r\n}\r\n"]}
159
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"payloads.js","sourceRoot":"","sources":["../../../../src/lib/crypto/payloads.ts"],"names":[],"mappings":"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","sourcesContent":["import { Type as ProtoType, Root as ProtoRoot } from \"protobufjs\"\r\nconst protoRoot = ProtoRoot.fromJSON(require(\"../../../witnet/witnet.proto.json\"))\r\n\r\nimport { Hash, NetworkPriorities, ValueTransferOutput } from \"../types\"\r\nimport { toHexString } from \"../utils\"\r\n\r\nimport { ILedger, IJsonRpcProvider, ITransactionPayload, ITransactionPayloadMultiSig } from \"./interfaces\"\r\nimport { sha256 } from \"./utils\"\r\nimport { Coins, PublicKeyHashString, TransactionPriority, Utxo } from \"./types\";\r\n\r\nexport abstract class TransactionPayload<Specs> implements ITransactionPayload<Specs> {\r\n \r\n    protected _change: bigint;\r\n    protected _covered: bigint;\r\n    protected _fees: bigint;\r\n    protected _priorities?: NetworkPriorities;\r\n    protected _protoType: ProtoType;\r\n    protected _target?: Specs;\r\n    \r\n    constructor(protoTypeName: string, initialTarget?: Specs) {\r\n        this._protoType = protoRoot.lookupType(protoTypeName)\r\n        this._target = this.validateTarget(initialTarget)\r\n        this._change = 0n\r\n        this._covered = 0n\r\n        this._fees = 0n\r\n    }\r\n\r\n    public get bytecode(): Uint8Array | undefined {\r\n        // make toProtobuf return Protobuf's deserialized message\r\n        const obj = this.toProtobuf()\r\n        \r\n        if (!obj) return undefined\r\n        \r\n        const err = this._protoType.verify(obj)\r\n        if (err) {\r\n            throw TypeError(err)\r\n        } else {\r\n            // console.log(\"\\nobj =>\", JSON.stringify(obj))\r\n            const message = this._protoType.fromObject(obj)\r\n            // console.log(\"\\nmessage =>\", JSON.stringify(message))\r\n            const bytecode = this._protoType.encode(message).finish()\r\n            // console.log(\"\\nbytecode =>\", toHexString(bytecode))\r\n            return bytecode\r\n        }\r\n    }\r\n\r\n    public get change(): Coins | undefined {\r\n        return this._change > 0 ? Coins.fromPedros(this._change) : undefined\r\n    }\r\n\r\n    public get covered(): boolean {\r\n        return (\r\n            !!this.fees\r\n                && this._covered >= this.value.pedros + this.fees.pedros\r\n        )\r\n    }\r\n\r\n    public get fees(): Coins | undefined {\r\n        return this._fees > 0 ? Coins.fromPedros(this._fees) : undefined\r\n    }\r\n\r\n    public get hash(): Hash | undefined {\r\n        const _bytecode = this.bytecode\r\n        if (_bytecode instanceof Uint8Array) {\r\n            return toHexString(sha256(_bytecode))\r\n        } else {\r\n            return undefined\r\n        }\r\n    }\r\n\r\n    public intoReceipt(target: Specs): any {\r\n        return {\r\n            ...target\r\n        }\r\n    }\r\n\r\n    abstract consumeUtxos(ledger: ILedger): Promise<bigint>;\r\n    abstract prepareOutputs(change?: { value: bigint, pkh: PublicKeyHashString }, params?: any): any;\r\n    abstract resetTarget(target: Specs): any;\r\n    abstract toJSON(humanize: boolean): any;\r\n    abstract toProtobuf(): any;\r\n    abstract validateTarget(target?: any): Specs | undefined;\r\n\r\n    abstract get outputs(): Array<ValueTransferOutput>;\r\n    abstract get maxWeight(): number;\r\n    abstract get prepared(): boolean;\r\n    abstract get value(): Coins;\r\n    abstract get weight(): number;\r\n\r\n    protected abstract _cleanTargetExtras(params?: any): any;\r\n    protected abstract _estimateNetworkFees(provider: IJsonRpcProvider, priority?: TransactionPriority): Promise<bigint>;\r\n}\r\n\r\nexport abstract class TransactionPayloadMultiSig<Specs> \r\n    extends TransactionPayload<Specs>\r\n    implements ITransactionPayloadMultiSig<Specs>\r\n{\r\n    protected _inputs: Array<Utxo>\r\n    protected _outputs: Array<ValueTransferOutput>\r\n    \r\n    constructor(protoTypeName: string, initialTarget?: Specs) {\r\n        super(protoTypeName, initialTarget)\r\n        this._inputs = []\r\n        this._outputs = []\r\n    }\r\n\r\n    public get inputs(): Array<Utxo> {\r\n        return this._inputs\r\n    }\r\n\r\n    public get outputs(): Array<ValueTransferOutput> {\r\n        return this._outputs\r\n    }\r\n\r\n    public get prepared(): boolean {\r\n        return (\r\n            this._inputs.length > 0 \r\n                && this._outputs.length > 0\r\n        )\r\n    }\r\n\r\n    public async consumeUtxos(ledger: ILedger, reload?: boolean): Promise<bigint> {\r\n        if (!this._target) {\r\n            throw new Error(`${this.constructor.name}: internal error: no in-flight params.`)\r\n        } \r\n        const prepared = this.prepared\r\n        if (!this.covered) {\r\n            \r\n            // consume utxos as to cover this.value, at least\r\n            const utxos = await ledger.selectUtxos({ \r\n                value: Coins.fromPedros(this.value.pedros - this._covered), \r\n                reload,\r\n            })\r\n            this._covered += utxos.map(utxo => utxo.value).reduce((prev, curr) => prev + curr, 0n)\r\n            this._inputs.push(...utxos)\r\n            ledger.consumeUtxos(...utxos)\r\n\r\n            // try to cover fees only if this.value is covered first\r\n            if (this._covered >= this.value.pedros) {\r\n                if ((this._target as any)?.fees instanceof Coins) {\r\n                    this._fees = (this._target as any).fees.pedros;\r\n                    if (this._covered < this.value.pedros + this._fees) {\r\n                        const extras = await ledger.selectUtxos({ \r\n                            value: Coins.fromPedros(this.value.pedros + this._fees  - this._covered),\r\n                        })\r\n                        ledger.consumeUtxos(...extras)\r\n                        this._inputs.push(...extras)\r\n                    }\r\n                    this._change = this._covered - (this.value.pedros + this._fees)\r\n                } else {\r\n                    const priority = (this._target as any)?.fees as TransactionPriority || TransactionPriority.Opulent\r\n                    let estimatedFees = await this._estimateNetworkFees(ledger.provider, priority);\r\n                    while (this._fees < estimatedFees) {\r\n                        this._fees = estimatedFees\r\n                        this._outputs = []\r\n                        // add more utxos only if the ones selected for covering the value and the estimate fees don't suffice:\r\n                        if (this._covered < this.value.pedros + this._fees) {\r\n                            const extras = await ledger.selectUtxos({ \r\n                                value: Coins.fromPedros(this.value.pedros + this._fees - this._covered)\r\n                            })\r\n                            ledger.consumeUtxos(...extras)\r\n                            this._covered += extras.map(utxo => utxo.value).reduce((prev, curr) => prev + curr)\r\n                            this._inputs.push(...extras)\r\n                        }\r\n                        this._change = this._covered - (this.value.pedros + this._fees)\r\n                        if (this._change < 0) {\r\n                            // insufficient funds ...\r\n                            break\r\n                        } else {\r\n                            this.prepareOutputs({ value: this._change, pkh: ledger.changePkh })\r\n                            // iterate until actual fees match estimated fees\r\n                            estimatedFees = await this._estimateNetworkFees(ledger.provider, priority)\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n        }\r\n        // prepare outputs, only if value and fees got fully covered for the first time:\r\n        if (this._change >= 0 && !prepared) {\r\n            this.prepareOutputs({ value: this._change, pkh: ledger.changePkh })\r\n        }\r\n        return this._change\r\n    }\r\n\r\n    public prepareOutputs(change?: { value: bigint, pkh: PublicKeyHashString }): any {\r\n        if (change?.value) {\r\n            this._outputs.push({\r\n                pkh: change.pkh,\r\n                value: change.value,\r\n                time_lock: 0,\r\n            })\r\n        }\r\n    }\r\n\r\n    public resetTarget(target: Specs): any {\r\n        this._change = 0n\r\n        this._covered = 0n\r\n        this._fees = 0n\r\n        this._inputs = []\r\n        this._outputs = []\r\n        this._target = target\r\n        delete this._priorities\r\n    }\r\n\r\n    abstract toJSON(humanize: boolean): any;\r\n    abstract toProtobuf(): any;\r\n    abstract validateTarget(target?: any): Specs | undefined;\r\n\r\n    abstract get maxWeight(): number;\r\n    abstract get value(): Coins;\r\n    abstract get weight(): number;\r\n    \r\n    protected abstract _cleanTargetExtras(params?: any): any;\r\n}\r\n"]}
@@ -1,4 +1,4 @@
1
- import { Balance, Network, QueryStakesOrder, StakeEntry } from "../types";
1
+ import { Balance, HexString, Network, QueryStakesOrder, StakeEntry } from "../types";
2
2
  import { IBIP32, IJsonRpcProvider, ISigner } from "./interfaces";
3
3
  import { Coins, KeyedSignature, PublicKey, PublicKeyHashString, Utxo, UtxoCacheInfo, UtxoSelectionStrategy } from "./types";
4
4
  export declare class Signer implements ISigner {
@@ -27,7 +27,14 @@ export declare class Signer implements ISigner {
27
27
  reload?: boolean;
28
28
  strategy?: UtxoSelectionStrategy;
29
29
  }): Promise<Array<Utxo>>;
30
+ authorizeEvmAddress(evmAddress: HexString): any;
30
31
  getStakeEntryNonce(validator: PublicKeyHashString): Promise<number>;
31
32
  signHash(hash: any): KeyedSignature;
33
+ signMessage(text: string): {
34
+ address: string;
35
+ message: string;
36
+ publicKey: HexString;
37
+ signature: HexString;
38
+ };
32
39
  }
33
40
  //# sourceMappingURL=signer.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"signer.d.ts","sourceRoot":"","sources":["../../../../src/lib/crypto/signer.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,gBAAgB,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;AACzE,OAAO,EAAE,MAAM,EAAE,gBAAgB,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AAChE,OAAO,EAAE,KAAK,EAAE,cAAc,EAAE,SAAS,EAAE,mBAAmB,EAAE,IAAI,EAAE,aAAa,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAA;AAG3H,qBAAa,MAAO,YAAW,OAAO;IAElC,SAAS,CAAC,IAAI,EAAE,MAAM,CAAC;IACvB,SAAS,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,CAAK;IACjC,OAAO,CAAC,YAAY,CAAU;IAE9B,SAAgB,QAAQ,EAAE,gBAAgB,CAAA;IACnC,QAAQ,EAAE,qBAAqB,CAAA;gBAGlC,IAAI,EAAE,MAAM,EACZ,QAAQ,EAAE,gBAAgB,EAC1B,QAAQ,CAAC,EAAE,qBAAqB;IAcpC,IAAW,SAAS,IAAI,aAAa,CAepC;IAED,IAAW,SAAS,IAAI,mBAAmB,CAE1C;IAED,IAAW,OAAO,IAAI,OAAO,CAE5B;IAED,IAAW,GAAG,IAAI,mBAAmB,CAEpC;IAED,IAAW,SAAS,IAAI,SAAS,CAEhC;IAEM,QAAQ,CAAC,GAAG,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,GAAG;QAAE,QAAQ,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;QAAC,QAAQ,EAAE,KAAK,CAAC,IAAI,CAAC,CAAA;KAAE;IAqBjF,YAAY,CAAC,GAAG,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC;IAc1C,UAAU,IAAI,OAAO,CAAC,OAAO,CAAC;IAI9B,aAAa,CAAC,KAAK,CAAC,EAAE,gBAAgB,GAAG,OAAO,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;IAOzE,SAAS,CAAC,GAAG,CAAC,EAAE,mBAAmB,GAAG,OAAO,GAAG,SAAS;IAInD,QAAQ,CAAC,MAAM,UAAQ,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAS9C,WAAW,CAAC,KAAK,CAAC,EAAE;QAC7B,KAAK,CAAC,EAAE,KAAK,CAAC;QACd,MAAM,CAAC,EAAE,OAAO,CAAC;QACjB,QAAQ,CAAC,EAAE,qBAAqB,CAAA;KACnC,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IASX,kBAAkB,CAAC,SAAS,EAAE,mBAAmB,GAAG,OAAO,CAAC,MAAM,CAAC;IAQzE,QAAQ,CAAC,IAAI,EAAE,GAAG,GAAG,cAAc;CAiC7C"}
1
+ {"version":3,"file":"signer.d.ts","sourceRoot":"","sources":["../../../../src/lib/crypto/signer.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,gBAAgB,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;AACpF,OAAO,EAAE,MAAM,EAAE,gBAAgB,EAAE,OAAO,EAAE,MAAM,cAAc,CAAA;AAChE,OAAO,EAAE,KAAK,EAAE,cAAc,EAAE,SAAS,EAAE,mBAAmB,EAAwB,IAAI,EAAE,aAAa,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAA;AAGjJ,qBAAa,MAAO,YAAW,OAAO;IAElC,SAAS,CAAC,IAAI,EAAE,MAAM,CAAC;IACvB,SAAS,CAAC,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,CAAK;IACjC,OAAO,CAAC,YAAY,CAAU;IAE9B,SAAgB,QAAQ,EAAE,gBAAgB,CAAA;IACnC,QAAQ,EAAE,qBAAqB,CAAA;gBAGlC,IAAI,EAAE,MAAM,EACZ,QAAQ,EAAE,gBAAgB,EAC1B,QAAQ,CAAC,EAAE,qBAAqB;IAcpC,IAAW,SAAS,IAAI,aAAa,CAepC;IAED,IAAW,SAAS,IAAI,mBAAmB,CAE1C;IAED,IAAW,OAAO,IAAI,OAAO,CAE5B;IAED,IAAW,GAAG,IAAI,mBAAmB,CAEpC;IAED,IAAW,SAAS,IAAI,SAAS,CAEhC;IAEM,QAAQ,CAAC,GAAG,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,GAAG;QAAE,QAAQ,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;QAAC,QAAQ,EAAE,KAAK,CAAC,IAAI,CAAC,CAAA;KAAE;IAqBjF,YAAY,CAAC,GAAG,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC,IAAI,CAAC;IAa1C,UAAU,IAAI,OAAO,CAAC,OAAO,CAAC;IAI9B,aAAa,CAAC,KAAK,CAAC,EAAE,gBAAgB,GAAG,OAAO,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;IAOzE,SAAS,CAAC,GAAG,CAAC,EAAE,mBAAmB,GAAG,OAAO,GAAG,SAAS;IAInD,QAAQ,CAAC,MAAM,UAAQ,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IAS9C,WAAW,CAAC,KAAK,CAAC,EAAE;QAC7B,KAAK,CAAC,EAAE,KAAK,CAAC;QACd,MAAM,CAAC,EAAE,OAAO,CAAC;QACjB,QAAQ,CAAC,EAAE,qBAAqB,CAAA;KACnC,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IASjB,mBAAmB,CAAC,UAAU,EAAE,SAAS,GAAG,GAAG;IAWzC,kBAAkB,CAAC,SAAS,EAAE,mBAAmB,GAAG,OAAO,CAAC,MAAM,CAAC;IAQzE,QAAQ,CAAC,IAAI,EAAE,GAAG,GAAG,cAAc;IAkCnC,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG;QAC9B,OAAO,EAAE,MAAM,CAAC;QAChB,OAAO,EAAE,MAAM,CAAC;QAChB,SAAS,EAAE,SAAS,CAAC;QACrB,SAAS,EAAE,SAAS,CAAA;KACvB;CAUJ"}
@@ -34,6 +34,8 @@ var __importStar = (this && this.__importStar) || (function () {
34
34
  })();
35
35
  Object.defineProperty(exports, "__esModule", { value: true });
36
36
  exports.Signer = void 0;
37
+ const ethers = require('ethers');
38
+ const keccak256 = require('keccak256');
37
39
  const secp256k1 = require('secp256k1');
38
40
  const utils = __importStar(require("../utils"));
39
41
  const types_1 = require("./types");
@@ -114,7 +116,6 @@ class Signer {
114
116
  return true;
115
117
  }
116
118
  });
117
- // console.log("Signer.consumeUtxos: remaining:", utxos)
118
119
  return utxos;
119
120
  }
120
121
  async getBalance() {
@@ -144,6 +145,16 @@ class Signer {
144
145
  }
145
146
  // ================================================================================================================
146
147
  // --- ISigner ----------------------------------------------------------------------------------------------------
148
+ authorizeEvmAddress(evmAddress) {
149
+ const addr = utils.fromHexString(evmAddress);
150
+ const hash = keccak256(Buffer.from(addr));
151
+ if (this.node.privateKey) {
152
+ const signingKey = new ethers.utils.SigningKey(this.node.privateKey);
153
+ const signature = signingKey.signDigest(hash);
154
+ const sig = `0x${signature.r.slice(2)}${signature.s.slice(2)}${signature.v.toString(16)}`;
155
+ return sig;
156
+ }
157
+ }
147
158
  async getStakeEntryNonce(validator) {
148
159
  return this.provider
149
160
  .stakes({ filter: {
@@ -189,6 +200,16 @@ class Signer {
189
200
  throw Error(`Signer: invalid BIP32 node: no private key`);
190
201
  }
191
202
  }
203
+ signMessage(text) {
204
+ const digest = utils.digestMessage(text);
205
+ const keyedSignature = this.signHash(digest);
206
+ return {
207
+ address: this.pkh,
208
+ message: text,
209
+ publicKey: types_1.PublicKey.fromProtobuf(keyedSignature.public_key).toHexString(),
210
+ signature: types_1.RecoverableSignature.fromKeyedSignature(keyedSignature, digest).toHexString(),
211
+ };
212
+ }
192
213
  }
193
214
  exports.Signer = Signer;
194
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signer.js","sourceRoot":"","sources":["../../../../src/lib/crypto/signer.ts"],"names":[],"mappings":"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","sourcesContent":["const secp256k1 = require('secp256k1')\r\nimport * as utils from \"../utils\"\r\n\r\nimport { Balance, Network, QueryStakesOrder, StakeEntry } from \"../types\"\r\nimport { IBIP32, IJsonRpcProvider, ISigner } from \"./interfaces\"\r\nimport { Coins, KeyedSignature, PublicKey, PublicKeyHashString, Utxo, UtxoCacheInfo, UtxoSelectionStrategy } from \"./types\"\r\nimport { selectUtxos } from \"./utils\"\r\n\r\nexport class Signer implements ISigner {\r\n    \r\n    protected node: IBIP32;\r\n    protected utxos: Array<Utxo> = []\r\n    private _initialized: boolean;\r\n    \r\n    public readonly provider: IJsonRpcProvider\r\n    public strategy: UtxoSelectionStrategy\r\n\r\n    constructor(\r\n        node: IBIP32, \r\n        provider: IJsonRpcProvider, \r\n        strategy?: UtxoSelectionStrategy,\r\n    ) {\r\n        this.node = node\r\n        this.provider = provider\r\n        this.strategy = strategy || UtxoSelectionStrategy.SlimFit\r\n        if (!provider.network) {\r\n            throw Error(`Signer: internal error: unintialized provider.`)\r\n        }\r\n        this._initialized = false\r\n    }\r\n\r\n    // ================================================================================================================\r\n    // --- ILedger ----------------------------------------------------------------------------------------------------\r\n\r\n    public get cacheInfo(): UtxoCacheInfo {\r\n        const now = Math.floor(Date.now() / 1000)\r\n        let expendable: bigint = 0n\r\n        let timelock: number = Number.MAX_SAFE_INTEGER\r\n        this.utxos.map(utxo => {\r\n            if (utxo.timelock > now) {\r\n                if (utxo.timelock < timelock) {\r\n                    timelock = utxo.timelock\r\n                }\r\n            } else {\r\n                expendable += utxo.value\r\n            }\r\n        })\r\n        if (timelock === Number.MAX_SAFE_INTEGER) timelock = 0;\r\n        return { expendable, timelock, size: this.utxos.length }\r\n    }\r\n\r\n    public get changePkh(): PublicKeyHashString {\r\n        return this.pkh\r\n    }\r\n\r\n    public get network(): Network {\r\n        return this.provider.network || \"mainnet\"\r\n    }\r\n\r\n    public get pkh(): PublicKeyHashString {\r\n        return this.publicKey.hash().toBech32(this.network)\r\n    }\r\n\r\n    public get publicKey(): PublicKey {\r\n        return PublicKey.fromUint8Array(this.node.publicKey)\r\n    }\r\n\r\n    public addUtxos(...utxos: Array<Utxo>): { excluded: Array<Utxo>, included: Array<Utxo> } {\r\n        const excluded: Array<Utxo> = []\r\n        const existingPointers = new Set(this.utxos.map(cached => cached.output_pointer));\r\n        const included: Array<Utxo> = utxos.filter(utxo => {\r\n            if (utxo.signer === this.pkh) {\r\n                // avoid adding duplicates\r\n                if (!existingPointers.has(utxo.output_pointer)) {\r\n                    existingPointers.add(utxo.output_pointer)\r\n                    return true\r\n                } else {\r\n                    return false\r\n                }\r\n            } else {\r\n                excluded.push(utxo)\r\n                return false;\r\n            }\r\n        })\r\n        this.utxos.push(...included)\r\n        return { excluded, included }\r\n    }\r\n\r\n    public consumeUtxos(...utxos: Array<Utxo>): Array<Utxo> {\r\n        this.utxos = this.utxos.filter(cached => {\r\n            const incomingIndex = utxos.findIndex(incoming => cached.output_pointer === incoming.output_pointer);\r\n            if (incomingIndex >= 0) {\r\n                utxos.splice(incomingIndex, 1)\r\n                return false\r\n            } else {\r\n                return true\r\n            }\r\n        })\r\n        // console.log(\"Signer.consumeUtxos: remaining:\", utxos)\r\n        return utxos\r\n    }\r\n\r\n    public async getBalance(): Promise<Balance> {\r\n        return this.provider.getBalance(this.pkh)\r\n    }\r\n\r\n    public async getDelegatees(order?: QueryStakesOrder): Promise<Array<StakeEntry>> {\r\n        return this.provider.stakes({\r\n            filter: { withdrawer: this.pkh },\r\n            params: { order },\r\n        })\r\n    }\r\n\r\n    public getSigner(pkh?: PublicKeyHashString): ISigner | undefined { \r\n        return (!pkh || pkh === this.pkh) ? this : undefined\r\n    }\r\n\r\n    public async getUtxos(reload = false): Promise<Array<Utxo>> {\r\n        if (reload || !this._initialized) {\r\n            this._initialized = true\r\n            this.utxos = (await this.provider.getUtxos(this.pkh))\r\n                .map(utxo => ({ ...utxo, signer: this.pkh }))\r\n        }\r\n        return this.utxos\r\n    }\r\n\r\n    public async selectUtxos(specs?: {\r\n        value?: Coins,\r\n        reload?: boolean,\r\n        strategy?: UtxoSelectionStrategy\r\n    }): Promise<Array<Utxo>> {\r\n        return this\r\n            .getUtxos(specs?.reload)\r\n            .then(utxos => selectUtxos({ utxos, value: specs?.value, strategy: specs?.strategy || this.strategy }))\r\n    }\r\n    \r\n    // ================================================================================================================\r\n    // --- ISigner ----------------------------------------------------------------------------------------------------\r\n    \r\n    public async getStakeEntryNonce(validator: PublicKeyHashString): Promise<number> {\r\n        return this.provider\r\n            .stakes({ filter: {\r\n                validator,\r\n                withdrawer: this.pkh\r\n            }}).then(([entry]) => entry.value.nonce)\r\n    }\r\n\r\n    public signHash(hash: any): KeyedSignature {\r\n        let buffer: Buffer;\r\n        if (hash instanceof Uint8Array) {\r\n            buffer = Buffer.from(hash)\r\n        } else if (hash instanceof Buffer) {\r\n            buffer = hash\r\n        } else if (typeof hash === 'string') {\r\n            buffer = Buffer.from(utils.fromHexString(hash))           \r\n        } else {\r\n            throw new Error(`${this.constructor.name}: unsupported hash value: ${hash}`)\r\n        }\r\n        if (!buffer || buffer.length !== 32) {\r\n            throw new Error(`${this.constructor.name}: invalid hash length: ${buffer.length} != 32`)\r\n        } else if (this.node.privateKey) {\r\n            const msg = Uint8Array.from(buffer)\r\n            const privateKey = Uint8Array.from(Buffer.from(this.node.privateKey))\r\n            const signature = secp256k1.ecdsaSign(msg, privateKey).signature\r\n            const der = secp256k1.signatureExport(signature)\r\n            return {\r\n                public_key: {\r\n                    compressed: this.publicKey.compressed,\r\n                    bytes: Array.from(this.publicKey.bytes),\r\n                },\r\n                signature: {\r\n                    Secp256k1: {\r\n                        der: Array.from(der),\r\n                    }\r\n                }\r\n            }\r\n        } else {\r\n            throw Error(`Signer: invalid BIP32 node: no private key`)\r\n        }\r\n    }\r\n}\r\n"]}
215
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signer.js","sourceRoot":"","sources":["../../../../src/lib/crypto/signer.ts"],"names":[],"mappings":"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","sourcesContent":["const ethers = require('ethers')\r\nconst keccak256 = require('keccak256')\r\nconst secp256k1 = require('secp256k1')\r\n\r\nimport * as utils from \"../utils\"\r\n\r\nimport { Balance, HexString, Network, QueryStakesOrder, StakeEntry } from \"../types\"\r\nimport { IBIP32, IJsonRpcProvider, ISigner } from \"./interfaces\"\r\nimport { Coins, KeyedSignature, PublicKey, PublicKeyHashString, RecoverableSignature, Utxo, UtxoCacheInfo, UtxoSelectionStrategy } from \"./types\"\r\nimport { selectUtxos } from \"./utils\"\r\n\r\nexport class Signer implements ISigner {\r\n    \r\n    protected node: IBIP32;\r\n    protected utxos: Array<Utxo> = []\r\n    private _initialized: boolean;\r\n    \r\n    public readonly provider: IJsonRpcProvider\r\n    public strategy: UtxoSelectionStrategy\r\n\r\n    constructor(\r\n        node: IBIP32, \r\n        provider: IJsonRpcProvider, \r\n        strategy?: UtxoSelectionStrategy,\r\n    ) {\r\n        this.node = node\r\n        this.provider = provider\r\n        this.strategy = strategy || UtxoSelectionStrategy.SlimFit\r\n        if (!provider.network) {\r\n            throw Error(`Signer: internal error: unintialized provider.`)\r\n        }\r\n        this._initialized = false\r\n    }\r\n\r\n    // ================================================================================================================\r\n    // --- ILedger ----------------------------------------------------------------------------------------------------\r\n\r\n    public get cacheInfo(): UtxoCacheInfo {\r\n        const now = Math.floor(Date.now() / 1000)\r\n        let expendable: bigint = 0n\r\n        let timelock: number = Number.MAX_SAFE_INTEGER\r\n        this.utxos.map(utxo => {\r\n            if (utxo.timelock > now) {\r\n                if (utxo.timelock < timelock) {\r\n                    timelock = utxo.timelock\r\n                }\r\n            } else {\r\n                expendable += utxo.value\r\n            }\r\n        })\r\n        if (timelock === Number.MAX_SAFE_INTEGER) timelock = 0;\r\n        return { expendable, timelock, size: this.utxos.length }\r\n    }\r\n\r\n    public get changePkh(): PublicKeyHashString {\r\n        return this.pkh\r\n    }\r\n\r\n    public get network(): Network {\r\n        return this.provider.network || \"mainnet\"\r\n    }\r\n\r\n    public get pkh(): PublicKeyHashString {\r\n        return this.publicKey.hash().toBech32(this.network)\r\n    }\r\n\r\n    public get publicKey(): PublicKey {\r\n        return PublicKey.fromUint8Array(this.node.publicKey)\r\n    }\r\n\r\n    public addUtxos(...utxos: Array<Utxo>): { excluded: Array<Utxo>, included: Array<Utxo> } {\r\n        const excluded: Array<Utxo> = []\r\n        const existingPointers = new Set(this.utxos.map(cached => cached.output_pointer));\r\n        const included: Array<Utxo> = utxos.filter(utxo => {\r\n            if (utxo.signer === this.pkh) {\r\n                // avoid adding duplicates\r\n                if (!existingPointers.has(utxo.output_pointer)) {\r\n                    existingPointers.add(utxo.output_pointer)\r\n                    return true\r\n                } else {\r\n                    return false\r\n                }\r\n            } else {\r\n                excluded.push(utxo)\r\n                return false;\r\n            }\r\n        })\r\n        this.utxos.push(...included)\r\n        return { excluded, included }\r\n    }\r\n\r\n    public consumeUtxos(...utxos: Array<Utxo>): Array<Utxo> {\r\n        this.utxos = this.utxos.filter(cached => {\r\n            const incomingIndex = utxos.findIndex(incoming => cached.output_pointer === incoming.output_pointer);\r\n            if (incomingIndex >= 0) {\r\n                utxos.splice(incomingIndex, 1)\r\n                return false\r\n            } else {\r\n                return true\r\n            }\r\n        })\r\n        return utxos\r\n    }\r\n\r\n    public async getBalance(): Promise<Balance> {\r\n        return this.provider.getBalance(this.pkh)\r\n    }\r\n\r\n    public async getDelegatees(order?: QueryStakesOrder): Promise<Array<StakeEntry>> {\r\n        return this.provider.stakes({\r\n            filter: { withdrawer: this.pkh },\r\n            params: { order },\r\n        })\r\n    }\r\n\r\n    public getSigner(pkh?: PublicKeyHashString): ISigner | undefined { \r\n        return (!pkh || pkh === this.pkh) ? this : undefined\r\n    }\r\n\r\n    public async getUtxos(reload = false): Promise<Array<Utxo>> {\r\n        if (reload || !this._initialized) {\r\n            this._initialized = true\r\n            this.utxos = (await this.provider.getUtxos(this.pkh))\r\n                .map(utxo => ({ ...utxo, signer: this.pkh }))\r\n        }\r\n        return this.utxos\r\n    }\r\n\r\n    public async selectUtxos(specs?: {\r\n        value?: Coins,\r\n        reload?: boolean,\r\n        strategy?: UtxoSelectionStrategy\r\n    }): Promise<Array<Utxo>> {\r\n        return this\r\n            .getUtxos(specs?.reload)\r\n            .then(utxos => selectUtxos({ utxos, value: specs?.value, strategy: specs?.strategy || this.strategy }))\r\n    }\r\n    \r\n    // ================================================================================================================\r\n    // --- ISigner ----------------------------------------------------------------------------------------------------\r\n\r\n    public authorizeEvmAddress(evmAddress: HexString): any {\r\n        const addr = utils.fromHexString(evmAddress)\r\n        const hash = keccak256(Buffer.from(addr))\r\n        if (this.node.privateKey) {\r\n            const signingKey = new ethers.utils.SigningKey(this.node.privateKey)\r\n            const signature = signingKey.signDigest(hash)\r\n            const sig = `0x${signature.r.slice(2)}${signature.s.slice(2)}${signature.v.toString(16)}`\r\n            return sig\r\n        }\r\n    }\r\n    \r\n    public async getStakeEntryNonce(validator: PublicKeyHashString): Promise<number> {\r\n        return this.provider\r\n            .stakes({ filter: {\r\n                validator,\r\n                withdrawer: this.pkh\r\n            }}).then(([entry]) => entry.value.nonce)\r\n    }\r\n\r\n    public signHash(hash: any): KeyedSignature {\r\n        let buffer: Buffer;\r\n        if (hash instanceof Uint8Array) {\r\n            buffer = Buffer.from(hash)\r\n        } else if (hash instanceof Buffer) {\r\n            buffer = hash\r\n        } else if (typeof hash === 'string') {\r\n            buffer = Buffer.from(utils.fromHexString(hash))           \r\n        } else {\r\n            throw new Error(`${this.constructor.name}: unsupported hash value: ${hash}`)\r\n        }\r\n        if (!buffer || buffer.length !== 32) {\r\n            throw new Error(`${this.constructor.name}: invalid hash length: ${buffer.length} != 32`)\r\n        } else if (this.node.privateKey) {\r\n            const msg = Uint8Array.from(buffer)\r\n            const privateKey = Uint8Array.from(Buffer.from(this.node.privateKey))\r\n            const signature = secp256k1.ecdsaSign(msg, privateKey).signature\r\n            const der = secp256k1.signatureExport(signature)\r\n            return {\r\n                public_key: {\r\n                    compressed: this.publicKey.compressed,\r\n                    bytes: Array.from(this.publicKey.bytes),\r\n                },\r\n                signature: {\r\n                    Secp256k1: {\r\n                        der: Array.from(der),\r\n                    }\r\n                }\r\n            }\r\n        } else {\r\n            throw Error(`Signer: invalid BIP32 node: no private key`)\r\n        }\r\n    }\r\n\r\n    public signMessage(text: string): {\r\n        address: string,\r\n        message: string,\r\n        publicKey: HexString,\r\n        signature: HexString\r\n    } {\r\n        const digest = utils.digestMessage(text)\r\n        const keyedSignature = this.signHash(digest)\r\n        return {\r\n            address: this.pkh,\r\n            message: text,\r\n            publicKey: PublicKey.fromProtobuf(keyedSignature.public_key).toHexString(),\r\n            signature: RecoverableSignature.fromKeyedSignature(keyedSignature, digest).toHexString(),\r\n        }\r\n    }\r\n}"]}
@@ -109,7 +109,7 @@ export declare class PublicKey implements Key {
109
109
  constructor(compressed: number, bytes: Uint8Array);
110
110
  equals(pubKey: PublicKey): boolean;
111
111
  hash(): PublicKeyHash;
112
- toString(): string;
112
+ toHexString(): string;
113
113
  toUint8Array(): Uint8Array;
114
114
  }
115
115
  export declare class PublicKeyHash {
@@ -137,7 +137,7 @@ export declare class RecoverableSignature extends Signature {
137
137
  readonly pubKey: PublicKey;
138
138
  readonly recoveryId: number;
139
139
  constructor(pubKey: PublicKey, bytes: Uint8Array, msg: Uint8Array);
140
- toHexString(): string;
140
+ toHexString(prefix0x?: boolean): string;
141
141
  toKeyedSignature(): any;
142
142
  toProtobuf(): any;
143
143
  }
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/lib/crypto/types.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AAKxE,qBAAa,KAAK;IACd,SAAS,CAAC,KAAK,EAAE,MAAM,CAAC;WACV,WAAW,CAAC,OAAO,EAAE,OAAO,GAAG,KAAK;WAOpC,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,KAAK;WAGrC,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,KAAK;WAGjC,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,KAAK;WAW7B,IAAI,IAAI,KAAK;gBAGd,MAAM,EAAE,MAAM;IAG3B,IAAW,MAAM,IAAI,MAAM,CAE1B;IACD,IAAW,QAAQ,IAAI,MAAM,CAE5B;IACD,IAAW,IAAI,IAAI,MAAM,CAUxB;IACM,QAAQ,CAAC,QAAQ,SAAI,GAAG,MAAM;CAGxC;AAED,MAAM,MAAM,OAAO,GAAG,KAAK,CAAC,MAAM,CAAC,CAAA;AAEnC,MAAM,MAAM,cAAc,GAAG;IACzB,SAAS,EAAE;QAAE,SAAS,EAAE;YAAE,GAAG,EAAE,KAAK,CAAC,MAAM,CAAC,CAAA;SAAE,CAAA;KAAC,CAAC;IAChD,UAAU,EAAE;QACR,KAAK,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;QACrB,UAAU,EAAE,MAAM,CAAC;KACtB,CAAC;CACL,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG,SAAS,CAAA;AAE3C,UAAU,GAAG;IACT,KAAK,EAAE,UAAU,CAAC;CACrB;AAED,MAAM,WAAW,UAAW,SAAQ,GAAG;IACnC,IAAI,EAAE,SAAS,CAAC;CACnB;AAED,MAAM,WAAW,SAAU,SAAQ,GAAG;IAClC,IAAI,EAAE,QAAQ,CAAC;CAClB;AAED,MAAM,MAAM,mBAAmB,GAAG,CAAC,OAAO,EAAE,kBAAkB,EAAE,KAAK,CAAC,EAAE,GAAG,KAAK,GAAG,CAAA;AAEnF,MAAM,MAAM,iBAAiB,GAAG;IAC5B,QAAQ,CAAC,EAAE,KAAK,CAAC;IACjB,IAAI,CAAC,EAAE,mBAAmB,GAAG,KAAK,CAAC;CACtC,CAAA;AAED,oBAAY,mBAAmB;IAC3B,MAAM,WAAW;IACjB,GAAG,QAAQ;IACX,MAAM,WAAW;IACjB,IAAI,SAAS;IACb,OAAO,YAAY;CACtB;AAED,MAAM,MAAM,kBAAkB,GAAG;IAC7B,aAAa,CAAC,EAAE,SAAS,CAAC;IAC1B,UAAU,CAAC,EAAE,KAAK,CAAC;IACnB,SAAS,CAAC,EAAE,IAAI,CAAC;IACjB,UAAU,CAAC,EAAE,mBAAmB,CAAC;IACjC,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,MAAM,CAAC,EAAE,KAAK,CAAC;IACf,OAAO,CAAC,EAAE,IAAI,CAAC;IACf,KAAK,CAAC,EAAE,KAAK,CAAC;IACd,IAAI,EAAE,KAAK,CAAC;IACZ,IAAI,CAAC,EAAE,KAAK,CAAC,mBAAmB,CAAC,GAAG,mBAAmB,CAAC;IACxD,IAAI,EAAE,IAAI,CAAC;IACX,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,GAAG,CAAC;IACd,OAAO,CAAC,EAAE,SAAS,CAAC;IACpB,UAAU,CAAC,EAAE,KAAK,CAAC,CAAC,mBAAmB,EAAE,KAAK,CAAC,CAAC,CAAC;IACjD,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,MAAM,CAAC;IACb,EAAE,CAAC,EAAE,GAAG,CAAC;IACT,SAAS,CAAC,EAAE,mBAAmB,CAAC;IAChC,KAAK,CAAC,EAAE,KAAK,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,CAAC,EAAE,mBAAmB,CAAC;IACjC,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC,mBAAmB,EAAE,KAAK,CAAC,CAAC;CAC3D,CAAA;AAED,MAAM,MAAM,iBAAiB,GAAG,QAAQ,GAAG,SAAS,GAAG,SAAS,GAAG,SAAS,GAAG,OAAO,GAAG,WAAW,GAAG,WAAW,CAAC;AAEnH,MAAM,MAAM,YAAY,GAAG;IACvB,QAAQ,CAAC,EAAE,UAAU,CAAC;IACtB,IAAI,CAAC,EAAE,IAAI,CAAC;IACZ,OAAO,EAAE,GAAG,CAAC;CAChB,CAAA;AAED,MAAM,MAAM,IAAI,GAAG,YAAY,GAAG;IAAE,MAAM,EAAE,mBAAmB,CAAA;CAAE,CAAA;AAEjE,MAAM,MAAM,aAAa,GAAG;IAExB,UAAU,EAAE,MAAM,CAAC;IAEnB,IAAI,EAAE,MAAM,CAAC;IAEb,QAAQ,EAAE,MAAM,CAAC;CACpB,CAAA;AAED,MAAM,MAAM,WAAW,GAAG;IAEtB,cAAc,EAAE,IAAI,CAAC;IAErB,YAAY,EAAE,MAAM,CAAC;CACxB,CAAC;AAEF,oBAAY,qBAAqB;IAC7B,QAAQ,cAAc;IACtB,MAAM,WAAW;IACjB,OAAO,aAAa;IACpB,UAAU,gBAAgB;CAC7B;AAOD,qBAAa,SAAU,YAAW,GAAG;IAEjC,SAAgB,UAAU,EAAE,MAAM,CAAC;IACnC,SAAgB,KAAK,EAAE,UAAU,CAAC;IAElC,MAAM,CAAC,YAAY,CAAC,QAAQ,EAAE;QAAE,UAAU,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,KAAK,CAAC,MAAM,CAAC,CAAA;KAAE,GAAG,SAAS;IAItF,MAAM,CAAC,cAAc,CAAC,UAAU,EAAE,UAAU,GAAG,SAAS;IAOxD,MAAM,CAAC,WAAW,CAAC,WAAW,EAAE,GAAG,EAAE,GAAG,EAAE,UAAU,GAAG,SAAS;gBAkBpD,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,UAAU;IAK1C,MAAM,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO;IAIlC,IAAI,IAAI,aAAa;IAIrB,QAAQ,IAAI,MAAM;IAIlB,YAAY,IAAI,UAAU;CAGpC;AAID,qBAAa,aAAa;IAEtB,MAAM,CAAC,QAAQ,CAAC,IAAI,EAAE,UAAU,GAAG,aAAa;IAIhD,MAAM,CAAC,aAAa,CAAC,IAAI,EAAE,SAAS,GAAG,aAAa;IAIpD,MAAM,CAAC,aAAa,CAAC,EAAE,EAAE,SAAS,GAAG,aAAa;IAQlD,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,aAAa;IAe7C,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC;gBAEd,KAAK,EAAE,MAAM,EAAE;IAIpB,QAAQ,CAAC,OAAO,SAAY,GAAG,MAAM;IAIrC,SAAS,IAAI,UAAU;IAIvB,SAAS,IAAI,UAAU;IAOvB,WAAW,IAAI,MAAM;CAG/B;AAID,qBAAa,SAAS;IAElB,MAAM,CAAC,aAAa,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS;IAI5C,SAAgB,KAAK,EAAE,UAAU,CAAC;gBAErB,KAAK,EAAE,UAAU;IAIvB,WAAW,IAAI,MAAM;CAG/B;AAID,qBAAa,oBAAqB,SAAQ,SAAS;IAE/C,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,GAAG,EAAE,GAAG,EAAE,UAAU,GAAG,oBAAoB;IAiBpE,MAAM,CAAC,kBAAkB,CAAC,EAAE,EAAE,cAAc,EAAE,GAAG,EAAE,UAAU,GAAG,oBAAoB;IAQpF,SAAgB,OAAO,EAAE,UAAU,CAAA;IACnC,SAAgB,MAAM,EAAE,SAAS,CAAA;IACjC,SAAgB,UAAU,EAAE,MAAM,CAAA;gBAErB,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,UAAU,EAAE,GAAG,EAAE,UAAU;IAgB3D,WAAW,IAAI,MAAM;IAIrB,gBAAgB,IAAI,GAAG;IAUvB,UAAU,IAAI,GAAG;CAM3B;AAKD,uBAAe,gBAAiB,SAAQ,KAAK;IACzC,QAAQ,CAAC,OAAO,EAAE,kBAAkB,CAAA;gBACxB,OAAO,EAAE,kBAAkB,EAAE,OAAO,CAAC,EAAE,MAAM;CAI5D;AACD,qBAAa,YAAa,SAAQ,gBAAgB;gBAClC,OAAO,EAAE,kBAAkB,EAAE,OAAO,CAAC,EAAE,MAAM;CAG5D;AAED,qBAAa,YAAa,SAAQ,gBAAgB;IAC9C,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;gBACV,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,kBAAkB,EAAE,OAAO,CAAC,EAAE,MAAM;CAI5E;AAGD,qBAAa,iBAAkB,SAAQ,KAAK;IACxC,QAAQ,CAAC,KAAK,CAAC,EAAE,GAAG,CAAC;IACrB,QAAQ,CAAC,QAAQ,EAAE,YAAY,CAAC;gBACpB,QAAQ,EAAE,YAAY,EAAE,KAAK,CAAC,EAAE,GAAG;CAMlD"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/lib/crypto/types.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AAKxE,qBAAa,KAAK;IACd,SAAS,CAAC,KAAK,EAAE,MAAM,CAAC;WACV,WAAW,CAAC,OAAO,EAAE,OAAO,GAAG,KAAK;WAOpC,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,KAAK;WAGrC,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,KAAK;WAGjC,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,KAAK;WAW7B,IAAI,IAAI,KAAK;gBAGd,MAAM,EAAE,MAAM;IAG3B,IAAW,MAAM,IAAI,MAAM,CAE1B;IACD,IAAW,QAAQ,IAAI,MAAM,CAE5B;IACD,IAAW,IAAI,IAAI,MAAM,CASxB;IACM,QAAQ,CAAC,QAAQ,SAAI,GAAG,MAAM;CAGxC;AAED,MAAM,MAAM,OAAO,GAAG,KAAK,CAAC,MAAM,CAAC,CAAA;AAEnC,MAAM,MAAM,cAAc,GAAG;IACzB,SAAS,EAAE;QAAE,SAAS,EAAE;YAAE,GAAG,EAAE,KAAK,CAAC,MAAM,CAAC,CAAA;SAAE,CAAA;KAAC,CAAC;IAChD,UAAU,EAAE;QACR,KAAK,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;QACrB,UAAU,EAAE,MAAM,CAAC;KACtB,CAAC;CACL,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG,SAAS,CAAA;AAE3C,UAAU,GAAG;IACT,KAAK,EAAE,UAAU,CAAC;CACrB;AAED,MAAM,WAAW,UAAW,SAAQ,GAAG;IACnC,IAAI,EAAE,SAAS,CAAC;CACnB;AAED,MAAM,WAAW,SAAU,SAAQ,GAAG;IAClC,IAAI,EAAE,QAAQ,CAAC;CAClB;AAED,MAAM,MAAM,mBAAmB,GAAG,CAAC,OAAO,EAAE,kBAAkB,EAAE,KAAK,CAAC,EAAE,GAAG,KAAK,GAAG,CAAA;AAEnF,MAAM,MAAM,iBAAiB,GAAG;IAC5B,QAAQ,CAAC,EAAE,KAAK,CAAC;IACjB,IAAI,CAAC,EAAE,mBAAmB,GAAG,KAAK,CAAC;CACtC,CAAA;AAED,oBAAY,mBAAmB;IAC3B,MAAM,WAAW;IACjB,GAAG,QAAQ;IACX,MAAM,WAAW;IACjB,IAAI,SAAS;IACb,OAAO,YAAY;CACtB;AAED,MAAM,MAAM,kBAAkB,GAAG;IAC7B,aAAa,CAAC,EAAE,SAAS,CAAC;IAC1B,UAAU,CAAC,EAAE,KAAK,CAAC;IACnB,SAAS,CAAC,EAAE,IAAI,CAAC;IACjB,UAAU,CAAC,EAAE,mBAAmB,CAAC;IACjC,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,MAAM,CAAC,EAAE,KAAK,CAAC;IACf,OAAO,CAAC,EAAE,IAAI,CAAC;IACf,KAAK,CAAC,EAAE,KAAK,CAAC;IACd,IAAI,EAAE,KAAK,CAAC;IACZ,IAAI,CAAC,EAAE,KAAK,CAAC,mBAAmB,CAAC,GAAG,mBAAmB,CAAC;IACxD,IAAI,EAAE,IAAI,CAAC;IACX,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,OAAO,CAAC,EAAE,GAAG,CAAC;IACd,OAAO,CAAC,EAAE,SAAS,CAAC;IACpB,UAAU,CAAC,EAAE,KAAK,CAAC,CAAC,mBAAmB,EAAE,KAAK,CAAC,CAAC,CAAC;IACjD,MAAM,EAAE,MAAM,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,MAAM,CAAC;IACb,EAAE,CAAC,EAAE,GAAG,CAAC;IACT,SAAS,CAAC,EAAE,mBAAmB,CAAC;IAChC,KAAK,CAAC,EAAE,KAAK,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,UAAU,CAAC,EAAE,mBAAmB,CAAC;IACjC,SAAS,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC,mBAAmB,EAAE,KAAK,CAAC,CAAC;CAC3D,CAAA;AAED,MAAM,MAAM,iBAAiB,GAAG,QAAQ,GAAG,SAAS,GAAG,SAAS,GAAG,SAAS,GAAG,OAAO,GAAG,WAAW,GAAG,WAAW,CAAC;AAEnH,MAAM,MAAM,YAAY,GAAG;IACvB,QAAQ,CAAC,EAAE,UAAU,CAAC;IACtB,IAAI,CAAC,EAAE,IAAI,CAAC;IACZ,OAAO,EAAE,GAAG,CAAC;CAChB,CAAA;AAED,MAAM,MAAM,IAAI,GAAG,YAAY,GAAG;IAAE,MAAM,EAAE,mBAAmB,CAAA;CAAE,CAAA;AAEjE,MAAM,MAAM,aAAa,GAAG;IAExB,UAAU,EAAE,MAAM,CAAC;IAEnB,IAAI,EAAE,MAAM,CAAC;IAEb,QAAQ,EAAE,MAAM,CAAC;CACpB,CAAA;AAED,MAAM,MAAM,WAAW,GAAG;IAEtB,cAAc,EAAE,IAAI,CAAC;IAErB,YAAY,EAAE,MAAM,CAAC;CACxB,CAAC;AAEF,oBAAY,qBAAqB;IAC7B,QAAQ,cAAc;IACtB,MAAM,WAAW;IACjB,OAAO,aAAa;IACpB,UAAU,gBAAgB;CAC7B;AAOD,qBAAa,SAAU,YAAW,GAAG;IAEjC,SAAgB,UAAU,EAAE,MAAM,CAAC;IACnC,SAAgB,KAAK,EAAE,UAAU,CAAC;IAElC,MAAM,CAAC,YAAY,CAAC,QAAQ,EAAE;QAAE,UAAU,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,KAAK,CAAC,MAAM,CAAC,CAAA;KAAE,GAAG,SAAS;IAItF,MAAM,CAAC,cAAc,CAAC,UAAU,EAAE,UAAU,GAAG,SAAS;IAOxD,MAAM,CAAC,WAAW,CAAC,WAAW,EAAE,GAAG,EAAE,GAAG,EAAE,UAAU,GAAG,SAAS;gBAkBpD,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,UAAU;IAK1C,MAAM,CAAC,MAAM,EAAE,SAAS,GAAG,OAAO;IAIlC,IAAI,IAAI,aAAa;IAIrB,WAAW,IAAI,MAAM;IAIrB,YAAY,IAAI,UAAU;CAGpC;AAID,qBAAa,aAAa;IAEtB,MAAM,CAAC,QAAQ,CAAC,IAAI,EAAE,UAAU,GAAG,aAAa;IAIhD,MAAM,CAAC,aAAa,CAAC,IAAI,EAAE,SAAS,GAAG,aAAa;IAIpD,MAAM,CAAC,aAAa,CAAC,EAAE,EAAE,SAAS,GAAG,aAAa;IAQlD,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,aAAa;IAe7C,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,CAAC;gBAEd,KAAK,EAAE,MAAM,EAAE;IAIpB,QAAQ,CAAC,OAAO,SAAY,GAAG,MAAM;IAIrC,SAAS,IAAI,UAAU;IAIvB,SAAS,IAAI,UAAU;IAOvB,WAAW,IAAI,MAAM;CAG/B;AAID,qBAAa,SAAS;IAElB,MAAM,CAAC,aAAa,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS;IAI5C,SAAgB,KAAK,EAAE,UAAU,CAAC;gBAErB,KAAK,EAAE,UAAU;IAIvB,WAAW,IAAI,MAAM;CAG/B;AAID,qBAAa,oBAAqB,SAAQ,SAAS;IAE/C,MAAM,CAAC,IAAI,CAAC,WAAW,EAAE,GAAG,EAAE,GAAG,EAAE,UAAU,GAAG,oBAAoB;IAiBpE,MAAM,CAAC,kBAAkB,CAAC,EAAE,EAAE,cAAc,EAAE,GAAG,EAAE,UAAU,GAAG,oBAAoB;IAQpF,SAAgB,OAAO,EAAE,UAAU,CAAA;IACnC,SAAgB,MAAM,EAAE,SAAS,CAAA;IACjC,SAAgB,UAAU,EAAE,MAAM,CAAA;gBAErB,MAAM,EAAE,SAAS,EAAE,KAAK,EAAE,UAAU,EAAE,GAAG,EAAE,UAAU;IAgB3D,WAAW,CAAC,QAAQ,UAAQ,GAAG,MAAM;IAIrC,gBAAgB,IAAI,GAAG;IAUvB,UAAU,IAAI,GAAG;CAM3B;AAKD,uBAAe,gBAAiB,SAAQ,KAAK;IACzC,QAAQ,CAAC,OAAO,EAAE,kBAAkB,CAAA;gBACxB,OAAO,EAAE,kBAAkB,EAAE,OAAO,CAAC,EAAE,MAAM;CAI5D;AACD,qBAAa,YAAa,SAAQ,gBAAgB;gBAClC,OAAO,EAAE,kBAAkB,EAAE,OAAO,CAAC,EAAE,MAAM;CAG5D;AAED,qBAAa,YAAa,SAAQ,gBAAgB;IAC9C,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC;gBACV,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,kBAAkB,EAAE,OAAO,CAAC,EAAE,MAAM;CAI5E;AAGD,qBAAa,iBAAkB,SAAQ,KAAK;IACxC,QAAQ,CAAC,KAAK,CAAC,EAAE,GAAG,CAAC;IACrB,QAAQ,CAAC,QAAQ,EAAE,YAAY,CAAC;gBACpB,QAAQ,EAAE,YAAY,EAAE,KAAK,CAAC,EAAE,GAAG;CAMlD"}
@@ -42,7 +42,6 @@ class Coins {
42
42
  throw new TypeError(`${this.constructor.name}: internal error: too many coins: ${quotient.toString()} > ${Number.MAX_SAFE_INTEGER}`);
43
43
  }
44
44
  const rest = Number(BigInt(this.coins) - quotient * 1000000000n) / 1000000000;
45
- // console.log("wits() =>", this.coins.toString(), quotient.toString(), rest, Number(quotient) + rest)
46
45
  return Number(quotient) + rest;
47
46
  }
48
47
  toString(decimals = 9) {
@@ -105,7 +104,7 @@ class PublicKey {
105
104
  hash() {
106
105
  return PublicKeyHash.fromPublicKey(this);
107
106
  }
108
- toString() {
107
+ toHexString() {
109
108
  return (0, helpers_1.toHexString)([this.compressed, ...this.bytes]);
110
109
  }
111
110
  toUint8Array() {
@@ -216,8 +215,8 @@ class RecoverableSignature extends Signature {
216
215
  this.pubKey = pubKey;
217
216
  this.recoveryId = recoveryId;
218
217
  }
219
- toHexString() {
220
- return (0, helpers_1.toHexString)([this.recoveryId, ...this.bytes]);
218
+ toHexString(prefix0x = false) {
219
+ return (0, helpers_1.toHexString)([this.recoveryId, ...this.bytes], prefix0x);
221
220
  }
222
221
  toKeyedSignature() {
223
222
  return {
@@ -270,4 +269,4 @@ exports.TransmissionError = TransmissionError;
270
269
  function matchingUint8Arrays(a, b) {
271
270
  return a.length === b.length && a.every((value, index) => value === b[index]);
272
271
  }
273
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/lib/crypto/types.ts"],"names":[],"mappings":"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","sourcesContent":["const secp256k1 = require('secp256k1')\r\nimport { bech32 } from 'bech32'\r\nimport { Balance, Epoch, Hash, HexString, UtxoMetadata } from \"../types\"\r\n\r\nimport { fromHexString, isHexString, toHexString, whole_wits } from \"../../bin/helpers\"\r\nimport { sha256 } from \"./utils\"\r\n\r\nexport class Coins {\r\n    protected coins: bigint;\r\n    public static fromBalance(balance: Balance): Coins {\r\n        return Coins.fromPedros(\r\n            balance.locked\r\n                + balance.staked\r\n                + balance.unlocked\r\n        )\r\n    }\r\n    public static fromNanowits(nanowits: bigint): Coins {\r\n        return new Coins(nanowits)\r\n    }\r\n    public static fromPedros(pedros: bigint): Coins {\r\n        return new Coins(pedros)\r\n    }\r\n    public static fromWits(wits: number): Coins {\r\n        if (wits > Number.MAX_SAFE_INTEGER) {\r\n            throw new TypeError(\r\n                `${this.constructor.name}: internal error: too many wits: ${wits} > ${Number.MAX_SAFE_INTEGER}`\r\n            )\r\n        }\r\n        return new Coins(\r\n            BigInt(Math.floor(wits)) * 10n ** 9n\r\n                + BigInt(Math.floor((wits - Math.floor(wits)) * 1000000000))\r\n        )\r\n    }\r\n    public static zero(): Coins {\r\n        return new Coins(0n)\r\n    }\r\n    constructor (pedros: bigint) {\r\n        this.coins = pedros\r\n    }\r\n    public get pedros(): bigint {\r\n        return this.coins\r\n    }\r\n    public get nanowits(): bigint {\r\n        return this.coins\r\n    }\r\n    public get wits(): number {\r\n        const quotient = BigInt(this.coins) / 1000000000n\r\n        if (Number(quotient) > Number.MAX_SAFE_INTEGER) {\r\n            throw new TypeError(\r\n                `${this.constructor.name}: internal error: too many coins: ${quotient.toString()} > ${Number.MAX_SAFE_INTEGER}`\r\n            )\r\n        }\r\n        const rest = Number(BigInt(this.coins) - quotient * 1000000000n) / 1000000000\r\n        // console.log(\"wits() =>\", this.coins.toString(), quotient.toString(), rest, Number(quotient) + rest)\r\n        return Number(quotient) + rest\r\n    }\r\n    public toString(decimals = 9): string {\r\n        return whole_wits(this.coins, decimals)\r\n    }\r\n}\r\n\r\nexport type KeyPath = Array<number>\r\n\r\nexport type KeyedSignature = {\r\n    signature: { Secp256k1: { der: Array<number> }},\r\n    public_key: {\r\n        bytes: Array<number>;\r\n        compressed: number,\r\n    },\r\n};\r\n\r\nexport type PublicKeyHashString = HexString\r\n\r\ninterface Key {\r\n    bytes: Uint8Array;\r\n}\r\n\r\nexport interface PrivateKey extends Key {\r\n    type: \"private\";\r\n}\r\n\r\nexport interface PublicKey extends Key {\r\n    type: \"public\";\r\n}\r\n\r\nexport type TransactionCallback = (receipt: TransactionReceipt, error?: any) => any\r\n\r\nexport type TransactionParams = {\r\n    deadline?: Epoch,\r\n    fees?: TransactionPriority | Coins,\r\n}\r\n\r\nexport enum TransactionPriority {\r\n    Stinky = \"stinky\",\r\n    Low = \"low\",\r\n    Medium = \"medium\",\r\n    High = \"high\",\r\n    Opulent = \"opulent\",\r\n}\r\n\r\nexport type TransactionReceipt = {\r\n    authorization?: HexString;\r\n    blockEpoch?: Epoch,\r\n    blockHash?: Hash,\r\n    blockMiner?: PublicKeyHashString,\r\n    blockTimestamp?: number,\r\n    confirmations?: number;\r\n    change?: Coins;\r\n    droHash?: Hash;\r\n    error?: Error,\r\n    fees: Coins;\r\n    from?: Array<PublicKeyHashString> | PublicKeyHashString;\r\n    hash: Hash;\r\n    outputLock?: number;\r\n    radArgs?: any;\r\n    radHash?: HexString;\r\n    recipients?: Array<[PublicKeyHashString, Coins]>;\r\n    status: string;\r\n    timestamp: number;\r\n    type: string;\r\n    tx?: any;\r\n    validator?: PublicKeyHashString;\r\n    value?: Coins;\r\n    weight: number;\r\n    withdrawer?: PublicKeyHashString;\r\n    witnesses?: number | Record<PublicKeyHashString, Coins>;\r\n}\r\n\r\nexport type TransactionStatus = \"signed\" | \"pending\" | \"relayed\" | \"removed\" | \"mined\" | \"confirmed\" | \"finalized\";\r\n\r\nexport type Transmission = {\r\n    bytecode?: Uint8Array,\r\n    hash?: Hash;\r\n    message: any;\r\n}\r\n\r\nexport type Utxo = UtxoMetadata & { signer: PublicKeyHashString }\r\n\r\nexport type UtxoCacheInfo = {\r\n    // total amount of expendable funds with currently cached UTXOs\r\n    expendable: bigint, \r\n    // number of cached UTXOs\r\n    size: number, \r\n    // earliest of all timelocks in the caché\r\n    timelock: number,\r\n}\r\n\r\nexport type UtxoPointer = {\r\n    // transaction identifier\r\n    transaction_id: Hash;\r\n    // output index within referred transaction\r\n    output_index: number;\r\n};\r\n\r\nexport enum UtxoSelectionStrategy {\r\n    BigFirst = \"big-first\",\r\n    Random = \"random\",\r\n    SlimFit = \"slim-fit\",\r\n    SmallFirst = \"small-first\",\r\n}\r\n\r\n\r\n///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\r\n/// EXPORTED CLASSES \r\n\r\n/// ===================================================================================================================\r\nexport class PublicKey implements Key {\r\n    \r\n    public readonly compressed: number;\r\n    public readonly bytes: Uint8Array;\r\n\r\n    static fromProtobuf(protobuf: { compressed: number, bytes: Array<number> }): PublicKey {\r\n        return new PublicKey(protobuf.compressed, Uint8Array.from(protobuf.bytes))\r\n    }\r\n\r\n    static fromUint8Array(uint8Array: Uint8Array): PublicKey {\r\n        return new PublicKey(\r\n            uint8Array[0],\r\n            uint8Array.slice(1),\r\n        );\r\n    }\r\n\r\n    static recoverFrom(recoverable: any, msg: Uint8Array): PublicKey {\r\n        let bytes\r\n        if (isHexString(recoverable)) {\r\n            bytes = fromHexString(recoverable)\r\n        } else if (recoverable instanceof Buffer) {\r\n            bytes = Uint8Array.from(recoverable.buffer)\r\n        } else if (recoverable instanceof Uint8Array) {\r\n            bytes = recoverable\r\n        } else {\r\n            throw new TypeError(`PublicKey: unsupported recoverable signature format: ${recoverable}`)\r\n        }\r\n        if (bytes.length !== 65) {\r\n            throw new TypeError(`PublicKey: expected recoverable signature with length 65: ${toHexString(bytes)}`)\r\n        } \r\n        const [ recoveryId, signature ] = [ bytes[0], bytes.slice(1) ]\r\n        return PublicKey.fromUint8Array(secp256k1.ecdsaRecover(signature, recoveryId, msg))\r\n    }\r\n\r\n    constructor(compressed: number, bytes: Uint8Array) {\r\n        this.compressed = compressed\r\n        this.bytes = bytes\r\n    }\r\n\r\n    public equals(pubKey: PublicKey): boolean {\r\n        return pubKey.compressed === this.compressed && matchingUint8Arrays(pubKey.bytes, pubKey.bytes)\r\n    }\r\n\r\n    public hash(): PublicKeyHash {\r\n        return PublicKeyHash.fromPublicKey(this)\r\n    }\r\n\r\n    public toString(): string {\r\n        return toHexString([this.compressed, ...this.bytes])\r\n    }\r\n\r\n    public toUint8Array(): Uint8Array {\r\n        return Uint8Array.from([this.compressed, ...this.bytes])\r\n    }\r\n};\r\n\r\n\r\n/// ===================================================================================================================\r\nexport class PublicKeyHash {\r\n\r\n    static fromHash(hash: Uint8Array): PublicKeyHash {\r\n        return new PublicKeyHash(bech32.toWords(hash));\r\n    }\r\n\r\n    static fromHexString(hash: HexString): PublicKeyHash {\r\n        return PublicKeyHash.fromHash(fromHexString(hash))\r\n    }\r\n    \r\n    static fromPublicKey(pk: PublicKey): PublicKeyHash {\r\n        return PublicKeyHash.fromHash(\r\n            sha256(\r\n                Buffer.from([pk.compressed, ...pk.bytes])\r\n            ).subarray(0, 20)\r\n        );\r\n    }\r\n    \r\n    static fromBech32(pkh: string): PublicKeyHash {\r\n        try {\r\n            pkh = pkh.toLowerCase()\r\n            if (pkh.startsWith('wit')) {\r\n                return new PublicKeyHash(bech32.decode(pkh, 66).words)\r\n            } else if (pkh.startsWith('twit')) {\r\n                return new PublicKeyHash(bech32.decode(pkh, 67).words)\r\n            } else {\r\n                throw new TypeError(`PublicKeyHash: invalid bech32 string: ${pkh}`);\r\n            }\r\n        } catch {\r\n            throw new TypeError(`PublicKeyHash: invalid bech32 string: ${pkh}`);\r\n        }\r\n    }\r\n\r\n    protected words: number[];\r\n    \r\n    constructor(words: number[]) {\r\n        this.words = words\r\n    }\r\n\r\n    public toBech32(network = \"mainnet\"): string {\r\n        return network === \"mainnet\" ? bech32.encode('wit', this.words, 66) : bech32.encode('twit', this.words, 67);\r\n    }\r\n\r\n    public toBytes20(): Uint8Array {\r\n        return Uint8Array.from(bech32.fromWords(this.words).slice(0, 20))\r\n    }\r\n\r\n    public toBytes32(): Uint8Array {\r\n        return Uint8Array.from([\r\n            ...bech32.fromWords(this.words).slice(0, 20),\r\n            ...new Array(12).fill(0),\r\n        ]);\r\n    }\r\n\r\n    public toHexString(): string {\r\n        return toHexString(this.toBytes20())\r\n    }\r\n}\r\n\r\n\r\n/// ===================================================================================================================\r\nexport class Signature {\r\n\r\n    static fromHexString(hex: string): Signature {\r\n        return new Signature(fromHexString(hex))\r\n    }\r\n\r\n    public readonly bytes: Uint8Array;\r\n\r\n    constructor (bytes: Uint8Array) {\r\n        this.bytes = bytes\r\n    }\r\n    \r\n    public toHexString(): string {\r\n        return toHexString(this.bytes)\r\n    }\r\n}\r\n\r\n\r\n/// ===================================================================================================================\r\nexport class RecoverableSignature extends Signature {\r\n\r\n    static from(recoverable: any, msg: Uint8Array): RecoverableSignature {\r\n        let bytes\r\n        if (isHexString(recoverable)) {\r\n            bytes = fromHexString(recoverable).slice(1)\r\n        } else if (recoverable instanceof Buffer) {\r\n            bytes = Uint8Array.from(recoverable.buffer).slice(1)\r\n        } else if (recoverable instanceof Uint8Array) {\r\n            bytes = recoverable.slice(1)\r\n        } else {\r\n            throw new TypeError(`RecoverableSignature: unsupported recoverable signature format: ${recoverable}`)\r\n        }\r\n        if (bytes.length !== 64) {\r\n            throw new TypeError(`RecoverableSignatre: expected recoverable signature with length 65: ${toHexString(bytes)}`)\r\n        } \r\n        return new RecoverableSignature(PublicKey.recoverFrom(recoverable, msg), bytes, msg)\r\n    }\r\n\r\n    static fromKeyedSignature(ks: KeyedSignature, msg: Uint8Array): RecoverableSignature {\r\n        return new RecoverableSignature(\r\n            PublicKey.fromProtobuf(ks.public_key),\r\n            secp256k1.signatureImport(Uint8Array.from(ks.signature.Secp256k1.der)),\r\n            msg\r\n        )   \r\n    }\r\n\r\n    public readonly message: Uint8Array\r\n    public readonly pubKey: PublicKey\r\n    public readonly recoveryId: number\r\n    \r\n    constructor (pubKey: PublicKey, bytes: Uint8Array, msg: Uint8Array) {\r\n        super(bytes)\r\n        const pubKeyRaw = pubKey.toUint8Array()\r\n        let recoveryId: number;\r\n        for (recoveryId = 0; recoveryId < 4; recoveryId ++) {\r\n            let recovered \r\n            try {\r\n              recovered = secp256k1.ecdsaRecover(bytes, recoveryId, msg)\r\n              if (matchingUint8Arrays(recovered, pubKeyRaw)) break;\r\n            } catch {}\r\n        }\r\n        this.message = msg\r\n        this.pubKey = pubKey\r\n        this.recoveryId = recoveryId\r\n    }\r\n\r\n    public toHexString(): string {\r\n        return toHexString([this.recoveryId, ...this.bytes])\r\n    }\r\n\r\n    public toKeyedSignature(): any {\r\n        return {\r\n            signature: { Secp256k1: { der: Array.from(secp256k1.signatureExport(this.bytes)) }},\r\n            public_key: {\r\n                bytes: Array.from(this.pubKey.bytes),\r\n                compressed: this.pubKey.compressed,\r\n            }\r\n        }\r\n    }\r\n\r\n    public toProtobuf(): any {\r\n        return {\r\n            signature: { Secp256k1: { der: Array.from(secp256k1.signatureExport(this.bytes)) }},\r\n            publicKey: { publicKey: Array.from([ this.pubKey.compressed, ...this.pubKey.bytes ]) },\r\n        }\r\n    }\r\n}\r\n\r\n\r\n/// ===================================================================================================================\r\n\r\nabstract class TransactionError extends Error {\r\n    readonly receipt: TransactionReceipt\r\n    constructor(receipt: TransactionReceipt, message?: string) {\r\n        super(message)\r\n        this.receipt = receipt\r\n    }\r\n}\r\nexport class MempoolError extends TransactionError {\r\n    constructor(receipt: TransactionReceipt, message?: string) {\r\n        super(receipt, message)\r\n    }\r\n}\r\n\r\nexport class TimeoutError extends TransactionError {\r\n    readonly msecs: number;\r\n    constructor (msecs: number, receipt: TransactionReceipt, message?: string) {\r\n        super(receipt, message)\r\n        this.msecs = msecs\r\n    }\r\n}\r\n    \r\n\r\nexport class TransmissionError extends Error {\r\n    readonly error?: any;\r\n    readonly inFlight: Transmission;\r\n    constructor(inFlight: Transmission, error?: any) {\r\n        super(JSON.stringify(error))\r\n        delete error?.stack\r\n        this.error = error\r\n        this.inFlight = inFlight\r\n    }\r\n}\r\n\r\n\r\n/// -------------------------------------------------------------------------------------------------------------------\r\n/// --- Internal functions \r\n\r\nfunction matchingUint8Arrays(a: Uint8Array, b: Uint8Array) {\r\n    return a.length === b.length && a.every((value, index) => value === b[index])\r\n}\r\n"]}
272
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/lib/crypto/types.ts"],"names":[],"mappings":"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","sourcesContent":["const secp256k1 = require('secp256k1')\r\nimport { bech32 } from 'bech32'\r\nimport { Balance, Epoch, Hash, HexString, UtxoMetadata } from \"../types\"\r\n\r\nimport { fromHexString, isHexString, toHexString, whole_wits } from \"../../bin/helpers\"\r\nimport { sha256 } from \"./utils\"\r\n\r\nexport class Coins {\r\n    protected coins: bigint;\r\n    public static fromBalance(balance: Balance): Coins {\r\n        return Coins.fromPedros(\r\n            balance.locked\r\n                + balance.staked\r\n                + balance.unlocked\r\n        )\r\n    }\r\n    public static fromNanowits(nanowits: bigint): Coins {\r\n        return new Coins(nanowits)\r\n    }\r\n    public static fromPedros(pedros: bigint): Coins {\r\n        return new Coins(pedros)\r\n    }\r\n    public static fromWits(wits: number): Coins {\r\n        if (wits > Number.MAX_SAFE_INTEGER) {\r\n            throw new TypeError(\r\n                `${this.constructor.name}: internal error: too many wits: ${wits} > ${Number.MAX_SAFE_INTEGER}`\r\n            )\r\n        }\r\n        return new Coins(\r\n            BigInt(Math.floor(wits)) * 10n ** 9n\r\n                + BigInt(Math.floor((wits - Math.floor(wits)) * 1000000000))\r\n        )\r\n    }\r\n    public static zero(): Coins {\r\n        return new Coins(0n)\r\n    }\r\n    constructor (pedros: bigint) {\r\n        this.coins = pedros\r\n    }\r\n    public get pedros(): bigint {\r\n        return this.coins\r\n    }\r\n    public get nanowits(): bigint {\r\n        return this.coins\r\n    }\r\n    public get wits(): number {\r\n        const quotient = BigInt(this.coins) / 1000000000n\r\n        if (Number(quotient) > Number.MAX_SAFE_INTEGER) {\r\n            throw new TypeError(\r\n                `${this.constructor.name}: internal error: too many coins: ${quotient.toString()} > ${Number.MAX_SAFE_INTEGER}`\r\n            )\r\n        }\r\n        const rest = Number(BigInt(this.coins) - quotient * 1000000000n) / 1000000000\r\n        return Number(quotient) + rest\r\n    }\r\n    public toString(decimals = 9): string {\r\n        return whole_wits(this.coins, decimals)\r\n    }\r\n}\r\n\r\nexport type KeyPath = Array<number>\r\n\r\nexport type KeyedSignature = {\r\n    signature: { Secp256k1: { der: Array<number> }},\r\n    public_key: {\r\n        bytes: Array<number>;\r\n        compressed: number,\r\n    },\r\n};\r\n\r\nexport type PublicKeyHashString = HexString\r\n\r\ninterface Key {\r\n    bytes: Uint8Array;\r\n}\r\n\r\nexport interface PrivateKey extends Key {\r\n    type: \"private\";\r\n}\r\n\r\nexport interface PublicKey extends Key {\r\n    type: \"public\";\r\n}\r\n\r\nexport type TransactionCallback = (receipt: TransactionReceipt, error?: any) => any\r\n\r\nexport type TransactionParams = {\r\n    deadline?: Epoch,\r\n    fees?: TransactionPriority | Coins,\r\n}\r\n\r\nexport enum TransactionPriority {\r\n    Stinky = \"stinky\",\r\n    Low = \"low\",\r\n    Medium = \"medium\",\r\n    High = \"high\",\r\n    Opulent = \"opulent\",\r\n}\r\n\r\nexport type TransactionReceipt = {\r\n    authorization?: HexString;\r\n    blockEpoch?: Epoch,\r\n    blockHash?: Hash,\r\n    blockMiner?: PublicKeyHashString,\r\n    blockTimestamp?: number,\r\n    confirmations?: number;\r\n    change?: Coins;\r\n    droHash?: Hash;\r\n    error?: Error,\r\n    fees: Coins;\r\n    from?: Array<PublicKeyHashString> | PublicKeyHashString;\r\n    hash: Hash;\r\n    outputLock?: number;\r\n    radArgs?: any;\r\n    radHash?: HexString;\r\n    recipients?: Array<[PublicKeyHashString, Coins]>;\r\n    status: string;\r\n    timestamp: number;\r\n    type: string;\r\n    tx?: any;\r\n    validator?: PublicKeyHashString;\r\n    value?: Coins;\r\n    weight: number;\r\n    withdrawer?: PublicKeyHashString;\r\n    witnesses?: number | Record<PublicKeyHashString, Coins>;\r\n}\r\n\r\nexport type TransactionStatus = \"signed\" | \"pending\" | \"relayed\" | \"removed\" | \"mined\" | \"confirmed\" | \"finalized\";\r\n\r\nexport type Transmission = {\r\n    bytecode?: Uint8Array,\r\n    hash?: Hash;\r\n    message: any;\r\n}\r\n\r\nexport type Utxo = UtxoMetadata & { signer: PublicKeyHashString }\r\n\r\nexport type UtxoCacheInfo = {\r\n    // total amount of expendable funds with currently cached UTXOs\r\n    expendable: bigint, \r\n    // number of cached UTXOs\r\n    size: number, \r\n    // earliest of all timelocks in the caché\r\n    timelock: number,\r\n}\r\n\r\nexport type UtxoPointer = {\r\n    // transaction identifier\r\n    transaction_id: Hash;\r\n    // output index within referred transaction\r\n    output_index: number;\r\n};\r\n\r\nexport enum UtxoSelectionStrategy {\r\n    BigFirst = \"big-first\",\r\n    Random = \"random\",\r\n    SlimFit = \"slim-fit\",\r\n    SmallFirst = \"small-first\",\r\n}\r\n\r\n\r\n///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////\r\n/// EXPORTED CLASSES \r\n\r\n/// ===================================================================================================================\r\nexport class PublicKey implements Key {\r\n    \r\n    public readonly compressed: number;\r\n    public readonly bytes: Uint8Array;\r\n\r\n    static fromProtobuf(protobuf: { compressed: number, bytes: Array<number> }): PublicKey {\r\n        return new PublicKey(protobuf.compressed, Uint8Array.from(protobuf.bytes))\r\n    }\r\n\r\n    static fromUint8Array(uint8Array: Uint8Array): PublicKey {\r\n        return new PublicKey(\r\n            uint8Array[0],\r\n            uint8Array.slice(1),\r\n        );\r\n    }\r\n\r\n    static recoverFrom(recoverable: any, msg: Uint8Array): PublicKey {\r\n        let bytes\r\n        if (isHexString(recoverable)) {\r\n            bytes = fromHexString(recoverable)\r\n        } else if (recoverable instanceof Buffer) {\r\n            bytes = Uint8Array.from(recoverable.buffer)\r\n        } else if (recoverable instanceof Uint8Array) {\r\n            bytes = recoverable\r\n        } else {\r\n            throw new TypeError(`PublicKey: unsupported recoverable signature format: ${recoverable}`)\r\n        }\r\n        if (bytes.length !== 65) {\r\n            throw new TypeError(`PublicKey: expected recoverable signature with length 65: ${toHexString(bytes)}`)\r\n        } \r\n        const [ recoveryId, signature ] = [ bytes[0], bytes.slice(1) ]\r\n        return PublicKey.fromUint8Array(secp256k1.ecdsaRecover(signature, recoveryId, msg))\r\n    }\r\n\r\n    constructor(compressed: number, bytes: Uint8Array) {\r\n        this.compressed = compressed\r\n        this.bytes = bytes\r\n    }\r\n\r\n    public equals(pubKey: PublicKey): boolean {\r\n        return pubKey.compressed === this.compressed && matchingUint8Arrays(pubKey.bytes, pubKey.bytes)\r\n    }\r\n\r\n    public hash(): PublicKeyHash {\r\n        return PublicKeyHash.fromPublicKey(this)\r\n    }\r\n\r\n    public toHexString(): string {\r\n        return toHexString([this.compressed, ...this.bytes])\r\n    }\r\n\r\n    public toUint8Array(): Uint8Array {\r\n        return Uint8Array.from([this.compressed, ...this.bytes])\r\n    }\r\n};\r\n\r\n\r\n/// ===================================================================================================================\r\nexport class PublicKeyHash {\r\n\r\n    static fromHash(hash: Uint8Array): PublicKeyHash {\r\n        return new PublicKeyHash(bech32.toWords(hash));\r\n    }\r\n\r\n    static fromHexString(hash: HexString): PublicKeyHash {\r\n        return PublicKeyHash.fromHash(fromHexString(hash))\r\n    }\r\n    \r\n    static fromPublicKey(pk: PublicKey): PublicKeyHash {\r\n        return PublicKeyHash.fromHash(\r\n            sha256(\r\n                Buffer.from([pk.compressed, ...pk.bytes])\r\n            ).subarray(0, 20)\r\n        );\r\n    }\r\n    \r\n    static fromBech32(pkh: string): PublicKeyHash {\r\n        try {\r\n            pkh = pkh.toLowerCase()\r\n            if (pkh.startsWith('wit')) {\r\n                return new PublicKeyHash(bech32.decode(pkh, 66).words)\r\n            } else if (pkh.startsWith('twit')) {\r\n                return new PublicKeyHash(bech32.decode(pkh, 67).words)\r\n            } else {\r\n                throw new TypeError(`PublicKeyHash: invalid bech32 string: ${pkh}`);\r\n            }\r\n        } catch {\r\n            throw new TypeError(`PublicKeyHash: invalid bech32 string: ${pkh}`);\r\n        }\r\n    }\r\n\r\n    protected words: number[];\r\n    \r\n    constructor(words: number[]) {\r\n        this.words = words\r\n    }\r\n\r\n    public toBech32(network = \"mainnet\"): string {\r\n        return network === \"mainnet\" ? bech32.encode('wit', this.words, 66) : bech32.encode('twit', this.words, 67);\r\n    }\r\n\r\n    public toBytes20(): Uint8Array {\r\n        return Uint8Array.from(bech32.fromWords(this.words).slice(0, 20))\r\n    }\r\n\r\n    public toBytes32(): Uint8Array {\r\n        return Uint8Array.from([\r\n            ...bech32.fromWords(this.words).slice(0, 20),\r\n            ...new Array(12).fill(0),\r\n        ]);\r\n    }\r\n\r\n    public toHexString(): string {\r\n        return toHexString(this.toBytes20())\r\n    }\r\n}\r\n\r\n\r\n/// ===================================================================================================================\r\nexport class Signature {\r\n\r\n    static fromHexString(hex: string): Signature {\r\n        return new Signature(fromHexString(hex))\r\n    }\r\n\r\n    public readonly bytes: Uint8Array;\r\n\r\n    constructor (bytes: Uint8Array) {\r\n        this.bytes = bytes\r\n    }\r\n    \r\n    public toHexString(): string {\r\n        return toHexString(this.bytes)\r\n    }\r\n}\r\n\r\n\r\n/// ===================================================================================================================\r\nexport class RecoverableSignature extends Signature {\r\n\r\n    static from(recoverable: any, msg: Uint8Array): RecoverableSignature {\r\n        let bytes\r\n        if (isHexString(recoverable)) {\r\n            bytes = fromHexString(recoverable).slice(1)\r\n        } else if (recoverable instanceof Buffer) {\r\n            bytes = Uint8Array.from(recoverable.buffer).slice(1)\r\n        } else if (recoverable instanceof Uint8Array) {\r\n            bytes = recoverable.slice(1)\r\n        } else {\r\n            throw new TypeError(`RecoverableSignature: unsupported recoverable signature format: ${recoverable}`)\r\n        }\r\n        if (bytes.length !== 64) {\r\n            throw new TypeError(`RecoverableSignatre: expected recoverable signature with length 65: ${toHexString(bytes)}`)\r\n        } \r\n        return new RecoverableSignature(PublicKey.recoverFrom(recoverable, msg), bytes, msg)\r\n    }\r\n\r\n    static fromKeyedSignature(ks: KeyedSignature, msg: Uint8Array): RecoverableSignature {\r\n        return new RecoverableSignature(\r\n            PublicKey.fromProtobuf(ks.public_key),\r\n            secp256k1.signatureImport(Uint8Array.from(ks.signature.Secp256k1.der)),\r\n            msg\r\n        )   \r\n    }\r\n\r\n    public readonly message: Uint8Array\r\n    public readonly pubKey: PublicKey\r\n    public readonly recoveryId: number\r\n    \r\n    constructor (pubKey: PublicKey, bytes: Uint8Array, msg: Uint8Array) {\r\n        super(bytes)\r\n        const pubKeyRaw = pubKey.toUint8Array()\r\n        let recoveryId: number;\r\n        for (recoveryId = 0; recoveryId < 4; recoveryId ++) {\r\n            let recovered \r\n            try {\r\n              recovered = secp256k1.ecdsaRecover(bytes, recoveryId, msg)\r\n              if (matchingUint8Arrays(recovered, pubKeyRaw)) break;\r\n            } catch {}\r\n        }\r\n        this.message = msg\r\n        this.pubKey = pubKey\r\n        this.recoveryId = recoveryId\r\n    }\r\n\r\n    public toHexString(prefix0x = false): string {\r\n        return toHexString([this.recoveryId, ...this.bytes], prefix0x)\r\n    }\r\n\r\n    public toKeyedSignature(): any {\r\n        return {\r\n            signature: { Secp256k1: { der: Array.from(secp256k1.signatureExport(this.bytes)) }},\r\n            public_key: {\r\n                bytes: Array.from(this.pubKey.bytes),\r\n                compressed: this.pubKey.compressed,\r\n            }\r\n        }\r\n    }\r\n\r\n    public toProtobuf(): any {\r\n        return {\r\n            signature: { Secp256k1: { der: Array.from(secp256k1.signatureExport(this.bytes)) }},\r\n            publicKey: { publicKey: Array.from([ this.pubKey.compressed, ...this.pubKey.bytes ]) },\r\n        }\r\n    }\r\n}\r\n\r\n\r\n/// ===================================================================================================================\r\n\r\nabstract class TransactionError extends Error {\r\n    readonly receipt: TransactionReceipt\r\n    constructor(receipt: TransactionReceipt, message?: string) {\r\n        super(message)\r\n        this.receipt = receipt\r\n    }\r\n}\r\nexport class MempoolError extends TransactionError {\r\n    constructor(receipt: TransactionReceipt, message?: string) {\r\n        super(receipt, message)\r\n    }\r\n}\r\n\r\nexport class TimeoutError extends TransactionError {\r\n    readonly msecs: number;\r\n    constructor (msecs: number, receipt: TransactionReceipt, message?: string) {\r\n        super(receipt, message)\r\n        this.msecs = msecs\r\n    }\r\n}\r\n    \r\n\r\nexport class TransmissionError extends Error {\r\n    readonly error?: any;\r\n    readonly inFlight: Transmission;\r\n    constructor(inFlight: Transmission, error?: any) {\r\n        super(JSON.stringify(error))\r\n        delete error?.stack\r\n        this.error = error\r\n        this.inFlight = inFlight\r\n    }\r\n}\r\n\r\n\r\n/// -------------------------------------------------------------------------------------------------------------------\r\n/// --- Internal functions \r\n\r\nfunction matchingUint8Arrays(a: Uint8Array, b: Uint8Array) {\r\n    return a.length === b.length && a.every((value, index) => value === b[index])\r\n}\r\n"]}
@@ -1,4 +1,4 @@
1
- import { Balance } from '../types';
1
+ import { Balance, HexString } from '../types';
2
2
  import { Coins, Utxo, UtxoSelectionStrategy } from './types';
3
3
  export { bech32 } from 'bech32';
4
4
  export { PrivateKey, PublicKey, PublicKeyHash, KeyedSignature, RecoverableSignature, Signature } from "./types";
@@ -6,6 +6,7 @@ export declare const BigMath: {
6
6
  max(value: bigint, ...values: bigint[]): bigint;
7
7
  };
8
8
  export declare function decipherXprv(slip32: string, passwd: string): string;
9
+ export declare function ecdsaVerify(msg: Buffer<ArrayBufferLike>, pubKey: HexString, signature: HexString): boolean;
9
10
  export declare const parseXprv: (slip32: string) => {
10
11
  chainCode: Uint8Array;
11
12
  keyPath: Array<number>;
@@ -1 +1 @@
1
- {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../../src/lib/crypto/utils.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,OAAO,EAAE,MAAM,UAAU,CAAA;AAClC,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAA;AAE5D,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAA;AAE/B,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,aAAa,EAAE,cAAc,EAAE,oBAAoB,EAAE,SAAS,EAAE,MAAM,SAAS,CAAA;AAE/G,eAAO,MAAM,OAAO;eACL,MAAM,aAAa,MAAM,EAAE,GAAG,MAAM;CAKlD,CAAA;AAqBD,wBAAgB,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,CAcnE;AAED,eAAO,MAAM,SAAS,WAAY,MAAM,KAAG;IACvC,SAAS,EAAE,UAAU,CAAC;IACtB,OAAO,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;IACvB,UAAU,EAAE,UAAU,CAAC;CAyD1B,CAAC;AAEF,wBAAgB,WAAW,CAAC,KAAK,EAAE;IAC/B,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;IACnB,KAAK,CAAC,EAAE,KAAK,CAAC;IACd,QAAQ,CAAC,EAAE,qBAAqB,CAAC;CACpC,GAAG,KAAK,CAAC,IAAI,CAAC,CA6Cd;AAED,wBAAgB,MAAM,CAAC,MAAM,EAAE,GAAG,2BAIjC;AAED,wBAAgB,UAAU,CAAC,OAAO,EAAE,OAAO,GAAG,KAAK,CAMlD"}
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../../src/lib/crypto/utils.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,UAAU,CAAA;AAC7C,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,qBAAqB,EAAE,MAAM,SAAS,CAAA;AAG5D,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAA;AAE/B,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,aAAa,EAAE,cAAc,EAAE,oBAAoB,EAAE,SAAS,EAAE,MAAM,SAAS,CAAA;AAE/G,eAAO,MAAM,OAAO;eACL,MAAM,aAAa,MAAM,EAAE,GAAG,MAAM;CAKlD,CAAA;AAqBD,wBAAgB,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,CAcnE;AAED,wBAAgB,WAAW,CACvB,GAAG,EAAE,MAAM,CAAC,eAAe,CAAC,EAC5B,MAAM,EAAE,SAAS,EACjB,SAAS,EAAE,SAAS,GACrB,OAAO,CAOT;AAED,eAAO,MAAM,SAAS,WAAY,MAAM,KAAG;IACvC,SAAS,EAAE,UAAU,CAAC;IACtB,OAAO,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;IACvB,UAAU,EAAE,UAAU,CAAC;CAyD1B,CAAC;AAEF,wBAAgB,WAAW,CAAC,KAAK,EAAE;IAC/B,KAAK,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;IACnB,KAAK,CAAC,EAAE,KAAK,CAAC;IACd,QAAQ,CAAC,EAAE,qBAAqB,CAAC;CACpC,GAAG,KAAK,CAAC,IAAI,CAAC,CA6Cd;AAED,wBAAgB,MAAM,CAAC,MAAM,EAAE,GAAG,2BAIjC;AAED,wBAAgB,UAAU,CAAC,OAAO,EAAE,OAAO,GAAG,KAAK,CAMlD"}