@witnet/sdk 1.0.0-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (149) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +103 -0
  3. package/dist/package.json +72 -0
  4. package/dist/src/bin/helpers.d.ts +91 -0
  5. package/dist/src/bin/helpers.d.ts.map +1 -0
  6. package/dist/src/bin/helpers.js +816 -0
  7. package/dist/src/index.d.ts +5 -0
  8. package/dist/src/index.d.ts.map +1 -0
  9. package/dist/src/index.js +47 -0
  10. package/dist/src/lib/crypto/account.d.ts +32 -0
  11. package/dist/src/lib/crypto/account.d.ts.map +1 -0
  12. package/dist/src/lib/crypto/account.js +106 -0
  13. package/dist/src/lib/crypto/coinbase.d.ts +10 -0
  14. package/dist/src/lib/crypto/coinbase.d.ts.map +1 -0
  15. package/dist/src/lib/crypto/coinbase.js +28 -0
  16. package/dist/src/lib/crypto/index.d.ts +8 -0
  17. package/dist/src/lib/crypto/index.d.ts.map +1 -0
  18. package/dist/src/lib/crypto/index.js +30 -0
  19. package/dist/src/lib/crypto/interfaces.d.ts +85 -0
  20. package/dist/src/lib/crypto/interfaces.d.ts.map +1 -0
  21. package/dist/src/lib/crypto/interfaces.js +3 -0
  22. package/dist/src/lib/crypto/payloads/DataRequestPayload.d.ts +55 -0
  23. package/dist/src/lib/crypto/payloads/DataRequestPayload.d.ts.map +1 -0
  24. package/dist/src/lib/crypto/payloads/DataRequestPayload.js +339 -0
  25. package/dist/src/lib/crypto/payloads/StakePayload.d.ts +28 -0
  26. package/dist/src/lib/crypto/payloads/StakePayload.d.ts.map +1 -0
  27. package/dist/src/lib/crypto/payloads/StakePayload.js +142 -0
  28. package/dist/src/lib/crypto/payloads/UnstakePayload.d.ts +36 -0
  29. package/dist/src/lib/crypto/payloads/UnstakePayload.d.ts.map +1 -0
  30. package/dist/src/lib/crypto/payloads/UnstakePayload.js +154 -0
  31. package/dist/src/lib/crypto/payloads/ValueTransferPayload.d.ts +25 -0
  32. package/dist/src/lib/crypto/payloads/ValueTransferPayload.d.ts.map +1 -0
  33. package/dist/src/lib/crypto/payloads/ValueTransferPayload.js +128 -0
  34. package/dist/src/lib/crypto/payloads.d.ts +57 -0
  35. package/dist/src/lib/crypto/payloads.d.ts.map +1 -0
  36. package/dist/src/lib/crypto/payloads.js +170 -0
  37. package/dist/src/lib/crypto/signer.d.ts +33 -0
  38. package/dist/src/lib/crypto/signer.d.ts.map +1 -0
  39. package/dist/src/lib/crypto/signer.js +194 -0
  40. package/dist/src/lib/crypto/transmitters/DataRequests.d.ts +15 -0
  41. package/dist/src/lib/crypto/transmitters/DataRequests.d.ts.map +1 -0
  42. package/dist/src/lib/crypto/transmitters/DataRequests.js +23 -0
  43. package/dist/src/lib/crypto/transmitters/StakeDeposits.d.ts +12 -0
  44. package/dist/src/lib/crypto/transmitters/StakeDeposits.d.ts.map +1 -0
  45. package/dist/src/lib/crypto/transmitters/StakeDeposits.js +17 -0
  46. package/dist/src/lib/crypto/transmitters/StakeWithdrawals.d.ts +18 -0
  47. package/dist/src/lib/crypto/transmitters/StakeWithdrawals.d.ts.map +1 -0
  48. package/dist/src/lib/crypto/transmitters/StakeWithdrawals.js +53 -0
  49. package/dist/src/lib/crypto/transmitters/ValueTransfers.d.ts +11 -0
  50. package/dist/src/lib/crypto/transmitters/ValueTransfers.d.ts.map +1 -0
  51. package/dist/src/lib/crypto/transmitters/ValueTransfers.js +16 -0
  52. package/dist/src/lib/crypto/transmitters.d.ts +47 -0
  53. package/dist/src/lib/crypto/transmitters.d.ts.map +1 -0
  54. package/dist/src/lib/crypto/transmitters.js +416 -0
  55. package/dist/src/lib/crypto/types.d.ts +161 -0
  56. package/dist/src/lib/crypto/types.d.ts.map +1 -0
  57. package/dist/src/lib/crypto/types.js +273 -0
  58. package/dist/src/lib/crypto/utils.d.ts +21 -0
  59. package/dist/src/lib/crypto/utils.d.ts.map +1 -0
  60. package/dist/src/lib/crypto/utils.js +156 -0
  61. package/dist/src/lib/crypto/wallet.d.ts +120 -0
  62. package/dist/src/lib/crypto/wallet.d.ts.map +1 -0
  63. package/dist/src/lib/crypto/wallet.js +258 -0
  64. package/dist/src/lib/index.d.ts +5 -0
  65. package/dist/src/lib/index.d.ts.map +1 -0
  66. package/dist/src/lib/index.js +44 -0
  67. package/dist/src/lib/radon/ccdr/eth.d.ts +160 -0
  68. package/dist/src/lib/radon/ccdr/eth.d.ts.map +1 -0
  69. package/dist/src/lib/radon/ccdr/eth.js +272 -0
  70. package/dist/src/lib/radon/ccdr/index.d.ts +14 -0
  71. package/dist/src/lib/radon/ccdr/index.d.ts.map +1 -0
  72. package/dist/src/lib/radon/ccdr/index.js +39 -0
  73. package/dist/src/lib/radon/ccdr/wit.d.ts +23 -0
  74. package/dist/src/lib/radon/ccdr/wit.d.ts.map +1 -0
  75. package/dist/src/lib/radon/ccdr/wit.js +35 -0
  76. package/dist/src/lib/radon/filters.d.ts +14 -0
  77. package/dist/src/lib/radon/filters.d.ts.map +1 -0
  78. package/dist/src/lib/radon/filters.js +45 -0
  79. package/dist/src/lib/radon/index.d.ts +296 -0
  80. package/dist/src/lib/radon/index.d.ts.map +1 -0
  81. package/dist/src/lib/radon/index.js +707 -0
  82. package/dist/src/lib/radon/reducers.d.ts +29 -0
  83. package/dist/src/lib/radon/reducers.d.ts.map +1 -0
  84. package/dist/src/lib/radon/reducers.js +66 -0
  85. package/dist/src/lib/radon/types.d.ts +521 -0
  86. package/dist/src/lib/radon/types.d.ts.map +1 -0
  87. package/dist/src/lib/radon/types.js +936 -0
  88. package/dist/src/lib/radon/utils.d.ts +53 -0
  89. package/dist/src/lib/radon/utils.d.ts.map +1 -0
  90. package/dist/src/lib/radon/utils.js +153 -0
  91. package/dist/src/lib/rpc/index.d.ts +3 -0
  92. package/dist/src/lib/rpc/index.d.ts.map +1 -0
  93. package/dist/src/lib/rpc/index.js +19 -0
  94. package/dist/src/lib/rpc/nodes.d.ts +40 -0
  95. package/dist/src/lib/rpc/nodes.d.ts.map +1 -0
  96. package/dist/src/lib/rpc/nodes.js +293 -0
  97. package/dist/src/lib/rpc/provider.d.ts +88 -0
  98. package/dist/src/lib/rpc/provider.d.ts.map +1 -0
  99. package/dist/src/lib/rpc/provider.js +336 -0
  100. package/dist/src/lib/rpc/reporter.d.ts +18 -0
  101. package/dist/src/lib/rpc/reporter.d.ts.map +1 -0
  102. package/dist/src/lib/rpc/reporter.js +30 -0
  103. package/dist/src/lib/rpc/types.d.ts +409 -0
  104. package/dist/src/lib/rpc/types.d.ts.map +1 -0
  105. package/dist/src/lib/rpc/types.js +81 -0
  106. package/dist/src/lib/types.d.ts +18 -0
  107. package/dist/src/lib/types.d.ts.map +1 -0
  108. package/dist/src/lib/types.js +7 -0
  109. package/dist/src/lib/utils.d.ts +13 -0
  110. package/dist/src/lib/utils.d.ts.map +1 -0
  111. package/dist/src/lib/utils.js +97 -0
  112. package/dist/witnet/assets/index.d.ts +30 -0
  113. package/dist/witnet/assets/index.d.ts.map +1 -0
  114. package/dist/witnet/assets/index.js +6 -0
  115. package/dist/witnet/assets/modals/index.d.ts +18 -0
  116. package/dist/witnet/assets/modals/index.d.ts.map +1 -0
  117. package/dist/witnet/assets/modals/index.js +21 -0
  118. package/dist/witnet/assets/modals/web3/eth.d.ts +5 -0
  119. package/dist/witnet/assets/modals/web3/eth.d.ts.map +1 -0
  120. package/dist/witnet/assets/modals/web3/eth.js +26 -0
  121. package/dist/witnet/assets/modals/web3/wit.d.ts +4 -0
  122. package/dist/witnet/assets/modals/web3/wit.d.ts.map +1 -0
  123. package/dist/witnet/assets/modals/web3/wit.js +20 -0
  124. package/dist/witnet/assets/requests.d.ts +11 -0
  125. package/dist/witnet/assets/requests.d.ts.map +1 -0
  126. package/dist/witnet/assets/requests.js +88 -0
  127. package/dist/witnet/witnet.proto.json +1325 -0
  128. package/package.json +72 -0
  129. package/src/bin/cli/history.js +31 -0
  130. package/src/bin/cli/inspect.js +359 -0
  131. package/src/bin/cli/network.js +592 -0
  132. package/src/bin/cli/nodes.js +364 -0
  133. package/src/bin/cli/radon.js +814 -0
  134. package/src/bin/cli/wallet.js +1000 -0
  135. package/src/bin/helpers.js +829 -0
  136. package/src/bin/postinstall.js +9 -0
  137. package/src/bin/toolkit.js +294 -0
  138. package/witnet/assets/_index.js +8 -0
  139. package/witnet/assets/_requests.js +25 -0
  140. package/witnet/assets/_sources.js +36 -0
  141. package/witnet/assets/_templates.js +36 -0
  142. package/witnet/assets/index.js +4 -0
  143. package/witnet/assets/modals/index.js +25 -0
  144. package/witnet/assets/modals/web3/btc.js +0 -0
  145. package/witnet/assets/modals/web3/eth.js +29 -0
  146. package/witnet/assets/modals/web3/sol.js +0 -0
  147. package/witnet/assets/modals/web3/wit.js +23 -0
  148. package/witnet/assets/requests.js +94 -0
  149. package/witnet/witnet.proto.json +1325 -0
