@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.
- package/LICENSE +21 -0
- package/README.md +103 -0
- package/dist/package.json +72 -0
- package/dist/src/bin/helpers.d.ts +91 -0
- package/dist/src/bin/helpers.d.ts.map +1 -0
- package/dist/src/bin/helpers.js +816 -0
- package/dist/src/index.d.ts +5 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +47 -0
- package/dist/src/lib/crypto/account.d.ts +32 -0
- package/dist/src/lib/crypto/account.d.ts.map +1 -0
- package/dist/src/lib/crypto/account.js +106 -0
- package/dist/src/lib/crypto/coinbase.d.ts +10 -0
- package/dist/src/lib/crypto/coinbase.d.ts.map +1 -0
- package/dist/src/lib/crypto/coinbase.js +28 -0
- package/dist/src/lib/crypto/index.d.ts +8 -0
- package/dist/src/lib/crypto/index.d.ts.map +1 -0
- package/dist/src/lib/crypto/index.js +30 -0
- package/dist/src/lib/crypto/interfaces.d.ts +85 -0
- package/dist/src/lib/crypto/interfaces.d.ts.map +1 -0
- package/dist/src/lib/crypto/interfaces.js +3 -0
- package/dist/src/lib/crypto/payloads/DataRequestPayload.d.ts +55 -0
- package/dist/src/lib/crypto/payloads/DataRequestPayload.d.ts.map +1 -0
- package/dist/src/lib/crypto/payloads/DataRequestPayload.js +339 -0
- package/dist/src/lib/crypto/payloads/StakePayload.d.ts +28 -0
- package/dist/src/lib/crypto/payloads/StakePayload.d.ts.map +1 -0
- package/dist/src/lib/crypto/payloads/StakePayload.js +142 -0
- package/dist/src/lib/crypto/payloads/UnstakePayload.d.ts +36 -0
- package/dist/src/lib/crypto/payloads/UnstakePayload.d.ts.map +1 -0
- package/dist/src/lib/crypto/payloads/UnstakePayload.js +154 -0
- package/dist/src/lib/crypto/payloads/ValueTransferPayload.d.ts +25 -0
- package/dist/src/lib/crypto/payloads/ValueTransferPayload.d.ts.map +1 -0
- package/dist/src/lib/crypto/payloads/ValueTransferPayload.js +128 -0
- package/dist/src/lib/crypto/payloads.d.ts +57 -0
- package/dist/src/lib/crypto/payloads.d.ts.map +1 -0
- package/dist/src/lib/crypto/payloads.js +170 -0
- package/dist/src/lib/crypto/signer.d.ts +33 -0
- package/dist/src/lib/crypto/signer.d.ts.map +1 -0
- package/dist/src/lib/crypto/signer.js +194 -0
- package/dist/src/lib/crypto/transmitters/DataRequests.d.ts +15 -0
- package/dist/src/lib/crypto/transmitters/DataRequests.d.ts.map +1 -0
- package/dist/src/lib/crypto/transmitters/DataRequests.js +23 -0
- package/dist/src/lib/crypto/transmitters/StakeDeposits.d.ts +12 -0
- package/dist/src/lib/crypto/transmitters/StakeDeposits.d.ts.map +1 -0
- package/dist/src/lib/crypto/transmitters/StakeDeposits.js +17 -0
- package/dist/src/lib/crypto/transmitters/StakeWithdrawals.d.ts +18 -0
- package/dist/src/lib/crypto/transmitters/StakeWithdrawals.d.ts.map +1 -0
- package/dist/src/lib/crypto/transmitters/StakeWithdrawals.js +53 -0
- package/dist/src/lib/crypto/transmitters/ValueTransfers.d.ts +11 -0
- package/dist/src/lib/crypto/transmitters/ValueTransfers.d.ts.map +1 -0
- package/dist/src/lib/crypto/transmitters/ValueTransfers.js +16 -0
- package/dist/src/lib/crypto/transmitters.d.ts +47 -0
- package/dist/src/lib/crypto/transmitters.d.ts.map +1 -0
- package/dist/src/lib/crypto/transmitters.js +416 -0
- package/dist/src/lib/crypto/types.d.ts +161 -0
- package/dist/src/lib/crypto/types.d.ts.map +1 -0
- package/dist/src/lib/crypto/types.js +273 -0
- package/dist/src/lib/crypto/utils.d.ts +21 -0
- package/dist/src/lib/crypto/utils.d.ts.map +1 -0
- package/dist/src/lib/crypto/utils.js +156 -0
- package/dist/src/lib/crypto/wallet.d.ts +120 -0
- package/dist/src/lib/crypto/wallet.d.ts.map +1 -0
- package/dist/src/lib/crypto/wallet.js +258 -0
- package/dist/src/lib/index.d.ts +5 -0
- package/dist/src/lib/index.d.ts.map +1 -0
- package/dist/src/lib/index.js +44 -0
- package/dist/src/lib/radon/ccdr/eth.d.ts +160 -0
- package/dist/src/lib/radon/ccdr/eth.d.ts.map +1 -0
- package/dist/src/lib/radon/ccdr/eth.js +272 -0
- package/dist/src/lib/radon/ccdr/index.d.ts +14 -0
- package/dist/src/lib/radon/ccdr/index.d.ts.map +1 -0
- package/dist/src/lib/radon/ccdr/index.js +39 -0
- package/dist/src/lib/radon/ccdr/wit.d.ts +23 -0
- package/dist/src/lib/radon/ccdr/wit.d.ts.map +1 -0
- package/dist/src/lib/radon/ccdr/wit.js +35 -0
- package/dist/src/lib/radon/filters.d.ts +14 -0
- package/dist/src/lib/radon/filters.d.ts.map +1 -0
- package/dist/src/lib/radon/filters.js +45 -0
- package/dist/src/lib/radon/index.d.ts +296 -0
- package/dist/src/lib/radon/index.d.ts.map +1 -0
- package/dist/src/lib/radon/index.js +707 -0
- package/dist/src/lib/radon/reducers.d.ts +29 -0
- package/dist/src/lib/radon/reducers.d.ts.map +1 -0
- package/dist/src/lib/radon/reducers.js +66 -0
- package/dist/src/lib/radon/types.d.ts +521 -0
- package/dist/src/lib/radon/types.d.ts.map +1 -0
- package/dist/src/lib/radon/types.js +936 -0
- package/dist/src/lib/radon/utils.d.ts +53 -0
- package/dist/src/lib/radon/utils.d.ts.map +1 -0
- package/dist/src/lib/radon/utils.js +153 -0
- package/dist/src/lib/rpc/index.d.ts +3 -0
- package/dist/src/lib/rpc/index.d.ts.map +1 -0
- package/dist/src/lib/rpc/index.js +19 -0
- package/dist/src/lib/rpc/nodes.d.ts +40 -0
- package/dist/src/lib/rpc/nodes.d.ts.map +1 -0
- package/dist/src/lib/rpc/nodes.js +293 -0
- package/dist/src/lib/rpc/provider.d.ts +88 -0
- package/dist/src/lib/rpc/provider.d.ts.map +1 -0
- package/dist/src/lib/rpc/provider.js +336 -0
- package/dist/src/lib/rpc/reporter.d.ts +18 -0
- package/dist/src/lib/rpc/reporter.d.ts.map +1 -0
- package/dist/src/lib/rpc/reporter.js +30 -0
- package/dist/src/lib/rpc/types.d.ts +409 -0
- package/dist/src/lib/rpc/types.d.ts.map +1 -0
- package/dist/src/lib/rpc/types.js +81 -0
- package/dist/src/lib/types.d.ts +18 -0
- package/dist/src/lib/types.d.ts.map +1 -0
- package/dist/src/lib/types.js +7 -0
- package/dist/src/lib/utils.d.ts +13 -0
- package/dist/src/lib/utils.d.ts.map +1 -0
- package/dist/src/lib/utils.js +97 -0
- package/dist/witnet/assets/index.d.ts +30 -0
- package/dist/witnet/assets/index.d.ts.map +1 -0
- package/dist/witnet/assets/index.js +6 -0
- package/dist/witnet/assets/modals/index.d.ts +18 -0
- package/dist/witnet/assets/modals/index.d.ts.map +1 -0
- package/dist/witnet/assets/modals/index.js +21 -0
- package/dist/witnet/assets/modals/web3/eth.d.ts +5 -0
- package/dist/witnet/assets/modals/web3/eth.d.ts.map +1 -0
- package/dist/witnet/assets/modals/web3/eth.js +26 -0
- package/dist/witnet/assets/modals/web3/wit.d.ts +4 -0
- package/dist/witnet/assets/modals/web3/wit.d.ts.map +1 -0
- package/dist/witnet/assets/modals/web3/wit.js +20 -0
- package/dist/witnet/assets/requests.d.ts +11 -0
- package/dist/witnet/assets/requests.d.ts.map +1 -0
- package/dist/witnet/assets/requests.js +88 -0
- package/dist/witnet/witnet.proto.json +1325 -0
- package/package.json +72 -0
- package/src/bin/cli/history.js +31 -0
- package/src/bin/cli/inspect.js +359 -0
- package/src/bin/cli/network.js +592 -0
- package/src/bin/cli/nodes.js +364 -0
- package/src/bin/cli/radon.js +814 -0
- package/src/bin/cli/wallet.js +1000 -0
- package/src/bin/helpers.js +829 -0
- package/src/bin/postinstall.js +9 -0
- package/src/bin/toolkit.js +294 -0
- package/witnet/assets/_index.js +8 -0
- package/witnet/assets/_requests.js +25 -0
- package/witnet/assets/_sources.js +36 -0
- package/witnet/assets/_templates.js +36 -0
- package/witnet/assets/index.js +4 -0
- package/witnet/assets/modals/index.js +25 -0
- package/witnet/assets/modals/web3/btc.js +0 -0
- package/witnet/assets/modals/web3/eth.js +29 -0
- package/witnet/assets/modals/web3/sol.js +0 -0
- package/witnet/assets/modals/web3/wit.js +23 -0
- package/witnet/assets/requests.js +94 -0
- package/witnet/witnet.proto.json +1325 -0
|
@@ -0,0 +1,339 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.DataRequestPayload = void 0;
|
|
4
|
+
const Long = require("long");
|
|
5
|
+
const protobufjs_1 = require("protobufjs");
|
|
6
|
+
const protoRoot = protobufjs_1.Root.fromJSON(require("../../../../witnet/witnet.proto.json"));
|
|
7
|
+
const helpers_1 = require("../../../bin/helpers");
|
|
8
|
+
const radon_1 = require("../../radon");
|
|
9
|
+
const payloads_1 = require("../payloads");
|
|
10
|
+
const types_1 = require("../types");
|
|
11
|
+
const utils_1 = require("../utils");
|
|
12
|
+
const DR_COMMIT_TX_WEIGHT = 400;
|
|
13
|
+
const DR_REVEAL_TX_WEIGHT = 200;
|
|
14
|
+
const DR_TALLY_TX_WEIGHT = 100;
|
|
15
|
+
const DR_TX_WEIGHT_ALPHA = 1;
|
|
16
|
+
const DR_TX_WEIGHT_BETA = 1;
|
|
17
|
+
const TX_WEIGHT_INPUT_SIZE = 133;
|
|
18
|
+
const TX_WEIGHT_OUTPUT_SIZE = 36;
|
|
19
|
+
class DataRequestPayload extends payloads_1.TransactionPayloadMultiSig {
|
|
20
|
+
constructor(protoTypeName, radon, initialTarget) {
|
|
21
|
+
super(protoTypeName, initialTarget);
|
|
22
|
+
if (radon instanceof radon_1.RadonRequest) {
|
|
23
|
+
this._request = radon;
|
|
24
|
+
}
|
|
25
|
+
else if (radon instanceof radon_1.RadonTemplate) {
|
|
26
|
+
this.template = radon;
|
|
27
|
+
}
|
|
28
|
+
else {
|
|
29
|
+
throw new TypeError(`DataRequestPayload: unsupported Radon asset type: ${radon?.constructor.name}`);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
get droHash() {
|
|
33
|
+
const obj = this._toDrOutputProtobuf();
|
|
34
|
+
if (obj) {
|
|
35
|
+
const DataRequestOutput = protoRoot.lookupType("DataRequestOutput");
|
|
36
|
+
const err = DataRequestOutput.verify(obj);
|
|
37
|
+
if (err) {
|
|
38
|
+
throw TypeError(err);
|
|
39
|
+
}
|
|
40
|
+
else {
|
|
41
|
+
// console.log("\ndroHash.obj =>", JSON.stringify(obj))
|
|
42
|
+
const message = DataRequestOutput.fromObject(obj);
|
|
43
|
+
// console.log("\ndroHash.message =>", JSON.stringify(message))
|
|
44
|
+
const bytecode = DataRequestOutput.encode(message).finish();
|
|
45
|
+
// console.log("\ndroHash.bytecode =>", bytecode)
|
|
46
|
+
return (0, helpers_1.toHexString)((0, utils_1.sha256)(bytecode));
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
return undefined;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
get droSLA() {
|
|
54
|
+
if (this._target && this._fees) {
|
|
55
|
+
const minConsensusPercentage = 51;
|
|
56
|
+
const witnesses = (typeof this._target.witnesses === 'object'
|
|
57
|
+
? Object.keys(this._target.witnesses).length
|
|
58
|
+
: this._target.witnesses || 0);
|
|
59
|
+
const commitAndRevealFee = this._fees2UnitaryCommitRevealReward(this._fees, witnesses);
|
|
60
|
+
const witnessReward = this._fees2UnitaryReward(this._fees);
|
|
61
|
+
const collateral = witnessReward * BigInt(DataRequestPayload.COLLATERAL_RATIO);
|
|
62
|
+
if (collateral > Number.MAX_SAFE_INTEGER)
|
|
63
|
+
throw new TypeError(`${this.constructor.name}: too much witness collateral: ${collateral.toString()} > ${Number.MAX_SAFE_INTEGER}`);
|
|
64
|
+
else if (witnessReward > Number.MAX_SAFE_INTEGER)
|
|
65
|
+
throw new TypeError(`${this.constructor.name}: too much witness reward: ${witnessReward.toString()} > ${Number.MAX_SAFE_INTEGER}`);
|
|
66
|
+
else if (commitAndRevealFee > Number.MAX_SAFE_INTEGER)
|
|
67
|
+
throw new TypeError(`${this.constructor.name}: too much commit/reveal fee: ${commitAndRevealFee.toString()} > ${Number.MAX_SAFE_INTEGER}`);
|
|
68
|
+
return {
|
|
69
|
+
collateral: Number(collateral),
|
|
70
|
+
commitAndRevealFee: Number(commitAndRevealFee),
|
|
71
|
+
minConsensusPercentage,
|
|
72
|
+
witnesses,
|
|
73
|
+
witnessReward: Number(witnessReward),
|
|
74
|
+
};
|
|
75
|
+
}
|
|
76
|
+
else {
|
|
77
|
+
return undefined;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
get hash() {
|
|
81
|
+
const _bytecode = this.bytecode;
|
|
82
|
+
if (_bytecode && this.droHash) {
|
|
83
|
+
return (0, helpers_1.toHexString)((0, utils_1.sha256)(Buffer.concat([
|
|
84
|
+
(0, helpers_1.fromHexString)(this.droHash),
|
|
85
|
+
(0, utils_1.sha256)(_bytecode),
|
|
86
|
+
])));
|
|
87
|
+
}
|
|
88
|
+
else {
|
|
89
|
+
return undefined;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
get maxWeight() {
|
|
93
|
+
return DataRequestPayload.MAX_WEIGHT;
|
|
94
|
+
}
|
|
95
|
+
get parameterized() {
|
|
96
|
+
return !!this.template;
|
|
97
|
+
}
|
|
98
|
+
get prepared() {
|
|
99
|
+
return (this.covered
|
|
100
|
+
&& this._inputs.length > 0
|
|
101
|
+
&& !!this._request
|
|
102
|
+
&& !!this._target);
|
|
103
|
+
}
|
|
104
|
+
get radArgs() {
|
|
105
|
+
return this.template ? this._target?.args : undefined;
|
|
106
|
+
}
|
|
107
|
+
get radHash() {
|
|
108
|
+
return this.request?.radHash;
|
|
109
|
+
}
|
|
110
|
+
get request() {
|
|
111
|
+
return this._request;
|
|
112
|
+
}
|
|
113
|
+
get value() {
|
|
114
|
+
if (this._target && this._fees) {
|
|
115
|
+
return types_1.Coins.fromPedros(this._fees2Value(this._fees, this._target.witnesses || 0));
|
|
116
|
+
}
|
|
117
|
+
else {
|
|
118
|
+
return types_1.Coins.zero();
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
get weight() {
|
|
122
|
+
if (this._request && this._target) {
|
|
123
|
+
const witnesses = typeof this._target.witnesses === 'object' ? Object.keys(this._target.witnesses).length : this._target.witnesses || 0;
|
|
124
|
+
return (DR_TX_WEIGHT_ALPHA * (this._request.weight() + 8 + 2 + 8 + 4 + 8),
|
|
125
|
+
+this._inputs.length * TX_WEIGHT_INPUT_SIZE
|
|
126
|
+
+ this._outputs.length * TX_WEIGHT_OUTPUT_SIZE
|
|
127
|
+
+ witnesses * (DR_COMMIT_TX_WEIGHT
|
|
128
|
+
+ DR_REVEAL_TX_WEIGHT * DR_TX_WEIGHT_BETA
|
|
129
|
+
+ TX_WEIGHT_OUTPUT_SIZE // TODO V2.1: typeof this._target.witnesses === 'object' ? TX_WEIGHT_OUTPUT_SIZE : 0
|
|
130
|
+
)
|
|
131
|
+
+ Math.max(DR_TALLY_TX_WEIGHT, this._target?.maxResultSize || 0) * DR_TX_WEIGHT_BETA);
|
|
132
|
+
}
|
|
133
|
+
else {
|
|
134
|
+
return 0;
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
async consumeUtxos(ledger, reload) {
|
|
138
|
+
if (!this._target) {
|
|
139
|
+
throw new Error(`${this.constructor.name}: internal error: no in-flight params.`);
|
|
140
|
+
}
|
|
141
|
+
else if (this._target?.fees instanceof types_1.Coins) {
|
|
142
|
+
this._fees = this._target.fees.pedros;
|
|
143
|
+
return super.consumeUtxos(ledger, reload);
|
|
144
|
+
}
|
|
145
|
+
if (!this.covered) {
|
|
146
|
+
if (!this._target.witnesses) {
|
|
147
|
+
this._target.witnesses = Math.min(DataRequestPayload.DEFAULT_WITNESSES, await ledger.provider.witnesses());
|
|
148
|
+
if (this._target.witnesses < 3) {
|
|
149
|
+
delete this._target.witnesses;
|
|
150
|
+
throw new Error(`${this.constructor.name}: cannot estimate witnesses: network not ready for witnessing.`);
|
|
151
|
+
}
|
|
152
|
+
else if (this.weight > DataRequestPayload.MAX_WEIGHT * 0.8) {
|
|
153
|
+
const delta = this.weight - DataRequestPayload.MAX_WEIGHT * 0.8;
|
|
154
|
+
this._target.witnesses -= Math.ceil(delta / (DR_COMMIT_TX_WEIGHT + DR_REVEAL_TX_WEIGHT * TX_WEIGHT_OUTPUT_SIZE));
|
|
155
|
+
if (this._target.witnesses < 3) {
|
|
156
|
+
delete this._target.witnesses;
|
|
157
|
+
throw new Error(`${this.constructor.name}: cannot estimate witnesses: radon request too complex: ${this.weight} weight units`);
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
const priority = this._target?.fees || types_1.TransactionPriority.Opulent;
|
|
162
|
+
let estimatedFees = await this._estimateNetworkFees(ledger.provider, priority);
|
|
163
|
+
while (this._fees < estimatedFees) {
|
|
164
|
+
this._fees = estimatedFees;
|
|
165
|
+
this._outputs = [];
|
|
166
|
+
this._inputs = [];
|
|
167
|
+
this._covered = 0n;
|
|
168
|
+
// consume utxos as to cover for estimated value and estimated fees
|
|
169
|
+
const value = this._fees2Value(this._fees, this._target.witnesses);
|
|
170
|
+
const utxos = await ledger.selectUtxos({
|
|
171
|
+
value: types_1.Coins.fromPedros(value + this._fees - this._covered),
|
|
172
|
+
reload,
|
|
173
|
+
});
|
|
174
|
+
this._covered += utxos.map(utxo => BigInt(utxo.value)).reduce((prev, curr) => prev + curr, 0n);
|
|
175
|
+
this._inputs.push(...utxos);
|
|
176
|
+
ledger.consumeUtxos(...utxos);
|
|
177
|
+
this._change = this._covered - (value + this._fees);
|
|
178
|
+
if (this._change >= 0) {
|
|
179
|
+
this.prepareOutputs({ value: this._change });
|
|
180
|
+
estimatedFees = await this._estimateNetworkFees(ledger.provider, priority);
|
|
181
|
+
}
|
|
182
|
+
else {
|
|
183
|
+
// insufficient funds ...
|
|
184
|
+
break;
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
return this._change;
|
|
189
|
+
}
|
|
190
|
+
intoReceipt(target) {
|
|
191
|
+
return {
|
|
192
|
+
droHash: this.droHash,
|
|
193
|
+
radArgs: this.radArgs,
|
|
194
|
+
radHash: this.radHash,
|
|
195
|
+
witnesses: target.witnesses,
|
|
196
|
+
};
|
|
197
|
+
}
|
|
198
|
+
prepareOutputs(change) {
|
|
199
|
+
if (change?.value) {
|
|
200
|
+
this._outputs.push({
|
|
201
|
+
pkh: this._inputs[0].signer,
|
|
202
|
+
value: change.value,
|
|
203
|
+
time_lock: 0,
|
|
204
|
+
});
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
resetTarget(target) {
|
|
208
|
+
this._change = 0n;
|
|
209
|
+
this._covered = 0n;
|
|
210
|
+
this._fees = 0n;
|
|
211
|
+
this._inputs = [];
|
|
212
|
+
this._outputs = [];
|
|
213
|
+
this._target = target;
|
|
214
|
+
if (this.droSLA?.collateral && this.droSLA.collateral < DataRequestPayload.MIN_COLLATERAL) {
|
|
215
|
+
throw new TypeError(`${this.constructor.name}: witnessing collateral below minimum: ${this.droSLA.collateral} < ${DataRequestPayload.MIN_COLLATERAL}`);
|
|
216
|
+
}
|
|
217
|
+
if (this.template) {
|
|
218
|
+
const args = target?.args;
|
|
219
|
+
if (args === undefined) {
|
|
220
|
+
throw new TypeError(`${this.constructor.name}: no template args were passed.`);
|
|
221
|
+
}
|
|
222
|
+
else if (typeof args === 'string') {
|
|
223
|
+
this._request = this.template.buildRadonRequest([args]);
|
|
224
|
+
}
|
|
225
|
+
else {
|
|
226
|
+
this._request = this.template.buildRadonRequest(args);
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
delete this._priorities;
|
|
230
|
+
}
|
|
231
|
+
toJSON(humanize = false) {
|
|
232
|
+
const droSLA = this.droSLA;
|
|
233
|
+
return {
|
|
234
|
+
inputs: this.inputs
|
|
235
|
+
.map(utxo => ({ output_pointer: utxo.output_pointer })),
|
|
236
|
+
outputs: this.outputs.map(vto => ({
|
|
237
|
+
pkh: vto.pkh,
|
|
238
|
+
time_lock: vto.time_lock,
|
|
239
|
+
value: vto.value.toString(),
|
|
240
|
+
})),
|
|
241
|
+
dr_output: {
|
|
242
|
+
...(this._request ? { data_request: this._request.toJSON(humanize) } : {}),
|
|
243
|
+
commit_and_reveal_fee: droSLA?.commitAndRevealFee,
|
|
244
|
+
min_consensus_percentage: droSLA?.minConsensusPercentage,
|
|
245
|
+
witnesses: droSLA?.witnesses,
|
|
246
|
+
witness_reward: droSLA?.witnessReward,
|
|
247
|
+
collateral: droSLA?.collateral
|
|
248
|
+
}
|
|
249
|
+
};
|
|
250
|
+
}
|
|
251
|
+
toProtobuf() {
|
|
252
|
+
if (this.prepared && this._target && this._request) {
|
|
253
|
+
return {
|
|
254
|
+
inputs: this.inputs
|
|
255
|
+
.map(utxo => {
|
|
256
|
+
const transactionId = utxo.output_pointer.split(':')[0];
|
|
257
|
+
const outputIndex = parseInt(utxo.output_pointer.split(':')[1]);
|
|
258
|
+
return {
|
|
259
|
+
outputPointer: {
|
|
260
|
+
transactionId: { SHA256: Array.from((0, helpers_1.fromHexString)(transactionId)) },
|
|
261
|
+
...(outputIndex > 0 ? { outputIndex } : {}),
|
|
262
|
+
},
|
|
263
|
+
};
|
|
264
|
+
}),
|
|
265
|
+
outputs: this.outputs.map(vto => ({
|
|
266
|
+
pkh: { hash: Array.from(types_1.PublicKeyHash.fromBech32(vto.pkh).toBytes20()), },
|
|
267
|
+
value: Long.fromValue(vto.value),
|
|
268
|
+
...(vto.time_lock > 0 ? { timeLock: vto.time_lock } : {}),
|
|
269
|
+
})),
|
|
270
|
+
drOutput: this._toDrOutputProtobuf(),
|
|
271
|
+
};
|
|
272
|
+
}
|
|
273
|
+
}
|
|
274
|
+
validateTarget(target) {
|
|
275
|
+
target = this._cleanTargetExtras(target);
|
|
276
|
+
if (target && Object.keys(target).length > 0) {
|
|
277
|
+
if (!(target
|
|
278
|
+
&& (!target?.fees
|
|
279
|
+
|| (target.fees instanceof types_1.Coins && target.fees.pedros > 0
|
|
280
|
+
|| Object.values(types_1.TransactionPriority).includes(target.fees)))
|
|
281
|
+
&& (target?.witnesses || target?.witnesses === undefined)
|
|
282
|
+
&& (!this.template || target?.args))) {
|
|
283
|
+
throw new TypeError(`${this.constructor.name}: invalid options: ${JSON.stringify(target)}`);
|
|
284
|
+
}
|
|
285
|
+
else if (target?.witnesses) {
|
|
286
|
+
if (typeof target.witnesses === 'object') {
|
|
287
|
+
throw new TypeError(`${this.constructor.name}: explicit witnessing committees not yet supported: ${target.witnesses}`);
|
|
288
|
+
}
|
|
289
|
+
target.witnesses = parseInt(target.witnesses);
|
|
290
|
+
}
|
|
291
|
+
return target;
|
|
292
|
+
}
|
|
293
|
+
else {
|
|
294
|
+
return undefined;
|
|
295
|
+
}
|
|
296
|
+
}
|
|
297
|
+
_cleanTargetExtras(target) {
|
|
298
|
+
if (target) {
|
|
299
|
+
return Object.fromEntries(Object.entries(target).filter(([key,]) => [
|
|
300
|
+
'args',
|
|
301
|
+
'fees',
|
|
302
|
+
'maxResultSize',
|
|
303
|
+
'witnesses',
|
|
304
|
+
].includes(key)));
|
|
305
|
+
}
|
|
306
|
+
}
|
|
307
|
+
async _estimateNetworkFees(provider, priority = types_1.TransactionPriority.Medium) {
|
|
308
|
+
if (!this._priorities) {
|
|
309
|
+
this._priorities = await provider.priorities();
|
|
310
|
+
}
|
|
311
|
+
return BigInt(Math.floor(this._priorities[`drt_${priority}`].priority * (this.covered ? this.weight : (this.weight
|
|
312
|
+
// estimate weight of one single output in case there was change to pay back
|
|
313
|
+
+ TX_WEIGHT_OUTPUT_SIZE))));
|
|
314
|
+
}
|
|
315
|
+
_fees2UnitaryCommitRevealReward(fees, witnesses) {
|
|
316
|
+
return fees / BigInt(witnesses) || 1n;
|
|
317
|
+
}
|
|
318
|
+
_fees2UnitaryReward(fees) {
|
|
319
|
+
return utils_1.BigMath.max(fees, 1n + DataRequestPayload.MIN_COLLATERAL / BigInt(DataRequestPayload.COLLATERAL_RATIO));
|
|
320
|
+
}
|
|
321
|
+
_fees2Value(fees, witnesses) {
|
|
322
|
+
return (BigInt(witnesses) * (this._fees2UnitaryReward(fees)
|
|
323
|
+
+ 2n * this._fees2UnitaryCommitRevealReward(fees, witnesses)));
|
|
324
|
+
}
|
|
325
|
+
_toDrOutputProtobuf() {
|
|
326
|
+
if (this._request) {
|
|
327
|
+
return {
|
|
328
|
+
...this.droSLA,
|
|
329
|
+
dataRequest: this._request.toProtobuf()
|
|
330
|
+
};
|
|
331
|
+
}
|
|
332
|
+
}
|
|
333
|
+
}
|
|
334
|
+
exports.DataRequestPayload = DataRequestPayload;
|
|
335
|
+
DataRequestPayload.COLLATERAL_RATIO = 125;
|
|
336
|
+
DataRequestPayload.DEFAULT_WITNESSES = 12;
|
|
337
|
+
DataRequestPayload.MAX_WEIGHT = 80000;
|
|
338
|
+
DataRequestPayload.MIN_COLLATERAL = 20000000000n;
|
|
339
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"DataRequestPayload.js","sourceRoot":"","sources":["../../../../../src/lib/crypto/payloads/DataRequestPayload.ts"],"names":[],"mappings":"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","sourcesContent":["const Long = require(\"long\")\r\n\r\nimport { Root as ProtoRoot } from \"protobufjs\"\r\nconst protoRoot = ProtoRoot.fromJSON(require(\"../../../../witnet/witnet.proto.json\"))\r\n\r\nimport { fromHexString, toHexString } from \"../../../bin/helpers\"\r\n\r\nimport { RadonRequest, RadonTemplate } from \"../../radon\"\r\nimport { Hash, HexString, IJsonRpcProvider } from \"../../types\"\r\n\r\nimport { ILedger } from \"../interfaces\"\r\nimport { TransactionPayloadMultiSig } from \"../payloads\"\r\nimport { Coins, PublicKeyHash, TransactionParams, TransactionPriority } from \"../types\"\r\nimport { BigMath, sha256 } from \"../utils\"\r\n\r\nexport type DataRequestTemplateArgs = any | string | string[] | string[][]\r\n    \r\nexport type DataRequestParams = TransactionParams & {\r\n    args?: DataRequestTemplateArgs,\r\n    maxResultSize?: number,\r\n    witnesses?: number,\r\n}\r\n\r\ntype DataRequestOutputSLA = {\r\n    collateral: number,\r\n    commitAndRevealFee: number,\r\n    minConsensusPercentage: number,\r\n    witnesses: number,\r\n    witnessReward?: number,\r\n}\r\n\r\nconst DR_COMMIT_TX_WEIGHT = 400\r\nconst DR_REVEAL_TX_WEIGHT = 200\r\nconst DR_TALLY_TX_WEIGHT = 100\r\n\r\nconst DR_TX_WEIGHT_ALPHA = 1\r\nconst DR_TX_WEIGHT_BETA = 1\r\n\r\nconst TX_WEIGHT_INPUT_SIZE = 133\r\nconst TX_WEIGHT_OUTPUT_SIZE = 36\r\n\r\nexport class DataRequestPayload extends TransactionPayloadMultiSig<DataRequestParams> {\r\n\r\n    public static COLLATERAL_RATIO = 125\r\n    public static DEFAULT_WITNESSES = 12\r\n    public static MAX_WEIGHT = 80_000\r\n    public static MIN_COLLATERAL = 20_000_000_000n\r\n\r\n    protected _request?: RadonRequest \r\n    public readonly template?: RadonTemplate\r\n    \r\n    constructor (protoTypeName: string, radon: RadonRequest | RadonTemplate, initialTarget?: DataRequestParams) {\r\n        super(protoTypeName, initialTarget)\r\n        if (radon instanceof RadonRequest) {\r\n            this._request = radon\r\n        } else if (radon instanceof RadonTemplate) {\r\n            this.template = radon\r\n        } else {\r\n            throw new TypeError(`DataRequestPayload: unsupported Radon asset type: ${(radon as any)?.constructor.name}`)\r\n        }\r\n    }\r\n\r\n    public get droHash(): Hash | undefined {\r\n        const obj = this._toDrOutputProtobuf()\r\n        if (obj) {\r\n            const DataRequestOutput = protoRoot.lookupType(\"DataRequestOutput\")\r\n            const err = DataRequestOutput.verify(obj)\r\n            if (err) {\r\n                throw TypeError(err)\r\n            } else {\r\n                // console.log(\"\\ndroHash.obj =>\", JSON.stringify(obj))\r\n                const message = DataRequestOutput.fromObject(obj)\r\n                // console.log(\"\\ndroHash.message =>\", JSON.stringify(message))\r\n                const bytecode = DataRequestOutput.encode(message).finish()\r\n                // console.log(\"\\ndroHash.bytecode =>\", bytecode)\r\n                return toHexString(sha256(bytecode))\r\n            }\r\n        } else {\r\n            return undefined\r\n        }\r\n    }\r\n\r\n    public get droSLA(): DataRequestOutputSLA | undefined {\r\n        if (this._target && this._fees) {\r\n            const minConsensusPercentage = 51\r\n            const witnesses = (\r\n                typeof this._target.witnesses === 'object'\r\n                    ? Object.keys(this._target.witnesses).length \r\n                    : this._target.witnesses || 0\r\n            );\r\n            const commitAndRevealFee = this._fees2UnitaryCommitRevealReward(this._fees, witnesses)\r\n            const witnessReward = this._fees2UnitaryReward(this._fees) \r\n            const collateral = witnessReward * BigInt(DataRequestPayload.COLLATERAL_RATIO)\r\n            if (collateral > Number.MAX_SAFE_INTEGER) \r\n                throw new TypeError(`${this.constructor.name}: too much witness collateral: ${collateral.toString()} > ${Number.MAX_SAFE_INTEGER}`);\r\n            else if (witnessReward > Number.MAX_SAFE_INTEGER)\r\n                throw new TypeError(`${this.constructor.name}: too much witness reward: ${witnessReward.toString()} > ${Number.MAX_SAFE_INTEGER}`);\r\n            else if (commitAndRevealFee > Number.MAX_SAFE_INTEGER)\r\n                throw new TypeError(`${this.constructor.name}: too much commit/reveal fee: ${commitAndRevealFee.toString()} > ${Number.MAX_SAFE_INTEGER}`);\r\n            return {\r\n                collateral: Number(collateral),\r\n                commitAndRevealFee: Number(commitAndRevealFee),\r\n                minConsensusPercentage,\r\n                witnesses,\r\n                witnessReward: Number(witnessReward),\r\n            }\r\n            \r\n        } else {\r\n            return undefined\r\n        }\r\n    }\r\n\r\n    public get hash(): Hash | undefined {\r\n        const _bytecode = this.bytecode\r\n        if (_bytecode && this.droHash) {\r\n            return toHexString(sha256(Buffer.concat([\r\n                fromHexString(this.droHash),\r\n                sha256(_bytecode),\r\n            ]))) as Hash\r\n        } else {\r\n            return undefined\r\n        }\r\n    }\r\n\r\n    public get maxWeight(): number {\r\n        return DataRequestPayload.MAX_WEIGHT\r\n    }\r\n\r\n    public get parameterized(): boolean {\r\n        return !!this.template\r\n    }\r\n\r\n    public get prepared(): boolean {\r\n        return (\r\n            this.covered\r\n                && this._inputs.length > 0\r\n                && !!this._request\r\n                && !!this._target\r\n        )\r\n    }\r\n\r\n    public get radArgs(): DataRequestTemplateArgs | undefined {\r\n        return this.template ? this._target?.args : undefined\r\n    }\r\n\r\n    public get radHash(): HexString | undefined {\r\n        return this.request?.radHash\r\n    }\r\n\r\n    public get request(): RadonRequest | undefined {\r\n        return this._request\r\n    }\r\n\r\n    public get value(): Coins {\r\n        if (this._target && this._fees) {\r\n            return Coins.fromPedros(this._fees2Value(this._fees, this._target.witnesses || 0))\r\n        } else {\r\n            return Coins.zero()\r\n        }\r\n    }\r\n\r\n    public get weight(): number {\r\n        if (this._request && this._target) {\r\n            const witnesses = typeof this._target.witnesses === 'object' ? Object.keys(this._target.witnesses).length : this._target.witnesses || 0\r\n            return (\r\n                DR_TX_WEIGHT_ALPHA * (this._request.weight() + 8 + 2 + 8 + 4 + 8),\r\n                    + this._inputs.length * TX_WEIGHT_INPUT_SIZE \r\n                    + this._outputs.length * TX_WEIGHT_OUTPUT_SIZE \r\n                    + witnesses * (\r\n                            DR_COMMIT_TX_WEIGHT\r\n                                + DR_REVEAL_TX_WEIGHT * DR_TX_WEIGHT_BETA  \r\n                                + TX_WEIGHT_OUTPUT_SIZE // TODO V2.1: typeof this._target.witnesses === 'object' ? TX_WEIGHT_OUTPUT_SIZE : 0\r\n                    )\r\n                    + Math.max(DR_TALLY_TX_WEIGHT, this._target?.maxResultSize || 0) * DR_TX_WEIGHT_BETA\r\n            );\r\n        } else {\r\n            return 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        } else if ((this._target as any)?.fees instanceof Coins) {\r\n            this._fees = (this._target as any).fees.pedros;\r\n            return super.consumeUtxos(ledger, reload)\r\n        }\r\n\r\n        if (!this.covered) {\r\n            if (!this._target.witnesses) {\r\n                this._target.witnesses = Math.min(\r\n                    DataRequestPayload.DEFAULT_WITNESSES, \r\n                    await ledger.provider.witnesses()\r\n                )\r\n                if (this._target.witnesses < 3) {\r\n                    delete this._target.witnesses\r\n                    throw new Error(`${this.constructor.name}: cannot estimate witnesses: network not ready for witnessing.`)    \r\n                \r\n                } else if (this.weight > DataRequestPayload.MAX_WEIGHT * 0.8) {\r\n                    const delta = this.weight - DataRequestPayload.MAX_WEIGHT * 0.8\r\n                    this._target.witnesses -= Math.ceil(delta / (DR_COMMIT_TX_WEIGHT + DR_REVEAL_TX_WEIGHT * TX_WEIGHT_OUTPUT_SIZE))\r\n                    if (this._target.witnesses < 3) {\r\n                        delete this._target.witnesses\r\n                        throw new Error(`${this.constructor.name}: cannot estimate witnesses: radon request too complex: ${this.weight} weight units`)\r\n                    }\r\n                }\r\n            }\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                this._inputs = []\r\n                this._covered = 0n\r\n                // consume utxos as to cover for estimated value and estimated fees \r\n                const value = this._fees2Value(this._fees, this._target.witnesses)\r\n                const utxos = await ledger.selectUtxos({ \r\n                    value: Coins.fromPedros(value + this._fees - this._covered), \r\n                    reload,\r\n                })\r\n                this._covered += utxos.map(utxo => BigInt(utxo.value)).reduce((prev, curr) => prev + curr, 0n)\r\n                this._inputs.push(...utxos)\r\n                ledger.consumeUtxos(...utxos)\r\n                this._change = this._covered - (value + this._fees)\r\n                if (this._change >= 0) {\r\n                    this.prepareOutputs({ value: this._change })\r\n                    estimatedFees = await this._estimateNetworkFees(ledger.provider, priority)\r\n                } else {\r\n                    // insufficient funds ...\r\n                    break\r\n                }\r\n            }\r\n        }\r\n        return this._change\r\n    }\r\n\r\n    public intoReceipt(target: DataRequestParams): any {\r\n        return {\r\n            droHash: this.droHash,\r\n            radArgs: this.radArgs,\r\n            radHash: this.radHash,\r\n            witnesses: target.witnesses,\r\n        }\r\n    }\r\n\r\n    public prepareOutputs(change?: { value: bigint }): any {\r\n        if (change?.value) {\r\n            this._outputs.push({\r\n                pkh: this._inputs[0].signer,\r\n                value: change.value,\r\n                time_lock: 0,\r\n            })\r\n        }\r\n    }\r\n\r\n    public resetTarget(target: DataRequestParams): 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        if (this.droSLA?.collateral && this.droSLA.collateral < DataRequestPayload.MIN_COLLATERAL) {\r\n            throw new TypeError(\r\n                `${this.constructor.name}: witnessing collateral below minimum: ${\r\n                    this.droSLA.collateral\r\n                } < ${\r\n                    DataRequestPayload.MIN_COLLATERAL\r\n                }`\r\n            );\r\n        }\r\n        if (this.template) {\r\n            const args = target?.args\r\n            if (args === undefined) {\r\n                throw new TypeError(`${this.constructor.name}: no template args were passed.`)\r\n            } else if (typeof args === 'string') {\r\n                this._request = this.template.buildRadonRequest([args])\r\n            } else {\r\n                this._request = this.template.buildRadonRequest(args)\r\n            }\r\n        }\r\n        delete this._priorities\r\n    }\r\n\r\n    public toJSON(humanize = false): any {\r\n        const droSLA = this.droSLA        \r\n        return {\r\n            inputs: this.inputs\r\n                .map(utxo => ({ output_pointer: utxo.output_pointer })),\r\n            outputs: this.outputs.map(vto => ({ \r\n                pkh: vto.pkh,\r\n                time_lock: vto.time_lock,\r\n                value: vto.value.toString(),\r\n            })),\r\n            dr_output: {\r\n                ...(this._request ? { data_request: this._request.toJSON(humanize) } : {}),\r\n                commit_and_reveal_fee: droSLA?.commitAndRevealFee,\r\n                min_consensus_percentage: droSLA?.minConsensusPercentage,\r\n                witnesses: droSLA?.witnesses,\r\n                witness_reward: droSLA?.witnessReward,\r\n                collateral: droSLA?.collateral\r\n            }\r\n        }\r\n    }   \r\n\r\n    public toProtobuf(): any {\r\n        if (this.prepared && this._target && this._request) {\r\n            return {    \r\n                inputs: this.inputs\r\n                    .map(utxo => { \r\n                        const transactionId = utxo.output_pointer.split(':')[0]\r\n                        const outputIndex = parseInt(utxo.output_pointer.split(':')[1])\r\n                        return {\r\n                            outputPointer: {\r\n                                transactionId: { SHA256: Array.from(fromHexString(transactionId)) },\r\n                                ...(outputIndex > 0 ? { outputIndex } : {}),\r\n                            },\r\n                        }\r\n                    }),\r\n                outputs: this.outputs.map(vto => ({ \r\n                    pkh: { hash: Array.from(PublicKeyHash.fromBech32(vto.pkh).toBytes20()), },\r\n                    value: Long.fromValue(vto.value),\r\n                    ...(vto.time_lock > 0 ? { timeLock: vto.time_lock } : {}),\r\n                })),\r\n                drOutput: this._toDrOutputProtobuf(),\r\n            }\r\n        }\r\n    }\r\n\r\n    public validateTarget(target?: any): DataRequestParams | undefined {\r\n        target = this._cleanTargetExtras(target)\r\n        if (target && Object.keys(target).length > 0) {\r\n            if (!(\r\n                target\r\n                    && (\r\n                        !target?.fees \r\n                        || (\r\n                            target.fees instanceof Coins && (target.fees as Coins).pedros > 0 \r\n                            || Object.values(TransactionPriority).includes(target.fees)\r\n                        )\r\n                    )\r\n                    && (target?.witnesses || target?.witnesses === undefined)\r\n                    && (!this.template || target?.args)\r\n            )) {\r\n                throw new TypeError(`${this.constructor.name}: invalid options: ${JSON.stringify(target)}`)\r\n            } else if (target?.witnesses) {\r\n                if (typeof target.witnesses === 'object') {\r\n                    throw new TypeError(`${this.constructor.name}: explicit witnessing committees not yet supported: ${target.witnesses}`)\r\n                } \r\n                target.witnesses = parseInt(target.witnesses as string)\r\n            }\r\n            return target as DataRequestParams\r\n        } else {\r\n            return undefined\r\n        }\r\n    }\r\n\r\n    protected _cleanTargetExtras(target?: any): any {\r\n        if (target) {\r\n            return Object.fromEntries(\r\n                Object.entries(target).filter(([key,]) => [\r\n                    'args',\r\n                    'fees',\r\n                    'maxResultSize',\r\n                    'witnesses',\r\n                ].includes(key))\r\n            )\r\n        }\r\n    }\r\n\r\n    protected async _estimateNetworkFees(provider: IJsonRpcProvider, priority = TransactionPriority.Medium): Promise<bigint> {\r\n        if (!this._priorities) {\r\n            this._priorities = await provider.priorities()\r\n        }\r\n        return BigInt(Math.floor(\r\n            this._priorities[`drt_${priority}`].priority * (\r\n                this.covered ? this.weight : (\r\n                    this.weight\r\n                    // estimate weight of one single output in case there was change to pay back\r\n                    + TX_WEIGHT_OUTPUT_SIZE \r\n                )\r\n            )\r\n        ));\r\n    }\r\n\r\n    protected _fees2UnitaryCommitRevealReward(fees: bigint, witnesses: number): bigint {\r\n        return fees / BigInt(witnesses) || 1n\r\n    }\r\n\r\n    protected _fees2UnitaryReward(fees: bigint): bigint {\r\n        return BigMath.max(\r\n            fees,\r\n            1n + DataRequestPayload.MIN_COLLATERAL / BigInt(DataRequestPayload.COLLATERAL_RATIO)\r\n        );\r\n    }\r\n    protected _fees2Value(fees: bigint, witnesses: number): bigint {\r\n        return (\r\n            BigInt(witnesses) * (\r\n                this._fees2UnitaryReward(fees)\r\n                + 2n * this._fees2UnitaryCommitRevealReward(fees, witnesses)\r\n            )\r\n        );\r\n    }\r\n\r\n    protected _toDrOutputProtobuf(): any {\r\n        if (this._request) {\r\n            return {\r\n                ...this.droSLA,\r\n                dataRequest: this._request.toProtobuf()\r\n            }\r\n        }\r\n    }\r\n}\r\n\r\n"]}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { HexString, IJsonRpcProvider, Network } from "../../types";
|
|
2
|
+
import { TransactionPayloadMultiSig } from "../payloads";
|
|
3
|
+
import { Coins, PublicKeyHashString, TransactionParams, TransactionPriority } from "../types";
|
|
4
|
+
export type StakeDepositParams = TransactionParams & {
|
|
5
|
+
authorization: HexString;
|
|
6
|
+
value: Coins;
|
|
7
|
+
withdrawer: PublicKeyHashString;
|
|
8
|
+
};
|
|
9
|
+
export declare class StakePayload extends TransactionPayloadMultiSig<StakeDepositParams> {
|
|
10
|
+
static MAX_WEIGHT: number;
|
|
11
|
+
static MIN_VALUE: number;
|
|
12
|
+
constructor(protoTypeName: string, specs?: any);
|
|
13
|
+
get maxWeight(): number;
|
|
14
|
+
get prepared(): boolean;
|
|
15
|
+
get value(): Coins;
|
|
16
|
+
get weight(): number;
|
|
17
|
+
intoReceipt(target: StakeDepositParams, network?: Network): {
|
|
18
|
+
authorization: string;
|
|
19
|
+
withdrawer: string;
|
|
20
|
+
validator: string;
|
|
21
|
+
};
|
|
22
|
+
toJSON(_humanize?: boolean, network?: Network): any;
|
|
23
|
+
toProtobuf(): any;
|
|
24
|
+
validateTarget(target?: any): StakeDepositParams | undefined;
|
|
25
|
+
protected _cleanTargetExtras(target?: any): any;
|
|
26
|
+
protected _estimateNetworkFees(provider: IJsonRpcProvider, priority?: TransactionPriority): Promise<bigint>;
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=StakePayload.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StakePayload.d.ts","sourceRoot":"","sources":["../../../../../src/lib/crypto/payloads/StakePayload.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,OAAO,EAAE,MAAM,aAAa,CAAA;AAElE,OAAO,EAAE,0BAA0B,EAAE,MAAM,aAAa,CAAA;AACxD,OAAO,EACH,KAAK,EAGL,mBAAmB,EAEnB,iBAAiB,EACjB,mBAAmB,EACtB,MAAM,UAAU,CAAA;AAEjB,MAAM,MAAM,kBAAkB,GAAG,iBAAiB,GAAG;IACjD,aAAa,EAAE,SAAS,CAAC;IACzB,KAAK,EAAE,KAAK,CAAC;IACb,UAAU,EAAE,mBAAmB,CAAC;CACnC,CAAA;AAMD,qBAAa,YAAa,SAAQ,0BAA0B,CAAC,kBAAkB,CAAC;IAE5E,OAAc,UAAU,SAAS;IACjC,OAAc,SAAS,SAAmB;gBAE7B,aAAa,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,GAAG;IAI/C,IAAW,SAAS,IAAI,MAAM,CAE7B;IAED,IAAW,QAAQ,IAAI,OAAO,CAM7B;IAED,IAAW,KAAK,IAAI,KAAK,CAExB;IAED,IAAW,MAAM,IAAI,MAAM,CAM1B;IAEM,WAAW,CAAC,MAAM,EAAE,kBAAkB,EAAE,OAAO,CAAC,EAAE,OAAO;;;;;IAQzD,MAAM,CAAC,SAAS,UAAQ,EAAE,OAAO,CAAC,EAAE,OAAO,GAAG,GAAG;IA6BjD,UAAU,IAAI,GAAG;IAoCjB,cAAc,CAAC,MAAM,CAAC,EAAE,GAAG,GAAG,kBAAkB,GAAG,SAAS;IA2CnE,SAAS,CAAC,kBAAkB,CAAC,MAAM,CAAC,EAAE,GAAG,GAAG,GAAG;cAa/B,oBAAoB,CAAC,QAAQ,EAAE,gBAAgB,EAAE,QAAQ,sBAA6B,GAAG,OAAO,CAAC,MAAM,CAAC;CAgB3H"}
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.StakePayload = void 0;
|
|
4
|
+
const Long = require("long");
|
|
5
|
+
const helpers_1 = require("../../../bin/helpers");
|
|
6
|
+
const payloads_1 = require("../payloads");
|
|
7
|
+
const types_1 = require("../types");
|
|
8
|
+
const TX_WEIGHT_BASE = 105;
|
|
9
|
+
const TX_WEIGHT_INPUT_SIZE = 133;
|
|
10
|
+
const TX_WEIGHT_OUTPUT_SIZE = 36;
|
|
11
|
+
class StakePayload extends payloads_1.TransactionPayloadMultiSig {
|
|
12
|
+
constructor(protoTypeName, specs) {
|
|
13
|
+
super(protoTypeName, specs);
|
|
14
|
+
}
|
|
15
|
+
get maxWeight() {
|
|
16
|
+
return StakePayload.MAX_WEIGHT;
|
|
17
|
+
}
|
|
18
|
+
get prepared() {
|
|
19
|
+
return (!!this._target
|
|
20
|
+
&& this._covered >= this._target.value.pedros
|
|
21
|
+
&& this._inputs.length > 0);
|
|
22
|
+
}
|
|
23
|
+
get value() {
|
|
24
|
+
return this._target?.value || types_1.Coins.zero();
|
|
25
|
+
}
|
|
26
|
+
get weight() {
|
|
27
|
+
return (TX_WEIGHT_BASE
|
|
28
|
+
+ this._inputs.length * TX_WEIGHT_INPUT_SIZE
|
|
29
|
+
+ this._outputs.length * TX_WEIGHT_OUTPUT_SIZE);
|
|
30
|
+
}
|
|
31
|
+
intoReceipt(target, network) {
|
|
32
|
+
return {
|
|
33
|
+
authorization: target.authorization,
|
|
34
|
+
withdrawer: target.withdrawer,
|
|
35
|
+
validator: types_1.PublicKeyHash.fromHexString(target.authorization.substring(0, 40)).toBech32(network),
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
toJSON(_humanize = false, network) {
|
|
39
|
+
return {
|
|
40
|
+
inputs: this.inputs
|
|
41
|
+
.map(utxo => {
|
|
42
|
+
return { output_pointer: utxo.output_pointer };
|
|
43
|
+
}),
|
|
44
|
+
...(this._target ? { output: {
|
|
45
|
+
authorization: types_1.RecoverableSignature.from(this._target.authorization.substring(40), types_1.PublicKeyHash.fromBech32(this._target.withdrawer).toBytes32()).toKeyedSignature(),
|
|
46
|
+
key: {
|
|
47
|
+
validator: types_1.PublicKeyHash.fromHexString(this._target.authorization.substring(0, 40)).toBech32(network),
|
|
48
|
+
withdrawer: this._target.withdrawer,
|
|
49
|
+
},
|
|
50
|
+
value: this._target.value.pedros.toString(),
|
|
51
|
+
} } : {}),
|
|
52
|
+
...(this.outputs.length > 0 ? { change: {
|
|
53
|
+
pkh: this.outputs[0].pkh,
|
|
54
|
+
value: this.outputs[0].value.toString(),
|
|
55
|
+
time_lock: 0,
|
|
56
|
+
} } : {}),
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
toProtobuf() {
|
|
60
|
+
if (this.prepared && this._target) {
|
|
61
|
+
return {
|
|
62
|
+
inputs: this.inputs
|
|
63
|
+
.map(utxo => {
|
|
64
|
+
const transactionId = utxo.output_pointer.split(':')[0];
|
|
65
|
+
const outputIndex = parseInt(utxo.output_pointer.split(':')[1]);
|
|
66
|
+
return {
|
|
67
|
+
outputPointer: {
|
|
68
|
+
transactionId: { SHA256: Array.from((0, helpers_1.fromHexString)(transactionId)) },
|
|
69
|
+
...(outputIndex > 0 ? { outputIndex } : {}),
|
|
70
|
+
},
|
|
71
|
+
};
|
|
72
|
+
}),
|
|
73
|
+
output: {
|
|
74
|
+
authorization: types_1.RecoverableSignature.from(this._target.authorization.substring(40), types_1.PublicKeyHash.fromBech32(this._target.withdrawer).toBytes32()).toProtobuf(),
|
|
75
|
+
key: {
|
|
76
|
+
validator: { hash: Array.from(types_1.PublicKeyHash.fromHexString(this._target.authorization.substring(0, 40)).toBytes20()) },
|
|
77
|
+
withdrawer: { hash: Array.from(types_1.PublicKeyHash.fromBech32(this._target.withdrawer).toBytes20()) },
|
|
78
|
+
},
|
|
79
|
+
value: Long.fromValue(this._target.value.pedros),
|
|
80
|
+
},
|
|
81
|
+
...(this._outputs.length > 0 ? { change: {
|
|
82
|
+
pkh: { hash: Array.from(types_1.PublicKeyHash.fromBech32(this.outputs[0].pkh).toBytes20()) },
|
|
83
|
+
value: Long.fromValue(this.outputs[0].value.toString()),
|
|
84
|
+
// timeLock: 0,
|
|
85
|
+
} } : { change: { pkh: { hash: Array(20).fill(0) } } }),
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
validateTarget(target) {
|
|
90
|
+
target = this._cleanTargetExtras(target);
|
|
91
|
+
if (target && Object.keys(target).length > 0) {
|
|
92
|
+
if (!(target
|
|
93
|
+
&& target?.authorization
|
|
94
|
+
&& (!target?.fees
|
|
95
|
+
|| (target.fees instanceof types_1.Coins && target.fees.pedros > 0
|
|
96
|
+
|| Object.values(types_1.TransactionPriority).includes(target.fees)))
|
|
97
|
+
&& target?.value && target.value.pedros > 0
|
|
98
|
+
&& target?.withdrawer)) {
|
|
99
|
+
throw new TypeError(`${this.constructor.name}: invalid options: ${JSON.stringify(target)}`);
|
|
100
|
+
}
|
|
101
|
+
else {
|
|
102
|
+
if (target.value.pedros < StakePayload.MIN_VALUE) {
|
|
103
|
+
throw new TypeError(`${this.constructor.name}: value below minimum stake: ${target.value.wits} < ${types_1.Coins.fromNanowits(BigInt(StakePayload.MIN_VALUE)).wits} $WIT`);
|
|
104
|
+
}
|
|
105
|
+
const pubKey = types_1.PublicKey.recoverFrom(target.authorization.substring(40), types_1.PublicKeyHash.fromBech32(target.withdrawer).toBytes32());
|
|
106
|
+
if (pubKey.hash().toHexString() !== target.authorization.substring(0, 40)) {
|
|
107
|
+
throw new TypeError(`${this.constructor.name}: authorization code not valid for withdrawer ${target.withdrawer}.`);
|
|
108
|
+
}
|
|
109
|
+
return target;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
else {
|
|
113
|
+
return undefined;
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
_cleanTargetExtras(target) {
|
|
117
|
+
if (target) {
|
|
118
|
+
return Object.fromEntries(Object.entries(target).filter(([key,]) => [
|
|
119
|
+
'authorization',
|
|
120
|
+
'fees',
|
|
121
|
+
'value',
|
|
122
|
+
'withdrawer',
|
|
123
|
+
].includes(key)));
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
async _estimateNetworkFees(provider, priority = types_1.TransactionPriority.Medium) {
|
|
127
|
+
if (!this._priorities) {
|
|
128
|
+
this._priorities = await provider.priorities();
|
|
129
|
+
}
|
|
130
|
+
return BigInt(Math.floor(
|
|
131
|
+
// todo: replace `vtt_` for `st_`
|
|
132
|
+
this._priorities[`vtt_${priority}`].priority * (this.covered ? this.weight : this.weight
|
|
133
|
+
// estimate one more input as to cover for network fees
|
|
134
|
+
+ TX_WEIGHT_INPUT_SIZE
|
|
135
|
+
// estimate weight of one single output in case there was change to pay back
|
|
136
|
+
+ TX_WEIGHT_OUTPUT_SIZE)));
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
exports.StakePayload = StakePayload;
|
|
140
|
+
StakePayload.MAX_WEIGHT = 10000; // 10,000
|
|
141
|
+
StakePayload.MIN_VALUE = 10000 * 10 ** 9; // 10,000.00 $WIT
|
|
142
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"StakePayload.js","sourceRoot":"","sources":["../../../../../src/lib/crypto/payloads/StakePayload.ts"],"names":[],"mappings":"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","sourcesContent":["const Long = require(\"long\")\r\n\r\nimport { fromHexString } from \"../../../bin/helpers\"\r\n\r\nimport { HexString, IJsonRpcProvider, Network } from \"../../types\"\r\n\r\nimport { TransactionPayloadMultiSig } from \"../payloads\"\r\nimport { \r\n    Coins,\r\n    PublicKey, \r\n    PublicKeyHash, \r\n    PublicKeyHashString, \r\n    RecoverableSignature, \r\n    TransactionParams, \r\n    TransactionPriority,\r\n} from \"../types\"\r\n\r\nexport type StakeDepositParams = TransactionParams & {\r\n    authorization: HexString,\r\n    value: Coins,\r\n    withdrawer: PublicKeyHashString,\r\n}\r\n\r\nconst TX_WEIGHT_BASE = 105;\r\nconst TX_WEIGHT_INPUT_SIZE = 133;\r\nconst TX_WEIGHT_OUTPUT_SIZE = 36;\r\n\r\nexport class StakePayload extends TransactionPayloadMultiSig<StakeDepositParams> {\r\n\r\n    public static MAX_WEIGHT = 10000;          // 10,000\r\n    public static MIN_VALUE = 10000 * 10 ** 9; // 10,000.00 $WIT\r\n\r\n    constructor (protoTypeName: string, specs?: any) {\r\n        super(protoTypeName, specs)\r\n    }\r\n\r\n    public get maxWeight(): number {\r\n        return StakePayload.MAX_WEIGHT\r\n    }\r\n\r\n    public get prepared(): boolean {\r\n        return (\r\n            !!this._target\r\n                && this._covered >= this._target.value.pedros \r\n                && this._inputs.length > 0\r\n        )\r\n    }\r\n\r\n    public get value(): Coins {\r\n        return this._target?.value || Coins.zero()\r\n    }\r\n\r\n    public get weight(): number {\r\n        return (\r\n            TX_WEIGHT_BASE\r\n                + this._inputs.length * TX_WEIGHT_INPUT_SIZE \r\n                + this._outputs.length * TX_WEIGHT_OUTPUT_SIZE \r\n        );\r\n    }\r\n\r\n    public intoReceipt(target: StakeDepositParams, network?: Network) {\r\n        return {\r\n            authorization: target.authorization,\r\n            withdrawer: target.withdrawer,\r\n            validator: PublicKeyHash.fromHexString(target.authorization.substring(0, 40)).toBech32(network),\r\n        }\r\n    }\r\n\r\n    public toJSON(_humanize = false, network?: Network): any {\r\n        return {\r\n            inputs: this.inputs\r\n                .map(utxo => {\r\n                    return { output_pointer: utxo.output_pointer }\r\n                }),\r\n            ...(\r\n                this._target ? { output: {\r\n                    authorization: RecoverableSignature.from(\r\n                            this._target.authorization.substring(40), \r\n                            PublicKeyHash.fromBech32(this._target.withdrawer).toBytes32()\r\n                        ).toKeyedSignature(),\r\n                    key: {\r\n                        validator: PublicKeyHash.fromHexString(this._target.authorization.substring(0, 40)).toBech32(network),\r\n                        withdrawer: this._target.withdrawer,\r\n                    },\r\n                    value: this._target.value.pedros.toString(),\r\n                }} : {}\r\n            ),\r\n            ...(\r\n                this.outputs.length > 0 ? { change: {\r\n                    pkh: this.outputs[0].pkh,\r\n                    value: this.outputs[0].value.toString(),\r\n                    time_lock: 0,\r\n                }} : {}\r\n            ),\r\n        }\r\n    }   \r\n\r\n    public toProtobuf(): any {\r\n        if (this.prepared && this._target) {\r\n            return {    \r\n                inputs: this.inputs\r\n                    .map(utxo => { \r\n                        const transactionId = utxo.output_pointer.split(':')[0]\r\n                        const outputIndex = parseInt(utxo.output_pointer.split(':')[1])\r\n                        return {\r\n                            outputPointer: {\r\n                                transactionId: { SHA256: Array.from(fromHexString(transactionId)) },\r\n                                ...(outputIndex > 0 ? { outputIndex } : {}),\r\n                            },\r\n                        }\r\n                    }),\r\n                output: {\r\n                    authorization: RecoverableSignature.from(\r\n                            this._target.authorization.substring(40), \r\n                            PublicKeyHash.fromBech32(this._target.withdrawer).toBytes32()\r\n                        ).toProtobuf(),\r\n                    key: {\r\n                        validator: { hash: Array.from(PublicKeyHash.fromHexString(this._target.authorization.substring(0, 40)).toBytes20()) },\r\n                        withdrawer: { hash: Array.from(PublicKeyHash.fromBech32(this._target.withdrawer).toBytes20()) },\r\n                    },\r\n                    value: Long.fromValue(this._target.value.pedros),\r\n                },\r\n                ...(\r\n                    this._outputs.length > 0 ? { change : {\r\n                        pkh: { hash: Array.from(PublicKeyHash.fromBech32(this.outputs[0].pkh).toBytes20()) },\r\n                        value: Long.fromValue(this.outputs[0].value.toString()),\r\n                        // timeLock: 0,\r\n                    }} : { change: { pkh: { hash: Array(20).fill(0) }}}\r\n                ),\r\n            }\r\n        }\r\n    }\r\n\r\n    public validateTarget(target?: any): StakeDepositParams | undefined {\r\n        target = this._cleanTargetExtras(target)\r\n        if (target && Object.keys(target).length > 0) {\r\n            if (!(\r\n                target\r\n                    && target?.authorization\r\n                    && (\r\n                        !target?.fees \r\n                        || (\r\n                            target.fees instanceof Coins && (target.fees as Coins).pedros > 0 \r\n                            || Object.values(TransactionPriority).includes(target.fees)\r\n                        )\r\n                    )\r\n                    && target?.value && (target.value as Coins).pedros > 0\r\n                    && target?.withdrawer\r\n            )) {\r\n                throw new TypeError(`${this.constructor.name}: invalid options: ${JSON.stringify(target)}`)\r\n            } else {\r\n                if ((target.value as Coins).pedros < StakePayload.MIN_VALUE) {\r\n                    throw new TypeError(\r\n                        `${this.constructor.name}: value below minimum stake: ${\r\n                            (target.value as Coins).wits\r\n                        } < ${\r\n                            Coins.fromNanowits(BigInt(StakePayload.MIN_VALUE)).wits\r\n                        } $WIT`\r\n                    );\r\n                }\r\n                const pubKey = PublicKey.recoverFrom(\r\n                    target.authorization.substring(40),\r\n                    PublicKeyHash.fromBech32(target.withdrawer).toBytes32()\r\n                )\r\n                if (pubKey.hash().toHexString() !== target.authorization.substring(0, 40)) {\r\n                    throw new TypeError(\r\n                        `${this.constructor.name}: authorization code not valid for withdrawer ${target.withdrawer}.`\r\n                    )\r\n                }\r\n                return target as StakeDepositParams\r\n            }\r\n        } else {\r\n            return undefined\r\n        }\r\n    }\r\n\r\n    protected _cleanTargetExtras(target?: any): any {\r\n        if (target) {\r\n            return Object.fromEntries(\r\n                Object.entries(target).filter(([key,]) => [\r\n                    'authorization',\r\n                    'fees',\r\n                    'value',\r\n                    'withdrawer',\r\n                ].includes(key))\r\n            )\r\n        }\r\n    }\r\n\r\n    protected async _estimateNetworkFees(provider: IJsonRpcProvider, priority = TransactionPriority.Medium): Promise<bigint> {\r\n        if (!this._priorities) {\r\n            this._priorities = await provider.priorities()\r\n        }\r\n        return BigInt(Math.floor(\r\n            // todo: replace `vtt_` for `st_`\r\n            this._priorities[`vtt_${priority}`].priority * (\r\n                this.covered ? this.weight : this.weight\r\n                    // estimate one more input as to cover for network fees\r\n                    + TX_WEIGHT_INPUT_SIZE \r\n                    // estimate weight of one single output in case there was change to pay back\r\n                    + TX_WEIGHT_OUTPUT_SIZE \r\n            )\r\n        ));\r\n    }\r\n\r\n}\r\n"]}
|