tx · HtV37J7tBNTzpMD31MYs2tDv8qk7j3DwebfkVyKUVUiY 3MyFHYRXw55tL2gQ928mKUuQoEabktL3hCR: -0.05000000 Waves 2023.07.18 16:28 [2671378] smart account 3MyFHYRXw55tL2gQ928mKUuQoEabktL3hCR > SELF 0.00000000 Waves
{ "type": 13, "id": "HtV37J7tBNTzpMD31MYs2tDv8qk7j3DwebfkVyKUVUiY", "fee": 5000000, "feeAssetId": null, "timestamp": 1689686928096, "version": 2, "chainId": 84, "sender": "3MyFHYRXw55tL2gQ928mKUuQoEabktL3hCR", "senderPublicKey": "bMD2x5tkB4skw1DeXM1jqE4hBh4o6tehbczXwwV7aRa", "proofs": [ "cUF7zACiTz4oJHBN6QHUzV1JgEPbj8V6wFCMnyEJacxpWq1E4M9BcKFZ6X12G9vx5sVw3XDNu6bvdtNL47tz649" ], "script": "base64:BgLnBwgCEgMKAQgSBQoDCAgIEgMKAQgSACIDU0VQIglQUkVDSVNJT04iFERFRkFVTFRfTUFYX1NMSVBQQUdFIgRtdWxwIgJfeCICX3kiBGpvaW4iAmFyIg5rZXlJbml0aWFsaXplZCIVa2V5Q29vcmRpbmF0b3JBZGRyZXNzIhJrZXlWZXJpZmllckFkZHJlc3MiFWtleUVhc3RTdGFraW5nQWRkcmVzcyISa2V5U3VidmF1bHRBZGRyZXNzIgxrZXlFYXN0QXNzZXQiDmtleU1heFNsaXBwYWdlIglrZXlTaWduZWQiCF9hZGRyZXNzIgVfdHhJZCINaXNJbml0aWFsaXplZCIPbXVzdEluaXRpYWxpemVkIhJtdXN0Tm90SW5pdGlhbGl6ZWQiCG11c3RTZWxmIgFpIgtjb29yZGluYXRvciIIdmVyaWZpZXIiByRtYXRjaDAiAXMiCmdldEFkZHJlc3MiA2tleSIDZXJyIhVnZXRFYXN0U3Rha2luZ0FkZHJlc3MiDmdldE1heFNsaXBwYWdlIg9nZXRFYXN0QXNzZXRTdHIiDGdldEVhc3RBc3NldCIMY2hlY2tBZGRyZXNzIgdhZGRyZXNzIhBJZHhTdGFrZXJBZGRyZXNzIhJJZHhFeGNoYW5nZUFkZHJlc3MiCWtleUFzc2V0cyIIa2V5QXNzZXQiCV9hc3NldFN0ciIXa2V5VG90YWxSZXdhcmRDb2xsZWN0ZWQiCWRhdGFBc3NldCIOX3N0YWtlckFkZHJlc3MiEF9leGNoYW5nZUFkZHJlc3MiF2dldFRvdGFsUmV3YXJkQ29sbGVjdGVkIglnZXRBc3NldHMiDmdldEFzc2V0c1ZhbHVlIghnZXRBc3NldCIGY29uZmlnIgZzdGFrZXIiCGV4Y2hhbmdlIhNfY29vcmRpbmF0b3JBZGRyZXNzIgZjaGVja3MiBmFzc2V0cyIJbmV3QXNzZXRzIgNpZHgiEGNsYWltQW5kRXhjaGFuZ2UiA2FjYyIEbmV4dCIIYXNzZXRTdHIiDSR0MDEzNjY0MTM3MzAiBnByb2ZpdCIBQCIIc3VidmF1bHQiCWFzc2V0UmF0ZSIFdXNkRXEiCHNsaXBwYWdlIg1taW5FYXN0QW1vdW50IgVhc3NldCIPZXhjaGFuZ2VkQW1vdW50IgxyZXdhcmRBbW91bnQi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dGlhbGl6ZQECYWEEAmFiCQDMCAIJAQF2AQUBdwkAzAgCCQEBdQAJAMwIAgkBAUkBBQJhYQUDbmlsAwkAAAIFAmFiBQJhYgkAzAgCCQELU3RyaW5nRW50cnkCCQEBagAFAmFhCQDMCAIJAQxCb29sZWFuRW50cnkCCQEBaQAGBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BdwEIYWRkQXNzZXQDAU8BUgFTBAJhYgkAzAgCCQEBdAAJAMwIAgkBAXYBBQF3CQDMCAIJAQFJAQUBUgkAzAgCCQEBSQEFAVMFA25pbAMJAAACBQJhYgUCYWIEAmFjCQEBVgADCQEPY29udGFpbnNFbGVtZW50AgUCYWMFAU8JAAIBAhVBc3NldCBhbHJlYWR5IGV4aXN0cy4EAmFkCQC5CQIJAM0IAgUCYWMFAU8FAWEJAMwIAgkBC1N0cmluZ0VudHJ5AgkBAU0ABQJhZAkAzAgCCQELU3RyaW5nRW50cnkCCQEBTgEFAU8JAQFRAgUBUgUBUwUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAXcBC3JlbW92ZUFzc2V0AQFPBAJhYgkAzAgCCQEBdAAJAMwIAgkBAXYBBQF3BQNuaWwDCQAAAgUCYWIFAmFiBAJhYwkBAVUABAJhZAQBegkAzwgCBQJhYwUBTwMJAAECBQF6AgNJbnQEAmFlBQF6CQC5CQIJANEIAgUCYWMFAmFlBQFhAwkAAQIFAXoCBFVuaXQJAAIBAiNVbmFibGUgdG8gcHJvY2VlZC4gQXNzZXQgbm90IGZvdW5kLgkAAgECC01hdGNoIGVycm9yCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQFNAAUCYWQJAMwIAgkBC0RlbGV0ZUVudHJ5AQkBAU4BBQFPBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BdwEKYWNrUmV3YXJkcwAKAQJhZgICYWcCYWgEAXoFAmFoAwkAAQIFAXoCBlN0cmluZwQCYWkFAXoEAmFqCQEBVwEFAmFpBAFZCAUCYWoCXzEEAVoIBQJhagJfMgQCYWsKAAJhbAkA/AcEBQFZAgtjbGFpbVByb2ZpdAUDbmlsBQNuaWwDCQABAgUCYWwCA0ludAUCYWwJAAIBCQCsAgIJAAMBBQJhbAIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50AwkAAAIFAmFrBQJhawQCYW0JARFAZXh0ck5hdGl2ZSgxMDYyKQEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQFZCQEBbQACE1N1YnZhdWx0IG5vdCBmb3VuZC4EAmFuCgACYWwJAPwHBAUCYW0CEmdldEN1cnJlbnRVc2RQcmljZQUDbmlsBQNuaWwDCQABAgUCYWwCA0ludAUCYWwJAAIBCQCsAgIJAAMBBQJhbAIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50AwkAAAIFAmFuBQJhbgQCYW8JAQFkAgUCYWsFAmFuBAJhcAkBAUYABAJhcQkBAWQCBQJhbwUCYXAEAmFyAwkAAAIFAmFpAgVXQVZFUwUEdW5pdAkA2QQBBQJhaQQCYXMKAAJhbAkA/AcEBQFaAgRzd2FwCQDMCAIFAmFxCQDMCAIJAQFHAAkAzAgCCQClCAEFBHRoaXMFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUCYXIFAmFrBQNuaWwDCQABAgUCYWwCA0ludAUCYWwJAAIBCQCsAgIJAAMBBQJhbAIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50AwkAAAIFAmFzBQJhcwkAZAIFAmFnBQJhcwkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgMJAAECBQF6AgRVbml0BQJhZwkAAgECC01hdGNoIGVycm9yBAJhYwkBAVUABAJhdAoAAmF1BQJhYwoAAmF2CQCQAwEFAmF1CgACYXcAAAoBAmF4AgJheQJhegMJAGcCBQJhegUCYXYFAmF5CQECYWYCBQJheQkAkQMCBQJhdQUCYXoKAQJhQQICYXkCYXoDCQBnAgUCYXoFAmF2BQJheQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDEwCQECYUECCQECYXgCCQECYXgCCQECYXgCCQECYXgCCQECYXgCCQECYXgCCQECYXgCCQECYXgCCQECYXgCCQECYXgCBQJhdwAAAAEAAgADAAQABQAGAAcACAAJAAoDCQAAAgUCYXQFAmF0BAJhQgkAZAIJAQFUAAUCYXQEAmFDCQEPQXR0YWNoZWRQYXltZW50AgkBAUgABQJhdAQCYUQJAPwHBAkBAUUAAhFhZGRTdGFraW5nUmV3YXJkcwUDbmlsCQDMCAIFAmFDBQNuaWwDCQAAAgUCYUQFAmFECQDMCAIJAQxJbnRlZ2VyRW50cnkCCQEBUAAFAmFCBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BAmFFAQJhRgAEAXoJAQF5AAMJAAECBQF6AgZTdHJpbmcEAUoFAXoJAQt2YWx1ZU9yRWxzZQIJAJsIAgkBEUBleHRyTmF0aXZlKDEwNjIpAQUBSgkBAXACCQClCAEFBHRoaXMJANgEAQgFAmFFAmlkBwkA9AMDCAUCYUUJYm9keUJ5dGVzCQCRAwIIBQJhRQZwcm9vZnMAAAgFAmFFD3NlbmRlclB1YmxpY0tleR+hRiM=", "height": 2671378, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: none Next: none Full:
Old | New | Differences | |
---|---|---|---|
1 | - | # no script | |
1 | + | {-# STDLIB_VERSION 6 #-} | |
2 | + | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | + | {-# CONTENT_TYPE DAPP #-} | |
4 | + | let SEP = "__" | |
5 | + | ||
6 | + | let PRECISION = 1000000000000 | |
7 | + | ||
8 | + | let DEFAULT_MAX_SLIPPAGE = ((PRECISION / 20) * 19) | |
9 | + | ||
10 | + | func mulp (_x,_y) = fraction(_x, _y, PRECISION, HALFEVEN) | |
11 | + | ||
12 | + | ||
13 | + | func join (ar) = makeString(ar, SEP) | |
14 | + | ||
15 | + | ||
16 | + | func keyInitialized () = join(["%s", "initialized"]) | |
17 | + | ||
18 | + | ||
19 | + | func keyCoordinatorAddress () = join(["%s", "coordinatorAddress"]) | |
20 | + | ||
21 | + | ||
22 | + | func keyVerifierAddress () = join(["%s", "verifierAddress"]) | |
23 | + | ||
24 | + | ||
25 | + | func keyEastStakingAddress () = join(["%s", "eastStakingAddress"]) | |
26 | + | ||
27 | + | ||
28 | + | func keySubvaultAddress () = join(["%s", "subvaultAddress"]) | |
29 | + | ||
30 | + | ||
31 | + | func keyEastAsset () = join(["%s", "eastAsset"]) | |
32 | + | ||
33 | + | ||
34 | + | func keyMaxSlippage () = join(["%s", "maxSlippage"]) | |
35 | + | ||
36 | + | ||
37 | + | func keySigned (_address,_txId) = join(["%s%s%s", "signed", _address, _txId]) | |
38 | + | ||
39 | + | ||
40 | + | func isInitialized () = valueOrElse(getBoolean(this, keyInitialized()), false) | |
41 | + | ||
42 | + | ||
43 | + | func mustInitialized () = if (!(isInitialized())) | |
44 | + | then throw("Not initialized") | |
45 | + | else unit | |
46 | + | ||
47 | + | ||
48 | + | func mustNotInitialized () = if (isInitialized()) | |
49 | + | then throw("Already initialized") | |
50 | + | else unit | |
51 | + | ||
52 | + | ||
53 | + | func mustSelf (i) = if ((i.caller != this)) | |
54 | + | then throw("Only self invocation allowed.") | |
55 | + | else unit | |
56 | + | ||
57 | + | ||
58 | + | func coordinator () = addressFromStringValue(valueOrErrorMessage(getString(keyCoordinatorAddress()), "Coordinator is not set")) | |
59 | + | ||
60 | + | ||
61 | + | func verifier () = match getString(keyCoordinatorAddress()) { | |
62 | + | case s: String => | |
63 | + | getString(addressFromStringValue(s), keyVerifierAddress()) | |
64 | + | case _: Unit => | |
65 | + | unit | |
66 | + | case _ => | |
67 | + | throw("Match error") | |
68 | + | } | |
69 | + | ||
70 | + | ||
71 | + | func getAddress (key,err) = addressFromStringValue(valueOrErrorMessage(getString(coordinator(), key), err)) | |
72 | + | ||
73 | + | ||
74 | + | func getEastStakingAddress () = getAddress(keyEastStakingAddress(), "East staking is not set") | |
75 | + | ||
76 | + | ||
77 | + | func getMaxSlippage () = valueOrElse(getInteger(coordinator(), keyMaxSlippage()), DEFAULT_MAX_SLIPPAGE) | |
78 | + | ||
79 | + | ||
80 | + | func getEastAssetStr () = valueOrErrorMessage(getString(coordinator(), keyEastAsset()), "East asset is not set") | |
81 | + | ||
82 | + | ||
83 | + | func getEastAsset () = fromBase58String(getEastAssetStr()) | |
84 | + | ||
85 | + | ||
86 | + | func checkAddress (_address) = match addressFromString(_address) { | |
87 | + | case address: Address => | |
88 | + | true | |
89 | + | case _: Unit => | |
90 | + | throw("Invalid address") | |
91 | + | case _ => | |
92 | + | throw("Match error") | |
93 | + | } | |
94 | + | ||
95 | + | ||
96 | + | let IdxStakerAddress = 1 | |
97 | + | ||
98 | + | let IdxExchangeAddress = 2 | |
99 | + | ||
100 | + | func keyAssets () = join(["%s", "assets"]) | |
101 | + | ||
102 | + | ||
103 | + | func keyAsset (_assetStr) = join(["%s%s", "asset", _assetStr]) | |
104 | + | ||
105 | + | ||
106 | + | func keyTotalRewardCollected () = join(["%s", "totalRewardPayed"]) | |
107 | + | ||
108 | + | ||
109 | + | func dataAsset (_stakerAddress,_exchangeAddress) = makeString(["%s%s", _stakerAddress, _exchangeAddress], SEP) | |
110 | + | ||
111 | + | ||
112 | + | func getTotalRewardCollected () = valueOrElse(getInteger(keyTotalRewardCollected()), 0) | |
113 | + | ||
114 | + | ||
115 | + | func getAssets () = split(valueOrErrorMessage(getString(keyAssets()), "No assets configured."), SEP) | |
116 | + | ||
117 | + | ||
118 | + | func getAssetsValue () = match getString(keyAssets()) { | |
119 | + | case s: String => | |
120 | + | split(value(s), SEP) | |
121 | + | case _: Unit => | |
122 | + | nil | |
123 | + | case _ => | |
124 | + | throw("Match error") | |
125 | + | } | |
126 | + | ||
127 | + | ||
128 | + | func getAsset (_assetStr) = { | |
129 | + | let config = split(valueOrErrorMessage(getString(keyAsset(_assetStr)), "Asset config not found."), SEP) | |
130 | + | let staker = addressFromStringValue(config[IdxStakerAddress]) | |
131 | + | let exchange = addressFromStringValue(config[IdxExchangeAddress]) | |
132 | + | $Tuple2(staker, exchange) | |
133 | + | } | |
134 | + | ||
135 | + | ||
136 | + | @Callable(i) | |
137 | + | func initialize (_coordinatorAddress) = { | |
138 | + | let checks = [mustSelf(i), mustNotInitialized(), checkAddress(_coordinatorAddress)] | |
139 | + | if ((checks == checks)) | |
140 | + | then [StringEntry(keyCoordinatorAddress(), _coordinatorAddress), BooleanEntry(keyInitialized(), true)] | |
141 | + | else throw("Strict value is not equal to itself.") | |
142 | + | } | |
143 | + | ||
144 | + | ||
145 | + | ||
146 | + | @Callable(i) | |
147 | + | func addAsset (_assetStr,_stakerAddress,_exchangeAddress) = { | |
148 | + | let checks = [mustInitialized(), mustSelf(i), checkAddress(_stakerAddress), checkAddress(_exchangeAddress)] | |
149 | + | if ((checks == checks)) | |
150 | + | then { | |
151 | + | let assets = getAssetsValue() | |
152 | + | if (containsElement(assets, _assetStr)) | |
153 | + | then throw("Asset already exists.") | |
154 | + | else { | |
155 | + | let newAssets = makeString((assets :+ _assetStr), SEP) | |
156 | + | [StringEntry(keyAssets(), newAssets), StringEntry(keyAsset(_assetStr), dataAsset(_stakerAddress, _exchangeAddress))] | |
157 | + | } | |
158 | + | } | |
159 | + | else throw("Strict value is not equal to itself.") | |
160 | + | } | |
161 | + | ||
162 | + | ||
163 | + | ||
164 | + | @Callable(i) | |
165 | + | func removeAsset (_assetStr) = { | |
166 | + | let checks = [mustInitialized(), mustSelf(i)] | |
167 | + | if ((checks == checks)) | |
168 | + | then { | |
169 | + | let assets = getAssets() | |
170 | + | let newAssets = match indexOf(assets, _assetStr) { | |
171 | + | case idx: Int => | |
172 | + | makeString(removeByIndex(assets, idx), SEP) | |
173 | + | case _: Unit => | |
174 | + | throw("Unable to proceed. Asset not found.") | |
175 | + | case _ => | |
176 | + | throw("Match error") | |
177 | + | } | |
178 | + | [StringEntry(keyAssets(), newAssets), DeleteEntry(keyAsset(_assetStr))] | |
179 | + | } | |
180 | + | else throw("Strict value is not equal to itself.") | |
181 | + | } | |
182 | + | ||
183 | + | ||
184 | + | ||
185 | + | @Callable(i) | |
186 | + | func ackRewards () = { | |
187 | + | func claimAndExchange (acc,next) = match next { | |
188 | + | case assetStr: String => | |
189 | + | let $t01366413730 = getAsset(assetStr) | |
190 | + | let staker = $t01366413730._1 | |
191 | + | let exchange = $t01366413730._2 | |
192 | + | let profit = { | |
193 | + | let @ = invoke(staker, "claimProfit", nil, nil) | |
194 | + | if ($isInstanceOf(@, "Int")) | |
195 | + | then @ | |
196 | + | else throw(($getType(@) + " couldn't be cast to Int")) | |
197 | + | } | |
198 | + | if ((profit == profit)) | |
199 | + | then { | |
200 | + | let subvault = addressFromStringValue(valueOrErrorMessage(getString(staker, keySubvaultAddress()), "Subvault not found.")) | |
201 | + | let assetRate = { | |
202 | + | let @ = invoke(subvault, "getCurrentUsdPrice", nil, nil) | |
203 | + | if ($isInstanceOf(@, "Int")) | |
204 | + | then @ | |
205 | + | else throw(($getType(@) + " couldn't be cast to Int")) | |
206 | + | } | |
207 | + | if ((assetRate == assetRate)) | |
208 | + | then { | |
209 | + | let usdEq = mulp(profit, assetRate) | |
210 | + | let slippage = getMaxSlippage() | |
211 | + | let minEastAmount = mulp(usdEq, slippage) | |
212 | + | let asset = if ((assetStr == "WAVES")) | |
213 | + | then unit | |
214 | + | else fromBase58String(assetStr) | |
215 | + | let exchangedAmount = { | |
216 | + | let @ = invoke(exchange, "swap", [minEastAmount, getEastAssetStr(), toString(this)], [AttachedPayment(asset, profit)]) | |
217 | + | if ($isInstanceOf(@, "Int")) | |
218 | + | then @ | |
219 | + | else throw(($getType(@) + " couldn't be cast to Int")) | |
220 | + | } | |
221 | + | if ((exchangedAmount == exchangedAmount)) | |
222 | + | then (acc + exchangedAmount) | |
223 | + | else throw("Strict value is not equal to itself.") | |
224 | + | } | |
225 | + | else throw("Strict value is not equal to itself.") | |
226 | + | } | |
227 | + | else throw("Strict value is not equal to itself.") | |
228 | + | case _: Unit => | |
229 | + | acc | |
230 | + | case _ => | |
231 | + | throw("Match error") | |
232 | + | } | |
233 | + | ||
234 | + | let assets = getAssets() | |
235 | + | let rewardAmount = { | |
236 | + | let $l = assets | |
237 | + | let $s = size($l) | |
238 | + | let $acc0 = 0 | |
239 | + | func $f0_1 ($a,$i) = if (($i >= $s)) | |
240 | + | then $a | |
241 | + | else claimAndExchange($a, $l[$i]) | |
242 | + | ||
243 | + | func $f0_2 ($a,$i) = if (($i >= $s)) | |
244 | + | then $a | |
245 | + | else throw("List size exceeds 10") | |
246 | + | ||
247 | + | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10) | |
248 | + | } | |
249 | + | if ((rewardAmount == rewardAmount)) | |
250 | + | then { | |
251 | + | let newTotalRewardCollected = (getTotalRewardCollected() + rewardAmount) | |
252 | + | let eastPayment = AttachedPayment(getEastAsset(), rewardAmount) | |
253 | + | let doAddEastReward = invoke(getEastStakingAddress(), "addStakingRewards", nil, [eastPayment]) | |
254 | + | if ((doAddEastReward == doAddEastReward)) | |
255 | + | then [IntegerEntry(keyTotalRewardCollected(), newTotalRewardCollected)] | |
256 | + | else throw("Strict value is not equal to itself.") | |
257 | + | } | |
258 | + | else throw("Strict value is not equal to itself.") | |
259 | + | } | |
260 | + | ||
261 | + | ||
262 | + | @Verifier(tx) | |
263 | + | func verify () = match verifier() { | |
264 | + | case address: String => | |
265 | + | valueOrElse(getBoolean(addressFromStringValue(address), keySigned(toString(this), toBase58String(tx.id))), false) | |
266 | + | case _ => | |
267 | + | sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
268 | + | } | |
269 | + |
github/deemru/w8io/169f3d6 29.76 ms ◑