@@ -0,0 +1,170 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TransactionPayloadMultiSig = exports.TransactionPayload = void 0;
4
+ const protobufjs_1 = require("protobufjs");
5
+ const protoRoot = protobufjs_1.Root.fromJSON(require("../../../witnet/witnet.proto.json"));
6
+ const utils_1 = require("../utils");
7
+ const utils_2 = require("./utils");
8
+ const types_1 = require("./types");
9
+ class TransactionPayload {
10
+ constructor(protoTypeName, initialTarget) {
11
+ this._protoType = protoRoot.lookupType(protoTypeName);
12
+ this._target = this.validateTarget(initialTarget);
13
+ this._change = 0n;
14
+ this._covered = 0n;
15
+ this._fees = 0n;
16
+ }
17
+ get bytecode() {
18
+ // make toProtobuf return Protobuf's deserialized message
19
+ const obj = this.toProtobuf();
20
+ // console.log("TransactionPayload<Specs>.bytecode() =>", obj)
21
+ if (!obj)
22
+ return undefined;
23
+ const err = this._protoType.verify(obj);
24
+ if (err) {
25
+ throw TypeError(err);
26
+ }
27
+ else {
28
+ // console.log("\nobj =>", JSON.stringify(obj))
29
+ const message = this._protoType.fromObject(obj);
30
+ // console.log("\nmessage =>", JSON.stringify(message))
31
+ const bytecode = this._protoType.encode(message).finish();
32
+ // console.log("\nbytecode =>", toHexString(bytecode))
33
+ return bytecode;
34
+ }
35
+ }
36
+ get change() {
37
+ return this._change > 0 ? types_1.Coins.fromPedros(this._change) : undefined;
38
+ }
39
+ get covered() {
40
+ return (!!this.fees
41
+ && this._covered >= this.value.pedros + this.fees.pedros);
42
+ }
43
+ get fees() {
44
+ return this._fees > 0 ? types_1.Coins.fromPedros(this._fees) : undefined;
45
+ }
46
+ get hash() {
47
+ const _bytecode = this.bytecode;
48
+ if (_bytecode instanceof Uint8Array) {
49
+ return (0, utils_1.toHexString)((0, utils_2.sha256)(_bytecode));
50
+ }
51
+ else {
52
+ return undefined;
53
+ }
54
+ }
55
+ intoReceipt(target) {
56
+ return {
57
+ ...target
58
+ };
59
+ }
60
+ }
61
+ exports.TransactionPayload = TransactionPayload;
62
+ class TransactionPayloadMultiSig extends TransactionPayload {
63
+ constructor(protoTypeName, initialTarget) {
64
+ super(protoTypeName, initialTarget);
65
+ this._inputs = [];
66
+ this._outputs = [];
67
+ }
68
+ get inputs() {
69
+ return this._inputs;
70
+ }
71
+ get outputs() {
72
+ return this._outputs;
73
+ }
74
+ get prepared() {
75
+ return (this._inputs.length > 0
76
+ && this._outputs.length > 0);
77
+ }
78
+ async consumeUtxos(ledger, reload) {
79
+ if (!this._target) {
80
+ throw new Error(`${this.constructor.name}: internal error: no in-flight params.`);
81
+ }
82
+ const prepared = this.prepared;
83
+ if (!this.covered) {
84
+ // console.log(ledger.constructor.name, "cacheInfo =>", ledger.pkh, ledger.cacheInfo)
85
+ // console.log(await ledger.getUtxos())
86
+ // consume utxos as to cover this.value, at least
87
+ const utxos = await ledger.selectUtxos({
88
+ value: types_1.Coins.fromPedros(this.value.pedros - this._covered),
89
+ reload,
90
+ });
91
+ this._covered += utxos.map(utxo => utxo.value).reduce((prev, curr) => prev + curr, 0n);
92
+ this._inputs.push(...utxos);
93
+ ledger.consumeUtxos(...utxos);
94
+ // try to cover fees only if this.value is covered first
95
+ if (this._covered >= this.value.pedros) {
96
+ // console.log(this._inputs)
97
+ // console.log("remaining utxos =>", await ledger.getUtxos())
98
+ if (this._target?.fees instanceof types_1.Coins) {
99
+ this._fees = this._target.fees.pedros;
100
+ // console.log(this._covered, this.value.pedros, this._fees, this._covered < this.value.pedros + this._fees)
101
+ if (this._covered < this.value.pedros + this._fees) {
102
+ // console.log("more utxos required...")
103
+ const extras = await ledger.selectUtxos({
104
+ value: types_1.Coins.fromPedros(this.value.pedros + this._fees - this._covered),
105
+ });
106
+ ledger.consumeUtxos(...extras);
107
+ this._covered += extras.map(utxo => utxo.value).reduce((prev, curr) => prev + curr);
108
+ this._inputs.push(...extras);
109
+ }
110
+ this._change = this._covered - (this.value.pedros + this._fees);
111
+ // console.log(this._change)
112
+ }
113
+ else {
114
+ const priority = this._target?.fees || types_1.TransactionPriority.Opulent;
115
+ let estimatedFees = await this._estimateNetworkFees(ledger.provider, priority);
116
+ while (this._fees < estimatedFees) {
117
+ this._fees = estimatedFees;
118
+ this._outputs = [];
119
+ // add more utxos only if the ones selected for covering the value and the estimate fees don't suffice:
120
+ if (this._covered < this.value.pedros + this._fees) {
121
+ const extras = await ledger.selectUtxos({
122
+ value: types_1.Coins.fromPedros(this.value.pedros + this._fees - this._covered)
123
+ });
124
+ ledger.consumeUtxos(...extras);
125
+ this._covered += extras.map(utxo => utxo.value).reduce((prev, curr) => prev + curr);
126
+ this._inputs.push(...extras);
127
+ }
128
+ this._change = this._covered - (this.value.pedros + this._fees);
129
+ if (this._change < 0) {
130
+ // insufficient funds ...
131
+ break;
132
+ }
133
+ else {
134
+ this.prepareOutputs({ value: this._change, pkh: ledger.changePkh });
135
+ // iterate until actual fees match estimated fees
136
+ estimatedFees = await this._estimateNetworkFees(ledger.provider, priority);
137
+ }
138
+ }
139
+ }
140
+ }
141
+ }
142
+ // prepare outputs, only if value and fees got fully covered for the first time:
143
+ if (this._change >= 0 && !prepared) {
144
+ // console.log('-'.repeat(80))
145
+ // console.log(this._inputs)
146
+ this.prepareOutputs({ value: this._change, pkh: ledger.changePkh });
147
+ }
148
+ return this._change;
149
+ }
150
+ prepareOutputs(change) {
151
+ if (change?.value) {
152
+ this._outputs.push({
153
+ pkh: change.pkh,
154
+ value: change.value,
155
+ time_lock: 0,
156
+ });
157
+ }
158
+ }
159
+ resetTarget(target) {
160
+ this._change = 0n;
161
+ this._covered = 0n;
162
+ this._fees = 0n;
163
+ this._inputs = [];
164
+ this._outputs = [];
165
+ this._target = target;
166
+ delete this._priorities;
167
+ }
168
+ }
169
+ 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"]}
@@ -0,0 +1,33 @@
1
+ import { Balance, Network, QueryStakesOrder, StakeEntry } from "../types";
2
+ import { IBIP32, IJsonRpcProvider, ISigner } from "./interfaces";
3
+ import { Coins, KeyedSignature, PublicKey, PublicKeyHashString, Utxo, UtxoCacheInfo, UtxoSelectionStrategy } from "./types";
4
+ export declare class Signer implements ISigner {
5
+ protected node: IBIP32;
6
+ protected utxos: Array<Utxo>;
7
+ private _initialized;
8
+ readonly provider: IJsonRpcProvider;
9
+ strategy: UtxoSelectionStrategy;
10
+ constructor(node: IBIP32, provider: IJsonRpcProvider, strategy?: UtxoSelectionStrategy);
11
+ get cacheInfo(): UtxoCacheInfo;
12
+ get changePkh(): PublicKeyHashString;
13
+ get network(): Network;
14
+ get pkh(): PublicKeyHashString;
15
+ get publicKey(): PublicKey;
16
+ addUtxos(...utxos: Array<Utxo>): {
17
+ excluded: Array<Utxo>;
18
+ included: Array<Utxo>;
19
+ };
20
+ consumeUtxos(...utxos: Array<Utxo>): Array<Utxo>;
21
+ getBalance(): Promise<Balance>;
22
+ getDelegatees(order?: QueryStakesOrder): Promise<Array<StakeEntry>>;
23
+ getSigner(pkh?: PublicKeyHashString): ISigner | undefined;
24
+ getUtxos(reload?: boolean): Promise<Array<Utxo>>;
25
+ selectUtxos(specs?: {
26
+ value?: Coins;
27
+ reload?: boolean;
28
+ strategy?: UtxoSelectionStrategy;
29
+ }): Promise<Array<Utxo>>;
30
+ getStakeEntryNonce(validator: PublicKeyHashString): Promise<number>;
31
+ signHash(hash: any): KeyedSignature;
32
+ }
33
+ //# sourceMappingURL=signer.d.ts.map
@@ -0,0 +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"}
@@ -0,0 +1,194 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.Signer = void 0;
37
+ const secp256k1 = require('secp256k1');
38
+ const utils = __importStar(require("../utils"));
39
+ const types_1 = require("./types");
40
+ const utils_1 = require("./utils");
41
+ class Signer {
42
+ constructor(node, provider, strategy) {
43
+ this.utxos = [];
44
+ this.node = node;
45
+ this.provider = provider;
46
+ this.strategy = strategy || types_1.UtxoSelectionStrategy.SlimFit;
47
+ if (!provider.network) {
48
+ throw Error(`Signer: internal error: unintialized provider.`);
49
+ }
50
+ this._initialized = false;
51
+ }
52
+ // ================================================================================================================
53
+ // --- ILedger ----------------------------------------------------------------------------------------------------
54
+ get cacheInfo() {
55
+ const now = Math.floor(Date.now() / 1000);
56
+ let expendable = 0n;
57
+ let timelock = Number.MAX_SAFE_INTEGER;
58
+ this.utxos.map(utxo => {
59
+ if (utxo.timelock > now) {
60
+ if (utxo.timelock < timelock) {
61
+ timelock = utxo.timelock;
62
+ }
63
+ }
64
+ else {
65
+ expendable += utxo.value;
66
+ }
67
+ });
68
+ if (timelock === Number.MAX_SAFE_INTEGER)
69
+ timelock = 0;
70
+ return { expendable, timelock, size: this.utxos.length };
71
+ }
72
+ get changePkh() {
73
+ return this.pkh;
74
+ }
75
+ get network() {
76
+ return this.provider.network || "mainnet";
77
+ }
78
+ get pkh() {
79
+ return this.publicKey.hash().toBech32(this.network);
80
+ }
81
+ get publicKey() {
82
+ return types_1.PublicKey.fromUint8Array(this.node.publicKey);
83
+ }
84
+ addUtxos(...utxos) {
85
+ const excluded = [];
86
+ const existingPointers = new Set(this.utxos.map(cached => cached.output_pointer));
87
+ const included = utxos.filter(utxo => {
88
+ if (utxo.signer === this.pkh) {
89
+ // avoid adding duplicates
90
+ if (!existingPointers.has(utxo.output_pointer)) {
91
+ existingPointers.add(utxo.output_pointer);
92
+ return true;
93
+ }
94
+ else {
95
+ return false;
96
+ }
97
+ }
98
+ else {
99
+ excluded.push(utxo);
100
+ return false;
101
+ }
102
+ });
103
+ this.utxos.push(...included);
104
+ return { excluded, included };
105
+ }
106
+ consumeUtxos(...utxos) {
107
+ this.utxos = this.utxos.filter(cached => {
108
+ const incomingIndex = utxos.findIndex(incoming => cached.output_pointer === incoming.output_pointer);
109
+ if (incomingIndex >= 0) {
110
+ utxos.splice(incomingIndex, 1);
111
+ return false;
112
+ }
113
+ else {
114
+ return true;
115
+ }
116
+ });
117
+ // console.log("Signer.consumeUtxos: remaining:", utxos)
118
+ return utxos;
119
+ }
120
+ async getBalance() {
121
+ return this.provider.getBalance(this.pkh);
122
+ }
123
+ async getDelegatees(order) {
124
+ return this.provider.stakes({
125
+ filter: { withdrawer: this.pkh },
126
+ params: { order },
127
+ });
128
+ }
129
+ getSigner(pkh) {
130
+ return (!pkh || pkh === this.pkh) ? this : undefined;
131
+ }
132
+ async getUtxos(reload = false) {
133
+ if (reload || !this._initialized) {
134
+ this._initialized = true;
135
+ this.utxos = (await this.provider.getUtxos(this.pkh))
136
+ .map(utxo => ({ ...utxo, signer: this.pkh }));
137
+ }
138
+ return this.utxos;
139
+ }
140
+ async selectUtxos(specs) {
141
+ return this
142
+ .getUtxos(specs?.reload)
143
+ .then(utxos => (0, utils_1.selectUtxos)({ utxos, value: specs?.value, strategy: specs?.strategy || this.strategy }));
144
+ }
145
+ // ================================================================================================================
146
+ // --- ISigner ----------------------------------------------------------------------------------------------------
147
+ async getStakeEntryNonce(validator) {
148
+ return this.provider
149
+ .stakes({ filter: {
150
+ validator,
151
+ withdrawer: this.pkh
152
+ } }).then(([entry]) => entry.value.nonce);
153
+ }
154
+ signHash(hash) {
155
+ let buffer;
156
+ if (hash instanceof Uint8Array) {
157
+ buffer = Buffer.from(hash);
158
+ }
159
+ else if (hash instanceof Buffer) {
160
+ buffer = hash;
161
+ }
162
+ else if (typeof hash === 'string') {
163
+ buffer = Buffer.from(utils.fromHexString(hash));
164
+ }
165
+ else {
166
+ throw new Error(`${this.constructor.name}: unsupported hash value: ${hash}`);
167
+ }
168
+ if (!buffer || buffer.length !== 32) {
169
+ throw new Error(`${this.constructor.name}: invalid hash length: ${buffer.length} != 32`);
170
+ }
171
+ else if (this.node.privateKey) {
172
+ const msg = Uint8Array.from(buffer);
173
+ const privateKey = Uint8Array.from(Buffer.from(this.node.privateKey));
174
+ const signature = secp256k1.ecdsaSign(msg, privateKey).signature;
175
+ const der = secp256k1.signatureExport(signature);
176
+ return {
177
+ public_key: {
178
+ compressed: this.publicKey.compressed,
179
+ bytes: Array.from(this.publicKey.bytes),
180
+ },
181
+ signature: {
182
+ Secp256k1: {
183
+ der: Array.from(der),
184
+ }
185
+ }
186
+ };
187
+ }
188
+ else {
189
+ throw Error(`Signer: invalid BIP32 node: no private key`);
190
+ }
191
+ }
192
+ }
193
+ 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"]}
@@ -0,0 +1,15 @@
1
+ import { RadonRequest, RadonTemplate } from "../../radon";
2
+ import { DataRequestPayload, DataRequestParams } from "../payloads/DataRequestPayload";
3
+ import { ILedger } from "../interfaces";
4
+ import { TransmitterMultiSig } from "../transmitters";
5
+ import { PublicKeyHashString } from "../types";
6
+ export { DataRequestParams } from "../payloads/DataRequestPayload";
7
+ export declare class DataRequests extends TransmitterMultiSig<DataRequestParams, DataRequestPayload> {
8
+ static COLLATERAL_RATIO: number;
9
+ static MAX_WEIGHT: number;
10
+ static from(ledger: ILedger, artifact: RadonRequest | RadonTemplate): DataRequests;
11
+ constructor(artifact: RadonRequest | RadonTemplate, ledger: ILedger, changePkh?: PublicKeyHashString);
12
+ get request(): RadonRequest | undefined;
13
+ get template(): RadonTemplate | undefined;
14
+ }
15
+ //# sourceMappingURL=DataRequests.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DataRequests.d.ts","sourceRoot":"","sources":["../../../../../src/lib/crypto/transmitters/DataRequests.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,aAAa,CAAA;AAEzD,OAAO,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAA;AACtF,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAA;AACvC,OAAO,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAA;AACrD,OAAO,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAA;AAE9C,OAAO,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAA;AAElE,qBAAa,YAAa,SAAQ,mBAAmB,CAAC,iBAAiB,EAAE,kBAAkB,CAAC;IAExF,OAAc,gBAAgB,SAAuC;IACrE,OAAc,UAAU,SAAiC;WAE3C,IAAI,CAAC,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,GAAG,aAAa,GAAI,YAAY;gBAI7E,QAAQ,EAAE,YAAY,GAAG,aAAa,EAAE,MAAM,EAAE,OAAO,EAAE,SAAS,CAAC,EAAE,mBAAmB;IAIrG,IAAW,OAAO,IAAI,YAAY,GAAG,SAAS,CAE7C;IAED,IAAW,QAAQ,IAAI,aAAa,GAAG,SAAS,CAE/C;CACJ"}
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.DataRequests = void 0;
4
+ const DataRequestPayload_1 = require("../payloads/DataRequestPayload");
5
+ const transmitters_1 = require("../transmitters");
6
+ class DataRequests extends transmitters_1.TransmitterMultiSig {
7
+ static from(ledger, artifact) {
8
+ return new DataRequests(artifact, ledger);
9
+ }
10
+ constructor(artifact, ledger, changePkh) {
11
+ super("DRTransaction", new DataRequestPayload_1.DataRequestPayload("DRTransactionBody", artifact), ledger, changePkh);
12
+ }
13
+ get request() {
14
+ return this._payload.request;
15
+ }
16
+ get template() {
17
+ return this._payload.template;
18
+ }
19
+ }
20
+ exports.DataRequests = DataRequests;
21
+ DataRequests.COLLATERAL_RATIO = DataRequestPayload_1.DataRequestPayload.COLLATERAL_RATIO;
22
+ DataRequests.MAX_WEIGHT = DataRequestPayload_1.DataRequestPayload.MAX_WEIGHT;
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiRGF0YVJlcXVlc3RzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2xpYi9jcnlwdG8vdHJhbnNtaXR0ZXJzL0RhdGFSZXF1ZXN0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFFQSx1RUFBc0Y7QUFFdEYsa0RBQXFEO0FBS3JELE1BQWEsWUFBYSxTQUFRLGtDQUEwRDtJQUtqRixNQUFNLENBQUMsSUFBSSxDQUFDLE1BQWUsRUFBRSxRQUFzQztRQUN0RSxPQUFPLElBQUksWUFBWSxDQUFDLFFBQVEsRUFBRSxNQUFNLENBQUMsQ0FBQTtJQUM3QyxDQUFDO0lBRUQsWUFBYSxRQUFzQyxFQUFFLE1BQWUsRUFBRSxTQUErQjtRQUNqRyxLQUFLLENBQUMsZUFBZSxFQUFFLElBQUksdUNBQWtCLENBQUMsbUJBQW1CLEVBQUUsUUFBUSxDQUFDLEVBQUUsTUFBTSxFQUFFLFNBQVMsQ0FBQyxDQUFBO0lBQ3BHLENBQUM7SUFFRCxJQUFXLE9BQU87UUFDZCxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFBO0lBQ2hDLENBQUM7SUFFRCxJQUFXLFFBQVE7UUFDZixPQUFPLElBQUksQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFBO0lBQ2pDLENBQUM7O0FBbkJMLG9DQW9CQztBQWxCaUIsNkJBQWdCLEdBQUcsdUNBQWtCLENBQUMsZ0JBQWdCLENBQUM7QUFDdkQsdUJBQVUsR0FBRyx1Q0FBa0IsQ0FBQyxVQUFVLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSYWRvblJlcXVlc3QsIFJhZG9uVGVtcGxhdGUgfSBmcm9tIFwiLi4vLi4vcmFkb25cIlxyXG5cclxuaW1wb3J0IHsgRGF0YVJlcXVlc3RQYXlsb2FkLCBEYXRhUmVxdWVzdFBhcmFtcyB9IGZyb20gXCIuLi9wYXlsb2Fkcy9EYXRhUmVxdWVzdFBheWxvYWRcIlxyXG5pbXBvcnQgeyBJTGVkZ2VyIH0gZnJvbSBcIi4uL2ludGVyZmFjZXNcIlxyXG5pbXBvcnQgeyBUcmFuc21pdHRlck11bHRpU2lnIH0gZnJvbSBcIi4uL3RyYW5zbWl0dGVyc1wiXHJcbmltcG9ydCB7IFB1YmxpY0tleUhhc2hTdHJpbmcgfSBmcm9tIFwiLi4vdHlwZXNcIlxyXG5cclxuZXhwb3J0IHsgRGF0YVJlcXVlc3RQYXJhbXMgfSBmcm9tIFwiLi4vcGF5bG9hZHMvRGF0YVJlcXVlc3RQYXlsb2FkXCJcclxuXHJcbmV4cG9ydCBjbGFzcyBEYXRhUmVxdWVzdHMgZXh0ZW5kcyBUcmFuc21pdHRlck11bHRpU2lnPERhdGFSZXF1ZXN0UGFyYW1zLCBEYXRhUmVxdWVzdFBheWxvYWQ+IHtcclxuICAgIFxyXG4gICAgcHVibGljIHN0YXRpYyBDT0xMQVRFUkFMX1JBVElPID0gRGF0YVJlcXVlc3RQYXlsb2FkLkNPTExBVEVSQUxfUkFUSU87XHJcbiAgICBwdWJsaWMgc3RhdGljIE1BWF9XRUlHSFQgPSBEYXRhUmVxdWVzdFBheWxvYWQuTUFYX1dFSUdIVDtcclxuXHJcbiAgICBwdWJsaWMgc3RhdGljIGZyb20obGVkZ2VyOiBJTGVkZ2VyLCBhcnRpZmFjdDogUmFkb25SZXF1ZXN0IHwgUmFkb25UZW1wbGF0ZSkgOiBEYXRhUmVxdWVzdHMge1xyXG4gICAgICAgIHJldHVybiBuZXcgRGF0YVJlcXVlc3RzKGFydGlmYWN0LCBsZWRnZXIpXHJcbiAgICB9XHJcblxyXG4gICAgY29uc3RydWN0b3IgKGFydGlmYWN0OiBSYWRvblJlcXVlc3QgfCBSYWRvblRlbXBsYXRlLCBsZWRnZXI6IElMZWRnZXIsIGNoYW5nZVBraD86IFB1YmxpY0tleUhhc2hTdHJpbmcpIHtcclxuICAgICAgICBzdXBlcihcIkRSVHJhbnNhY3Rpb25cIiwgbmV3IERhdGFSZXF1ZXN0UGF5bG9hZChcIkRSVHJhbnNhY3Rpb25Cb2R5XCIsIGFydGlmYWN0KSwgbGVkZ2VyLCBjaGFuZ2VQa2gpXHJcbiAgICB9XHJcblxyXG4gICAgcHVibGljIGdldCByZXF1ZXN0KCk6IFJhZG9uUmVxdWVzdCB8IHVuZGVmaW5lZCB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuX3BheWxvYWQucmVxdWVzdFxyXG4gICAgfVxyXG5cclxuICAgIHB1YmxpYyBnZXQgdGVtcGxhdGUoKTogUmFkb25UZW1wbGF0ZSB8IHVuZGVmaW5lZCB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuX3BheWxvYWQudGVtcGxhdGVcclxuICAgIH1cclxufVxyXG4iXX0=
@@ -0,0 +1,12 @@
1
+ import { StakePayload, StakeDepositParams } from "../payloads/StakePayload";
2
+ import { ILedger } from "../interfaces";
3
+ import { TransmitterMultiSig } from "../transmitters";
4
+ import { PublicKeyHashString } from "../types";
5
+ export { StakeDepositParams } from "../payloads/StakePayload";
6
+ export declare class StakeDeposits extends TransmitterMultiSig<StakeDepositParams, StakePayload> {
7
+ static MAX_WEIGHT: number;
8
+ static MIN_VALUE: number;
9
+ static from(ledger: ILedger): StakeDeposits;
10
+ constructor(ledger: ILedger, changePkh?: PublicKeyHashString);
11
+ }
12
+ //# sourceMappingURL=StakeDeposits.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StakeDeposits.d.ts","sourceRoot":"","sources":["../../../../../src/lib/crypto/transmitters/StakeDeposits.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAA;AAE3E,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAA;AACvC,OAAO,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAA;AACrD,OAAO,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAA;AAE9C,OAAO,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAA;AAE7D,qBAAa,aAAc,SAAQ,mBAAmB,CAAC,kBAAkB,EAAE,YAAY,CAAC;IAEpF,OAAc,UAAU,SAA2B;IACnD,OAAc,SAAS,SAA0B;WAEnC,IAAI,CAAC,MAAM,EAAE,OAAO,GAAG,aAAa;gBAIrC,MAAM,EAAE,OAAO,EAAE,SAAS,CAAC,EAAE,mBAAmB;CAGhE"}
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.StakeDeposits = void 0;
4
+ const StakePayload_1 = require("../payloads/StakePayload");
5
+ const transmitters_1 = require("../transmitters");
6
+ class StakeDeposits extends transmitters_1.TransmitterMultiSig {
7
+ static from(ledger) {
8
+ return new StakeDeposits(ledger);
9
+ }
10
+ constructor(ledger, changePkh) {
11
+ super("StakeTransaction", new StakePayload_1.StakePayload("StakeTransactionBody"), ledger, changePkh);
12
+ }
13
+ }
14
+ exports.StakeDeposits = StakeDeposits;
15
+ StakeDeposits.MAX_WEIGHT = StakePayload_1.StakePayload.MAX_WEIGHT;
16
+ StakeDeposits.MIN_VALUE = StakePayload_1.StakePayload.MIN_VALUE;
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU3Rha2VEZXBvc2l0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9saWIvY3J5cHRvL3RyYW5zbWl0dGVycy9TdGFrZURlcG9zaXRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLDJEQUEyRTtBQUczRSxrREFBcUQ7QUFLckQsTUFBYSxhQUFjLFNBQVEsa0NBQXFEO0lBSzdFLE1BQU0sQ0FBQyxJQUFJLENBQUMsTUFBZTtRQUM5QixPQUFPLElBQUksYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFBO0lBQ3BDLENBQUM7SUFFRCxZQUFhLE1BQWUsRUFBRSxTQUErQjtRQUN6RCxLQUFLLENBQUMsa0JBQWtCLEVBQUUsSUFBSSwyQkFBWSxDQUFDLHNCQUFzQixDQUFDLEVBQUUsTUFBTSxFQUFFLFNBQVMsQ0FBQyxDQUFBO0lBQzFGLENBQUM7O0FBWEwsc0NBWUM7QUFWaUIsd0JBQVUsR0FBRywyQkFBWSxDQUFDLFVBQVUsQ0FBQztBQUNyQyx1QkFBUyxHQUFHLDJCQUFZLENBQUMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU3Rha2VQYXlsb2FkLCBTdGFrZURlcG9zaXRQYXJhbXMgfSBmcm9tIFwiLi4vcGF5bG9hZHMvU3Rha2VQYXlsb2FkXCJcclxuXHJcbmltcG9ydCB7IElMZWRnZXIgfSBmcm9tIFwiLi4vaW50ZXJmYWNlc1wiXHJcbmltcG9ydCB7IFRyYW5zbWl0dGVyTXVsdGlTaWcgfSBmcm9tIFwiLi4vdHJhbnNtaXR0ZXJzXCJcclxuaW1wb3J0IHsgUHVibGljS2V5SGFzaFN0cmluZyB9IGZyb20gXCIuLi90eXBlc1wiXHJcblxyXG5leHBvcnQgeyBTdGFrZURlcG9zaXRQYXJhbXMgfSBmcm9tIFwiLi4vcGF5bG9hZHMvU3Rha2VQYXlsb2FkXCJcclxuXHJcbmV4cG9ydCBjbGFzcyBTdGFrZURlcG9zaXRzIGV4dGVuZHMgVHJhbnNtaXR0ZXJNdWx0aVNpZzxTdGFrZURlcG9zaXRQYXJhbXMsIFN0YWtlUGF5bG9hZD4ge1xyXG4gICAgXHJcbiAgICBwdWJsaWMgc3RhdGljIE1BWF9XRUlHSFQgPSBTdGFrZVBheWxvYWQuTUFYX1dFSUdIVDtcclxuICAgIHB1YmxpYyBzdGF0aWMgTUlOX1ZBTFVFID0gU3Rha2VQYXlsb2FkLk1JTl9WQUxVRTtcclxuXHJcbiAgICBwdWJsaWMgc3RhdGljIGZyb20obGVkZ2VyOiBJTGVkZ2VyKTogU3Rha2VEZXBvc2l0cyB7XHJcbiAgICAgICAgcmV0dXJuIG5ldyBTdGFrZURlcG9zaXRzKGxlZGdlcilcclxuICAgIH1cclxuXHJcbiAgICBjb25zdHJ1Y3RvciAobGVkZ2VyOiBJTGVkZ2VyLCBjaGFuZ2VQa2g/OiBQdWJsaWNLZXlIYXNoU3RyaW5nKSB7XHJcbiAgICAgICAgc3VwZXIoXCJTdGFrZVRyYW5zYWN0aW9uXCIsIG5ldyBTdGFrZVBheWxvYWQoXCJTdGFrZVRyYW5zYWN0aW9uQm9keVwiKSwgbGVkZ2VyLCBjaGFuZ2VQa2gpXHJcbiAgICB9XHJcbn1cclxuIl19
@@ -0,0 +1,18 @@
1
+ import { UnstakePayload, StakeWithdrawalParams } from "../payloads/UnstakePayload";
2
+ import { TransactionReceipt } from "../types";
3
+ import { ILedger } from "../interfaces";
4
+ import { Transmitter } from "../transmitters";
5
+ import { PublicKeyHashString } from "../types";
6
+ import { Hash } from "../../types";
7
+ export { StakeWithdrawalParams } from "../payloads/UnstakePayload";
8
+ export declare class StakeWithdrawals extends Transmitter<StakeWithdrawalParams, UnstakePayload> {
9
+ static MIN_TIMELOCK_SECS: number;
10
+ static WEIGHT: number;
11
+ static from(ledger: ILedger): StakeWithdrawals;
12
+ constructor(ledger: ILedger, changePkh?: PublicKeyHashString);
13
+ signTransaction(params?: StakeWithdrawalParams, reload?: boolean): Promise<TransactionReceipt>;
14
+ _signTransactionPayload(): Hash;
15
+ protected _toJSON(humanize: boolean): any;
16
+ protected _toProtobuf(): any;
17
+ }
18
+ //# sourceMappingURL=StakeWithdrawals.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StakeWithdrawals.d.ts","sourceRoot":"","sources":["../../../../../src/lib/crypto/transmitters/StakeWithdrawals.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAA;AAElF,OAAO,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAA;AAC7C,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAA;AACvC,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAA;AAC7C,OAAO,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAA;AAE9C,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAA;AAElC,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAA;AAElE,qBAAa,gBAAiB,SAAQ,WAAW,CAAC,qBAAqB,EAAE,cAAc,CAAC;IAEpF,OAAc,iBAAiB,SAAmC;IAClE,OAAc,MAAM,SAAwB;WAE9B,IAAI,CAAC,MAAM,EAAE,OAAO,GAAG,gBAAgB;gBAIxC,MAAM,EAAE,OAAO,EAAE,SAAS,CAAC,EAAE,mBAAmB;IAIhD,eAAe,CAAC,MAAM,CAAC,EAAE,qBAAqB,EAAE,MAAM,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAIpG,uBAAuB,IAAI,IAAI;IAoBtC,SAAS,CAAC,OAAO,CAAC,QAAQ,EAAE,OAAO,GAAG,GAAG;IASzC,SAAS,CAAC,WAAW,IAAI,GAAG;CAS/B"}