@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,36 @@
1
+ import { Epoch, ValueTransferOutput } from "../../types";
2
+ import { ILedger, IJsonRpcProvider } from "../interfaces";
3
+ import { TransactionPayload } from "../payloads";
4
+ import { Coins, PublicKeyHashString, TransactionParams, TransactionPriority } from "../types";
5
+ export type StakeWithdrawalParams = TransactionParams & {
6
+ nonce?: Epoch;
7
+ validator: PublicKeyHashString;
8
+ value: Coins;
9
+ };
10
+ export declare class UnstakePayload extends TransactionPayload<StakeWithdrawalParams> {
11
+ static MIN_TIMELOCK_SECS: number;
12
+ static WEIGHT: number;
13
+ protected _outputs: Array<ValueTransferOutput>;
14
+ constructor(protoTypeName: string, specs?: any);
15
+ get covered(): boolean;
16
+ get maxWeight(): number;
17
+ get outputs(): Array<ValueTransferOutput>;
18
+ get prepared(): boolean;
19
+ get value(): Coins;
20
+ get weight(): number;
21
+ consumeUtxos(ledger: ILedger): Promise<bigint>;
22
+ intoReceipt(target: StakeWithdrawalParams): {
23
+ withdrawer?: string | undefined;
24
+ nonce: number | undefined;
25
+ outputLock: number;
26
+ validator: string;
27
+ };
28
+ prepareOutputs(): any;
29
+ resetTarget(target: StakeWithdrawalParams): any;
30
+ toJSON(_humanize?: boolean): any;
31
+ toProtobuf(): any;
32
+ validateTarget(target?: any): StakeWithdrawalParams | undefined;
33
+ protected _cleanTargetExtras(target?: any): any;
34
+ protected _estimateNetworkFees(provider: IJsonRpcProvider, priority?: TransactionPriority): Promise<bigint>;
35
+ }
36
+ //# sourceMappingURL=UnstakePayload.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"UnstakePayload.d.ts","sourceRoot":"","sources":["../../../../../src/lib/crypto/payloads/UnstakePayload.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAA;AACxD,OAAO,EAAE,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAA;AACzD,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAA;AAChD,OAAO,EAAE,KAAK,EAAiB,mBAAmB,EAAE,iBAAiB,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAA;AAE5G,MAAM,MAAM,qBAAqB,GAAG,iBAAiB,GAAG;IACpD,KAAK,CAAC,EAAE,KAAK,CAAC;IACd,SAAS,EAAE,mBAAmB,CAAC;IAC/B,KAAK,EAAE,KAAK,CAAC;CAChB,CAAA;AAED,qBAAa,cAAe,SAAQ,kBAAkB,CAAC,qBAAqB,CAAC;IAEzE,OAAc,iBAAiB,SAAa;IAC5C,OAAc,MAAM,SAAO;IAE3B,SAAS,CAAC,QAAQ,EAAE,KAAK,CAAC,mBAAmB,CAAC,CAAK;gBAEtC,aAAa,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,GAAG;IAI/C,IAAW,OAAO,IAAI,OAAO,CAG5B;IAED,IAAW,SAAS,IAAI,MAAM,CAE7B;IAED,IAAW,OAAO,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAE/C;IAED,IAAW,QAAQ,IAAI,OAAO,CAK7B;IAED,IAAW,KAAK,IAAI,KAAK,CAExB;IAED,IAAW,MAAM,IAAI,MAAM,CAE1B;IAEY,YAAY,CAAC,MAAM,EAAE,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC;IAiCpD,WAAW,CAAC,MAAM,EAAE,qBAAqB;;;;;;IASzC,cAAc,IAAI,GAAG;IAErB,WAAW,CAAC,MAAM,EAAE,qBAAqB,GAAG,GAAG;IAQ/C,MAAM,CAAC,SAAS,UAAQ,GAAG,GAAG;IAa9B,UAAU,IAAI,GAAG;IAejB,cAAc,CAAC,MAAM,CAAC,EAAE,GAAG,GAAG,qBAAqB,GAAG,SAAS;IA+BtE,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;CAU3H"}
@@ -0,0 +1,154 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.UnstakePayload = void 0;
4
+ const Long = require("long");
5
+ const payloads_1 = require("../payloads");
6
+ const types_1 = require("../types");
7
+ class UnstakePayload extends payloads_1.TransactionPayload {
8
+ constructor(protoTypeName, specs) {
9
+ super(protoTypeName, specs);
10
+ this._outputs = [];
11
+ }
12
+ get covered() {
13
+ return this._covered > 0
14
+ && this.outputs.length > 0;
15
+ }
16
+ get maxWeight() {
17
+ return UnstakePayload.WEIGHT;
18
+ }
19
+ get outputs() {
20
+ return this._outputs;
21
+ }
22
+ get prepared() {
23
+ return (this._target !== undefined
24
+ && this._outputs.length > 0);
25
+ }
26
+ get value() {
27
+ return this._target?.value || types_1.Coins.zero();
28
+ }
29
+ get weight() {
30
+ return UnstakePayload.WEIGHT;
31
+ }
32
+ async consumeUtxos(ledger) {
33
+ if (!this._target) {
34
+ throw new Error(`${this.constructor.name}: internal error: no in-flight params.`);
35
+ }
36
+ else if (!this._covered) {
37
+ const signer = ledger.getSigner();
38
+ if (!signer) {
39
+ throw new Error(`${this.constructor.name}: internal error: no default Signer for ${ledger.constructor.name} ${ledger.pkh}.`);
40
+ }
41
+ // settle fees if none specified
42
+ if (this._target?.fees instanceof types_1.Coins) {
43
+ this._fees = this._target.fees.pedros;
44
+ }
45
+ else {
46
+ const priority = this._target?.fees || types_1.TransactionPriority.Medium;
47
+ this._fees = await this._estimateNetworkFees(ledger.provider, priority);
48
+ }
49
+ // determine whether withdrawn amount covers MORE than the fees
50
+ this._change = this.value.pedros - this._fees;
51
+ if (this._change > 0) {
52
+ // settle nonce if none specified
53
+ this._covered = BigInt(this._target?.nonce || await signer.getStakeEntryNonce(this._target.validator));
54
+ this._outputs.push({
55
+ pkh: signer.pkh,
56
+ value: this.value.pedros - this._fees,
57
+ time_lock: UnstakePayload.MIN_TIMELOCK_SECS
58
+ });
59
+ }
60
+ }
61
+ return this._change;
62
+ }
63
+ intoReceipt(target) {
64
+ return {
65
+ nonce: target.nonce,
66
+ outputLock: UnstakePayload.MIN_TIMELOCK_SECS,
67
+ validator: target.validator,
68
+ ...(this._outputs ? { withdrawer: this._outputs[0].pkh } : {}),
69
+ };
70
+ }
71
+ prepareOutputs() { }
72
+ resetTarget(target) {
73
+ this._change = 0n;
74
+ this._covered = 0n;
75
+ this._fees = 0n;
76
+ this._outputs = [];
77
+ this._target = target;
78
+ }
79
+ toJSON(_humanize = false) {
80
+ return {
81
+ fee: this._fees.toString(),
82
+ nonce: Number(this._covered),
83
+ operator: this._target?.validator,
84
+ withdrawal: {
85
+ pkh: this.outputs[0].pkh,
86
+ value: this.outputs[0].value.toString(),
87
+ time_lock: UnstakePayload.MIN_TIMELOCK_SECS,
88
+ },
89
+ };
90
+ }
91
+ toProtobuf() {
92
+ if (this.prepared && this._target) {
93
+ return {
94
+ ...(this._fees > 0 ? { fee: Long.fromValue(this._fees) } : {}),
95
+ nonce: Number(this._covered),
96
+ operator: { hash: Array.from(types_1.PublicKeyHash.fromBech32(this._target.validator).toBytes20()) },
97
+ withdrawal: {
98
+ pkh: { hash: Array.from(types_1.PublicKeyHash.fromBech32(this.outputs[0].pkh).toBytes20()) },
99
+ value: Long.fromValue(this.outputs[0].value),
100
+ timeLock: this.outputs[0].time_lock,
101
+ },
102
+ };
103
+ }
104
+ }
105
+ validateTarget(target) {
106
+ target = this._cleanTargetExtras(target);
107
+ if (target && Object.keys(target).length > 0) {
108
+ if (!(target
109
+ && (!target?.fees
110
+ || (target.fees instanceof types_1.Coins && target.fees.pedros >= 0
111
+ || Object.values(types_1.TransactionPriority).includes(target.fees)))
112
+ && target?.value && target.value.pedros > 0
113
+ && target?.validator)) {
114
+ throw new TypeError(`${this.constructor.name}: invalid options: ${JSON.stringify(target)}`);
115
+ }
116
+ else {
117
+ if (target?.nonce || parseInt(target.nonce) <= 0) {
118
+ throw new TypeError(`${this.constructor.name}: nonce must be positive if provided.`);
119
+ }
120
+ // asume zero fees if not given in target params
121
+ if (!target?.fees) {
122
+ target.fees = types_1.Coins.zero();
123
+ }
124
+ return target;
125
+ }
126
+ }
127
+ else {
128
+ return undefined;
129
+ }
130
+ }
131
+ _cleanTargetExtras(target) {
132
+ if (target) {
133
+ return Object.fromEntries(Object.entries(target).filter(([key,]) => [
134
+ 'fees',
135
+ 'nonce',
136
+ 'value',
137
+ 'validator',
138
+ ].includes(key)));
139
+ }
140
+ }
141
+ async _estimateNetworkFees(provider, priority = types_1.TransactionPriority.Medium) {
142
+ if (!this._priorities) {
143
+ this._priorities = await provider.priorities();
144
+ }
145
+ return BigInt(Math.floor(
146
+ // todo: replace `vtt_` for `ut_`
147
+ this._priorities[`vtt_${priority}`].priority
148
+ * this.weight));
149
+ }
150
+ }
151
+ exports.UnstakePayload = UnstakePayload;
152
+ UnstakePayload.MIN_TIMELOCK_SECS = 1209600;
153
+ UnstakePayload.WEIGHT = 153;
154
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"UnstakePayload.js","sourceRoot":"","sources":["../../../../../src/lib/crypto/payloads/UnstakePayload.ts"],"names":[],"mappings":"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","sourcesContent":["const Long = require(\"long\")\r\n\r\nimport { Epoch, ValueTransferOutput } from \"../../types\"\r\nimport { ILedger, IJsonRpcProvider } from \"../interfaces\"\r\nimport { TransactionPayload } from \"../payloads\"\r\nimport { Coins, PublicKeyHash, PublicKeyHashString, TransactionParams, TransactionPriority } from \"../types\"\r\n\r\nexport type StakeWithdrawalParams = TransactionParams & {\r\n    nonce?: Epoch,\r\n    validator: PublicKeyHashString,\r\n    value: Coins,\r\n}\r\n\r\nexport class UnstakePayload extends TransactionPayload<StakeWithdrawalParams> {\r\n\r\n    public static MIN_TIMELOCK_SECS = 1_209_600;\r\n    public static WEIGHT = 153;\r\n\r\n    protected _outputs: Array<ValueTransferOutput> = []\r\n\r\n    constructor (protoTypeName: string, specs?: any) {\r\n        super(protoTypeName, specs)\r\n    }\r\n\r\n    public get covered(): boolean {\r\n        return this._covered > 0\r\n            && this.outputs.length > 0 \r\n    }\r\n\r\n    public get maxWeight(): number {\r\n        return UnstakePayload.WEIGHT\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._target !== undefined\r\n                && this._outputs.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 UnstakePayload.WEIGHT\r\n    }\r\n    \r\n    public async consumeUtxos(ledger: ILedger): 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._covered) {\r\n            const signer = ledger.getSigner()\r\n            if (!signer) {\r\n                throw new Error(\r\n                    `${this.constructor.name}: internal error: no default Signer for ${ledger.constructor.name} ${ledger.pkh}.`\r\n                )\r\n            }\r\n            // settle fees if none specified\r\n            if (this._target?.fees instanceof Coins) {\r\n                this._fees = this._target.fees.pedros\r\n            } else {\r\n                const priority = this._target?.fees as TransactionPriority || TransactionPriority.Medium\r\n                this._fees = await this._estimateNetworkFees(ledger.provider, priority)\r\n            }\r\n            // determine whether withdrawn amount covers MORE than the fees\r\n            this._change = this.value.pedros - this._fees\r\n            if (this._change > 0) {\r\n                // settle nonce if none specified\r\n                this._covered = BigInt(this._target?.nonce || await signer.getStakeEntryNonce(this._target.validator))\r\n                this._outputs.push({\r\n                    pkh: signer.pkh,\r\n                    value: this.value.pedros - this._fees,\r\n                    time_lock: UnstakePayload.MIN_TIMELOCK_SECS\r\n                })\r\n            }\r\n        }\r\n        return this._change;\r\n    }\r\n\r\n    public intoReceipt(target: StakeWithdrawalParams) {\r\n        return {\r\n            nonce: target.nonce,\r\n            outputLock: UnstakePayload.MIN_TIMELOCK_SECS,\r\n            validator: target.validator,\r\n            ...(this._outputs ? { withdrawer: this._outputs[0].pkh } : {}),\r\n        }\r\n    }\r\n\r\n    public prepareOutputs(): any {}\r\n\r\n    public resetTarget(target: StakeWithdrawalParams): any {\r\n        this._change = 0n\r\n        this._covered = 0n\r\n        this._fees = 0n\r\n        this._outputs = []\r\n        this._target = target\r\n    }\r\n\r\n    public toJSON(_humanize = false): any {\r\n        return {\r\n            fee: this._fees.toString(),\r\n            nonce: Number(this._covered),\r\n            operator: this._target?.validator,\r\n            withdrawal: {\r\n                pkh: this.outputs[0].pkh,\r\n                value: this.outputs[0].value.toString(),\r\n                time_lock: UnstakePayload.MIN_TIMELOCK_SECS,\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                ...(this._fees > 0 ? { fee: Long.fromValue(this._fees) } : {}),\r\n                nonce: Number(this._covered),\r\n                operator: { hash: Array.from(PublicKeyHash.fromBech32(this._target.validator).toBytes20()) },\r\n                withdrawal: {\r\n                    pkh: { hash: Array.from(PublicKeyHash.fromBech32(this.outputs[0].pkh).toBytes20()) },\r\n                    value: Long.fromValue(this.outputs[0].value),\r\n                    timeLock: this.outputs[0].time_lock,\r\n                },\r\n            }\r\n        }\r\n    }\r\n\r\n    public validateTarget(target?: any): StakeWithdrawalParams | 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?.value && (target.value as Coins).pedros > 0\r\n                    && target?.validator\r\n            )) {\r\n                throw new TypeError(`${this.constructor.name}: invalid options: ${JSON.stringify(target)}`)\r\n            } else {\r\n                if (target?.nonce || parseInt(target.nonce) <= 0) {\r\n                    throw new TypeError(`${this.constructor.name}: nonce must be positive if provided.`)\r\n                }\r\n                // asume zero fees if not given in target params\r\n                if (!target?.fees) {\r\n                    target.fees = Coins.zero()\r\n                }\r\n                return target as StakeWithdrawalParams\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                    'fees',\r\n                    'nonce',\r\n                    'value',\r\n                    'validator',\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 `ut_`\r\n            this._priorities[`vtt_${priority}`].priority\r\n                * this.weight\r\n        ));\r\n    }\r\n}\r\n"]}
@@ -0,0 +1,25 @@
1
+ import { IJsonRpcProvider } from "../../types";
2
+ import { TransactionPayloadMultiSig } from "../payloads";
3
+ import { Coins, PublicKeyHashString, TransactionParams, TransactionPriority } from "../types";
4
+ export type ValueTransferParams = TransactionParams & {
5
+ recipients: Array<[pkh: PublicKeyHashString, value: Coins]>;
6
+ timelock?: number;
7
+ };
8
+ export declare class ValueTransferPayload extends TransactionPayloadMultiSig<ValueTransferParams> {
9
+ static MAX_WEIGHT: number;
10
+ constructor(protoTypeName: string, initialTarget?: ValueTransferParams);
11
+ get maxWeight(): number;
12
+ get value(): Coins;
13
+ get weight(): number;
14
+ prepareOutputs(change?: {
15
+ value: bigint;
16
+ pkh: PublicKeyHashString;
17
+ }): any;
18
+ intoReceipt(target: ValueTransferParams): any;
19
+ toJSON(): any;
20
+ toProtobuf(): any;
21
+ validateTarget(target?: any): ValueTransferParams | undefined;
22
+ protected _cleanTargetExtras(target?: any): any;
23
+ protected _estimateNetworkFees(provider: IJsonRpcProvider, priority?: TransactionPriority): Promise<bigint>;
24
+ }
25
+ //# sourceMappingURL=ValueTransferPayload.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ValueTransferPayload.d.ts","sourceRoot":"","sources":["../../../../../src/lib/crypto/payloads/ValueTransferPayload.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAA;AAE9C,OAAO,EAAE,0BAA0B,EAAE,MAAM,aAAa,CAAA;AACxD,OAAO,EAAE,KAAK,EAAiB,mBAAmB,EAAE,iBAAiB,EAAE,mBAAmB,EAAE,MAAM,UAAU,CAAA;AAE5G,MAAM,MAAM,mBAAmB,GAAG,iBAAiB,GAAG;IAClD,UAAU,EAAE,KAAK,CAAC,CAAC,GAAG,EAAE,mBAAmB,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC;IAC5D,QAAQ,CAAC,EAAE,MAAM,CAAC;CACrB,CAAA;AAMD,qBAAa,oBAAqB,SAAQ,0BAA0B,CAAC,mBAAmB,CAAC;IAErF,OAAc,UAAU,SAAS;gBAEpB,aAAa,EAAE,MAAM,EAAE,aAAa,CAAC,EAAE,mBAAmB;IAIvE,IAAW,SAAS,IAAI,MAAM,CAE7B;IAED,IAAW,KAAK,IAAI,KAAK,CAExB;IAED,IAAW,MAAM,IAAI,MAAM,CAK1B;IAEM,cAAc,CAAC,MAAM,CAAC,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,GAAG,EAAE,mBAAmB,CAAA;KAAE,GAAG,GAAG;IAWzE,WAAW,CAAC,MAAM,EAAE,mBAAmB,GAAG,GAAG;IAO7C,MAAM,IAAI,GAAG;IAcb,UAAU,IAAI,GAAG;IAuBjB,cAAc,CAAC,MAAM,CAAC,EAAE,GAAG,GAAG,mBAAmB,GAAG,SAAS;IAsCpE,SAAS,CAAC,kBAAkB,CAAC,MAAM,CAAC,EAAE,GAAG,GAAG,GAAG;cAY/B,oBAAoB,CAAC,QAAQ,EAAE,gBAAgB,EAAE,QAAQ,sBAA6B,GAAG,OAAO,CAAC,MAAM,CAAC;CAc3H"}
@@ -0,0 +1,128 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ValueTransferPayload = 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_INPUT_SIZE = 133;
9
+ const TX_WEIGHT_OUTPUT_SIZE = 36;
10
+ const TX_WEIGHT_GAMMA = 10;
11
+ class ValueTransferPayload extends payloads_1.TransactionPayloadMultiSig {
12
+ constructor(protoTypeName, initialTarget) {
13
+ super(protoTypeName, initialTarget);
14
+ }
15
+ get maxWeight() {
16
+ return ValueTransferPayload.MAX_WEIGHT;
17
+ }
18
+ get value() {
19
+ return types_1.Coins.fromPedros(this._target?.recipients.reduce((prev, [, curr]) => prev + curr.pedros, 0n) || 0n);
20
+ }
21
+ get weight() {
22
+ return (this._inputs.length * TX_WEIGHT_INPUT_SIZE
23
+ + this._outputs.length * TX_WEIGHT_OUTPUT_SIZE * TX_WEIGHT_GAMMA);
24
+ }
25
+ prepareOutputs(change) {
26
+ if (this._target && this._outputs.length === 0) {
27
+ this._outputs.push(...this._target.recipients.map(([pkh, value]) => ({
28
+ pkh,
29
+ value: value.pedros,
30
+ time_lock: this._target?.timelock || 0
31
+ })));
32
+ super.prepareOutputs(change);
33
+ }
34
+ }
35
+ intoReceipt(target) {
36
+ return {
37
+ outputLock: target.timelock,
38
+ recipients: target.recipients.map(([pkh,]) => pkh).filter((pkh, index, array) => index === array.indexOf(pkh)),
39
+ };
40
+ }
41
+ toJSON() {
42
+ return {
43
+ inputs: this.inputs
44
+ .map(utxo => {
45
+ return { output_pointer: utxo.output_pointer };
46
+ }),
47
+ outputs: this.outputs.map(vto => ({
48
+ pkh: vto.pkh,
49
+ time_lock: vto.time_lock,
50
+ value: vto.value.toString(),
51
+ }))
52
+ };
53
+ }
54
+ toProtobuf() {
55
+ if (this.prepared) {
56
+ return {
57
+ inputs: this.inputs
58
+ .map(utxo => {
59
+ const transactionId = utxo.output_pointer.split(':')[0];
60
+ const outputIndex = parseInt(utxo.output_pointer.split(':')[1]);
61
+ return {
62
+ outputPointer: {
63
+ transactionId: { SHA256: Array.from((0, helpers_1.fromHexString)(transactionId)) },
64
+ ...(outputIndex > 0 ? { outputIndex } : {}),
65
+ },
66
+ };
67
+ }),
68
+ outputs: this.outputs.map(vto => ({
69
+ pkh: { hash: Array.from(types_1.PublicKeyHash.fromBech32(vto.pkh).toBytes20()), },
70
+ value: Long.fromValue(vto.value),
71
+ ...(vto.time_lock > 0 ? { timeLock: vto.time_lock } : {}),
72
+ }))
73
+ };
74
+ }
75
+ }
76
+ validateTarget(target) {
77
+ target = this._cleanTargetExtras(target);
78
+ if (target && Object.keys(target).length > 0) {
79
+ if (!target) {
80
+ throw new TypeError(`${this.constructor.name}: no options passed.`);
81
+ }
82
+ else if (!(!target?.fees
83
+ || ((target.fees instanceof types_1.Coins && target.fees.pedros > 0)
84
+ || Object.values(types_1.TransactionPriority).includes(target.fees)))) {
85
+ throw new TypeError(`${this.constructor.name}: invalid fees: ${target.fees}`);
86
+ }
87
+ else if (!target?.recipients) {
88
+ throw new TypeError(`${this.constructor.name}: no recipients.`);
89
+ }
90
+ else if (!(Array.isArray(target.recipients)
91
+ && target.recipients.length > 0
92
+ && target.recipients.filter(([, value]) => value instanceof types_1.Coins))) {
93
+ throw new TypeError(`${this.constructor.name}: invalid recipients: ${target.recipients}`);
94
+ }
95
+ else if (!(!target?.timelock || target.timelock >= 0)) {
96
+ throw new TypeError(`${this.constructor.name}: invalid timelock: ${target.timelock}`);
97
+ }
98
+ else {
99
+ return target;
100
+ }
101
+ }
102
+ else {
103
+ return undefined;
104
+ }
105
+ }
106
+ _cleanTargetExtras(target) {
107
+ if (target) {
108
+ return Object.fromEntries(Object.entries(target).filter(([key,]) => [
109
+ 'fees',
110
+ 'recipients',
111
+ 'timelock',
112
+ ].includes(key)));
113
+ }
114
+ }
115
+ async _estimateNetworkFees(provider, priority = types_1.TransactionPriority.Medium) {
116
+ if (!this._priorities) {
117
+ this._priorities = await provider.priorities();
118
+ }
119
+ return BigInt(Math.floor(this._priorities[`vtt_${priority}`].priority * (this.covered ? this.weight : this.weight
120
+ // estimate one more input as to cover for network fees
121
+ + TX_WEIGHT_INPUT_SIZE
122
+ // estimate as many outputs as recipients plus one, as to cover for eventual change output
123
+ + TX_WEIGHT_OUTPUT_SIZE * (this._target?.recipients.length || 1 + 1) * TX_WEIGHT_GAMMA)));
124
+ }
125
+ }
126
+ exports.ValueTransferPayload = ValueTransferPayload;
127
+ ValueTransferPayload.MAX_WEIGHT = 20000;
128
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ValueTransferPayload.js","sourceRoot":"","sources":["../../../../../src/lib/crypto/payloads/ValueTransferPayload.ts"],"names":[],"mappings":"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","sourcesContent":["const Long = require(\"long\")\r\n\r\nimport { fromHexString } from \"../../../bin/helpers\"\r\nimport { IJsonRpcProvider } from \"../../types\"\r\n\r\nimport { TransactionPayloadMultiSig } from \"../payloads\"\r\nimport { Coins, PublicKeyHash, PublicKeyHashString, TransactionParams, TransactionPriority } from \"../types\"\r\n\r\nexport type ValueTransferParams = TransactionParams & {\r\n    recipients: Array<[pkh: PublicKeyHashString, value: Coins]>,\r\n    timelock?: number,\r\n}\r\n\r\nconst TX_WEIGHT_INPUT_SIZE = 133;\r\nconst TX_WEIGHT_OUTPUT_SIZE = 36;\r\nconst TX_WEIGHT_GAMMA = 10;\r\n\r\nexport class ValueTransferPayload extends TransactionPayloadMultiSig<ValueTransferParams> {\r\n\r\n    public static MAX_WEIGHT = 20000;\r\n    \r\n    constructor (protoTypeName: string, initialTarget?: ValueTransferParams) {\r\n        super(protoTypeName, initialTarget)\r\n    }\r\n\r\n    public get maxWeight(): number {\r\n        return ValueTransferPayload.MAX_WEIGHT\r\n    }\r\n\r\n    public get value(): Coins {\r\n        return Coins.fromPedros(this._target?.recipients.reduce((prev, [,curr]) => prev + curr.pedros, 0n) || 0n)\r\n    }\r\n\r\n    public get weight(): number {\r\n        return (\r\n            this._inputs.length * TX_WEIGHT_INPUT_SIZE \r\n                + this._outputs.length * TX_WEIGHT_OUTPUT_SIZE * TX_WEIGHT_GAMMA\r\n        );\r\n    }\r\n\r\n    public prepareOutputs(change?: { value: bigint, pkh: PublicKeyHashString }): any {\r\n        if (this._target && this._outputs.length === 0) {\r\n            this._outputs.push(...this._target.recipients.map(([pkh, value]) => ({\r\n                pkh, \r\n                value: value.pedros, \r\n                time_lock: this._target?.timelock || 0\r\n            })));\r\n            super.prepareOutputs(change)\r\n        }\r\n    }\r\n\r\n    public intoReceipt(target: ValueTransferParams): any {\r\n        return {\r\n            outputLock: target.timelock,\r\n            recipients: target.recipients.map(([pkh,]) => pkh).filter((pkh, index, array) => index === array.indexOf(pkh)),\r\n        }\r\n    }\r\n\r\n    public toJSON(): 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            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        }\r\n    }   \r\n\r\n    public toProtobuf(): any {\r\n        if (this.prepared) {\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            }\r\n        }\r\n    }\r\n\r\n    public validateTarget(target?: any): ValueTransferParams | undefined {\r\n        target = this._cleanTargetExtras(target)\r\n        if (target && Object.keys(target).length > 0) {\r\n            if (!target) {\r\n                throw new TypeError(`${this.constructor.name}: no options passed.`)\r\n            \r\n            } else if (!(\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                throw new TypeError(`${this.constructor.name}: invalid fees: ${target.fees}`)\r\n            \r\n            } else if (!target?.recipients) {\r\n                throw new TypeError(`${this.constructor.name}: no recipients.`)\r\n            \r\n            } else if (!(\r\n                Array.isArray(target.recipients)\r\n                && target.recipients.length > 0\r\n                && (target.recipients as [[PublicKeyHashString, Coins]]).filter(([, value]) => value instanceof Coins)\r\n            )) {\r\n                throw new TypeError(`${this.constructor.name}: invalid recipients: ${target.recipients}`)\r\n            \r\n            } else if(!(\r\n                !target?.timelock || target.timelock >= 0\r\n            )) {\r\n                throw new TypeError(`${this.constructor.name}: invalid timelock: ${target.timelock}`)\r\n            \r\n            } else {\r\n                return target as ValueTransferParams\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                    'fees',\r\n                    'recipients',\r\n                    'timelock',\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[`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 as many outputs as recipients plus one, as to cover for eventual change output\r\n                    + TX_WEIGHT_OUTPUT_SIZE * (this._target?.recipients.length || 1 + 1) * TX_WEIGHT_GAMMA\r\n            )\r\n        ));\r\n    }\r\n}\r\n"]}
@@ -0,0 +1,57 @@
1
+ import { Type as ProtoType } from "protobufjs";
2
+ import { Hash, NetworkPriorities, ValueTransferOutput } from "../types";
3
+ import { ILedger, IJsonRpcProvider, ITransactionPayload, ITransactionPayloadMultiSig } from "./interfaces";
4
+ import { Coins, PublicKeyHashString, TransactionPriority, Utxo } from "./types";
5
+ export declare abstract class TransactionPayload<Specs> implements ITransactionPayload<Specs> {
6
+ protected _change: bigint;
7
+ protected _covered: bigint;
8
+ protected _fees: bigint;
9
+ protected _priorities?: NetworkPriorities;
10
+ protected _protoType: ProtoType;
11
+ protected _target?: Specs;
12
+ constructor(protoTypeName: string, initialTarget?: Specs);
13
+ get bytecode(): Uint8Array | undefined;
14
+ get change(): Coins | undefined;
15
+ get covered(): boolean;
16
+ get fees(): Coins | undefined;
17
+ get hash(): Hash | undefined;
18
+ intoReceipt(target: Specs): any;
19
+ abstract consumeUtxos(ledger: ILedger): Promise<bigint>;
20
+ abstract prepareOutputs(change?: {
21
+ value: bigint;
22
+ pkh: PublicKeyHashString;
23
+ }, params?: any): any;
24
+ abstract resetTarget(target: Specs): any;
25
+ abstract toJSON(humanize: boolean): any;
26
+ abstract toProtobuf(): any;
27
+ abstract validateTarget(target?: any): Specs | undefined;
28
+ abstract get outputs(): Array<ValueTransferOutput>;
29
+ abstract get maxWeight(): number;
30
+ abstract get prepared(): boolean;
31
+ abstract get value(): Coins;
32
+ abstract get weight(): number;
33
+ protected abstract _cleanTargetExtras(params?: any): any;
34
+ protected abstract _estimateNetworkFees(provider: IJsonRpcProvider, priority?: TransactionPriority): Promise<bigint>;
35
+ }
36
+ export declare abstract class TransactionPayloadMultiSig<Specs> extends TransactionPayload<Specs> implements ITransactionPayloadMultiSig<Specs> {
37
+ protected _inputs: Array<Utxo>;
38
+ protected _outputs: Array<ValueTransferOutput>;
39
+ constructor(protoTypeName: string, initialTarget?: Specs);
40
+ get inputs(): Array<Utxo>;
41
+ get outputs(): Array<ValueTransferOutput>;
42
+ get prepared(): boolean;
43
+ consumeUtxos(ledger: ILedger, reload?: boolean): Promise<bigint>;
44
+ prepareOutputs(change?: {
45
+ value: bigint;
46
+ pkh: PublicKeyHashString;
47
+ }): any;
48
+ resetTarget(target: Specs): any;
49
+ abstract toJSON(humanize: boolean): any;
50
+ abstract toProtobuf(): any;
51
+ abstract validateTarget(target?: any): Specs | undefined;
52
+ abstract get maxWeight(): number;
53
+ abstract get value(): Coins;
54
+ abstract get weight(): number;
55
+ protected abstract _cleanTargetExtras(params?: any): any;
56
+ }
57
+ //# sourceMappingURL=payloads.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"payloads.d.ts","sourceRoot":"","sources":["../../../../src/lib/crypto/payloads.ts"],"names":[],"mappings":"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"}