tx · 5WAd5iLZ9EVt2AjjapnsEVyA8G9vgfFQUfAXJNYCijME 3N11gzZic4yASFhatzjC8zvLnpNhDo2B1Rv: -0.01000000 Waves 2023.10.06 13:39 [2786649] smart account 3N11gzZic4yASFhatzjC8zvLnpNhDo2B1Rv > SELF 0.00000000 Waves
{ "type": 13, "id": "5WAd5iLZ9EVt2AjjapnsEVyA8G9vgfFQUfAXJNYCijME", "fee": 1000000, "feeAssetId": null, "timestamp": 1696588766396, "version": 2, "chainId": 84, "sender": "3N11gzZic4yASFhatzjC8zvLnpNhDo2B1Rv", "senderPublicKey": "EnUXxxhBK8wUfh1FveDYv9G5HBMXop6YwZWzVrBrLo2i", "proofs": [ "4LqXpj4Yo5pQxzNUv64iUVKjV3KHTUdXRtPT6ThZoJEKfB13e7842rhzAorxYe3TFKQwQrZik5oZ7hDaph6gSN5v" ], "script": "base64:BgIfCAISABIICgYBAQgIGBgSBAoCCAgSBAoCCAESAwoBCAoADGFkbWluQWRkcmVzcwkBC3ZhbHVlT3JFbHNlAgkAnQgCBQR0aGlzAgVhZG1pbgIAAA13eFN3YXBBZGRyZXNzAiMzUDY4ek5pdWZzdTF2aVpwdTFhWTNjZGFoUlJLY3ZWNU45MwELd3JpdGVTdHJpbmcCA2tleQtzdHJpbmdWYWx1ZQkBC1N0cmluZ0VudHJ5AgUDa2V5BQtzdHJpbmdWYWx1ZQEMd3JpdGVJbnRlZ2VyAgNrZXkMaW50ZWdlclZhbHVlCQEMSW50ZWdlckVudHJ5AgUDa2V5BQxpbnRlZ2VyVmFsdWUBB2lzQWRtaW4BDWNhbGxlckFkZHJlc3MDCQAAAgUNY2FsbGVyQWRkcmVzcwkA2QQBBQxhZG1pbkFkZHJlc3MGBwENc3BsaXRDZm1tSnNvbgEFZW50cnkJALUJAgUFZW50cnkCAS8BEWRldGVybWluZVBsYXRmb3JtAwRjZm1tCXRva2VuSWRJbgp0b2tlbklkT3V0BARpdGVtCQENc3BsaXRDZm1tSnNvbgEFBGNmbW0EC2lucHV0QW1vdW50CQC2CQEJAJEDAgUEaXRlbQACBAckbWF0Y2gwBQtpbnB1dEFtb3VudAMJAAECBQckbWF0Y2gwAgNJbnQEC2lucHV0QW1vdW50BQckbWF0Y2gwAwkAAAIJAJEDAgUEaXRlbQAAAgRTV09QCQD8BwQJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAJEDAgUEaXRlbQABAghleGNoYW5nZQkAzAgCAAEFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkA2QQBBQl0b2tlbklkSW4FC2lucHV0QW1vdW50BQNuaWwDCQAAAgkAkQMCBQRpdGVtAAACDldhdmVzIEV4Y2hhbmdlCQD8BwQJARFAZXh0ck5hdGl2ZSgxMDYyKQEFDXd4U3dhcEFkZHJlc3MCBHN3YXAJAMwIAgABCQDMCAIFCnRva2VuSWRPdXQJAMwIAgUMYWRtaW5BZGRyZXNzBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJANkEAQUJdG9rZW5JZEluBQtpbnB1dEFtb3VudAUDbmlsAwkAAAIJAJEDAgUEaXRlbQAAAgtQdXp6bGUgU3dhcAkA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ARRkaXN0cmlidXRlRGlmZmVyZW5jZQIFBXN3YXBzBQRkaWZmAl8xBQVzd2FwcwUNYWRqdXN0ZWRTd2FwcwUBaQEFc2V0dXAAAwkBASEBCQEJaXNEZWZpbmVkAQkAnQgCBQR0aGlzAgVhZG1pbgkAzAgCCQELd3JpdGVTdHJpbmcCAgVhZG1pbgkA2AQBCAgFAWkGY2FsbGVyBWJ5dGVzBQNuaWwJAAIBAhNEYXBwIGFscmVhZHkgc2V0dXAhAWkBCGJhc2ljQXJiBgtzdGFydEFtb3VudA5zZWNvbmRBbW91bnRJbgpmaXJzdFRva2VuC3NlY29uZFRva2VuCWZpcnN0U3dhcApzZWNvbmRTd2FwAwkBB2lzQWRtaW4BCAgFAWkGY2FsbGVyBWJ5dGVzBAxmaXJzdFRva2VuSWQEA3RJZAkA2QQBBQpmaXJzdFRva2VuBAckbWF0Y2gwBQN0SWQDCQABAgUHJG1hdGNoMAIKQnl0ZVZlY3RvcgQDdElkBQckbWF0Y2gwBQN0SWQJAAIBAhBJbnZhbGlkIGRhdGF0eXBlBBlhdmFpbGFibGVBbW91bnRGaXJzdFRva2VuCQDwBwIFBHRoaXMFDGZpcnN0VG9rZW5JZAMJAGcCBRlhdmFpbGFibGVBbW91bnRGaXJzdFRva2VuBQtzdGFydEFtb3VudAQGcmVzdWx0CQEMcHJvY2Vzc0NmbW1zAwUJZmlyc3RTd2FwBQpmaXJzdFRva2VuBQtzZWNvbmRUb2tlbgQNc2Vjb25kVG9rZW5JZAQCaWQJANkEAQULc2Vjb25kVG9rZW4EByRtYXRjaDAFAmlkAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEAmlkBQckbWF0Y2gwBQJpZAkAAgECEEludmFsaWQgZGF0YXR5cGUEGmF2YWlsYWJsZUFtb3VudFNlY29uZFRva2VuCQDwBwIFBHRoaXMFDXNlY29uZFRva2VuSWQEC3NlY29uZFN3YXBzAwkAAAIFGmF2YWlsYWJsZUFtb3VudFNlY29uZFRva2VuBQ5zZWNvbmRBbW91bnRJbgUKc2Vjb25kU3dhcAkBF2hhbmRsZVNlY29uZElucHV0QW1vdW50AwUOc2Vjb25kQW1vdW50SW4FGmF2YWlsYWJsZUFtb3VudFNlY29uZFRva2VuBQpzZWNvbmRTd2FwBAlyZXN1bHRUd28JAQxwcm9jZXNzQ2ZtbXMDBQtzZWNvbmRTd2FwcwULc2Vjb25kVG9rZW4FCmZpcnN0VG9rZW4EGGN1cnJlbnRTdGFydFRva2VuQmFsYW5jZQkA8AcCBQR0aGlzBQxmaXJzdFRva2VuSWQDCQBmAgUYY3VycmVudFN0YXJ0VG9rZW5CYWxhbmNlBQtzdGFydEFtb3VudAUDbmlsCQACAQIZVHJhZGUgd2FzIG5vdCBwcm9maXRhYmxlIQkAAgECKUF2YWlsYWJsZSBpbnB1dCBhbW91bnQgaXMgbm90IHN1ZmZpY2llbnQhCQACAQIqQWRkcmVzcyBkb2VzIG5vdCBtYXRjaCB3aXRoIGFkbWluIGFkZHJlc3MhAWkBEXVwZGF0ZVN0cmluZ0VudHJ5AgNrZXkLc3RyaW5nVmFsdWUDCQEHaXNBZG1pbgEICAUBaQZjYWxsZXIFYnl0ZXMJAMwIAgkBC3dyaXRlU3RyaW5nAgUDa2V5BQtzdHJpbmdWYWx1ZQUDbmlsCQACAQIqQWRkcmVzcyBkb2VzIG5vdCBtYXRjaCB3aXRoIGFkbWluIGFkZHJlc3MhAWkBEnVwZGF0ZUludGVnZXJFbnRyeQIDa2V5DGludGVnZXJWYWx1ZQMJAQdpc0FkbWluAQgIBQFpBmNhbGxlcgVieXRlcwkAzAgCCQEMd3JpdGVJbnRlZ2VyAgUDa2V5BQxpbnRlZ2VyVmFsdWUFA25pbAkAAgECKkFkZHJlc3MgZG9lcyBub3QgbWF0Y2ggd2l0aCBhZG1pbiBhZGRyZXNzIQFpARJkZWxldGVTdG9yYWdlRW50cnkBA2tleQMJAQdpc0FkbWluAQgIBQFpBmNhbGxlcgVieXRlcwkAzAgCCQELRGVsZXRlRW50cnkBBQNrZXkFA25pbAkAAgECKkFkZHJlc3MgZG9lcyBub3QgbWF0Y2ggd2l0aCBhZG1pbiBhZGRyZXNzIQECdHgBBnZlcmlmeQAJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAIBQJ0eA9zZW5kZXJQdWJsaWNLZXmonmw5", "height": 2786649, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: J2DMxezfqgViwjspp1h55dBuFpyFabwac4nMEjM7wxNR Next: 3KojrtqfHoJe5euPC8h4gvhNLqnDSfti6yXYZXrxvWeJ Diff:
Old | New | Differences | |
---|---|---|---|
118 | 118 | ||
119 | 119 | ||
120 | 120 | @Callable(i) | |
121 | - | func setup ( | |
122 | - | then [writeString("admin", | |
121 | + | func setup () = if (!(isDefined(getString(this, "admin")))) | |
122 | + | then [writeString("admin", toBase58String(i.caller.bytes))] | |
123 | 123 | else throw("Dapp already setup!") | |
124 | 124 | ||
125 | 125 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let adminAddress = valueOrElse(getString(this, "admin"), "") | |
5 | 5 | ||
6 | 6 | let wxSwapAddress = "3P68zNiufsu1viZpu1aY3cdahRRKcvV5N93" | |
7 | 7 | ||
8 | 8 | func writeString (key,stringValue) = StringEntry(key, stringValue) | |
9 | 9 | ||
10 | 10 | ||
11 | 11 | func writeInteger (key,integerValue) = IntegerEntry(key, integerValue) | |
12 | 12 | ||
13 | 13 | ||
14 | 14 | func isAdmin (callerAddress) = if ((callerAddress == fromBase58String(adminAddress))) | |
15 | 15 | then true | |
16 | 16 | else false | |
17 | 17 | ||
18 | 18 | ||
19 | 19 | func splitCfmmJson (entry) = split(entry, "/") | |
20 | 20 | ||
21 | 21 | ||
22 | 22 | func determinePlatform (cfmm,tokenIdIn,tokenIdOut) = { | |
23 | 23 | let item = splitCfmmJson(cfmm) | |
24 | 24 | let inputAmount = parseInt(item[2]) | |
25 | 25 | match inputAmount { | |
26 | 26 | case inputAmount: Int => | |
27 | 27 | if ((item[0] == "SWOP")) | |
28 | 28 | then invoke(addressFromStringValue(item[1]), "exchange", [1], [AttachedPayment(fromBase58String(tokenIdIn), inputAmount)]) | |
29 | 29 | else if ((item[0] == "Waves Exchange")) | |
30 | 30 | then invoke(addressFromStringValue(wxSwapAddress), "swap", [1, tokenIdOut, adminAddress], [AttachedPayment(fromBase58String(tokenIdIn), inputAmount)]) | |
31 | 31 | else if ((item[0] == "Puzzle Swap")) | |
32 | 32 | then invoke(addressFromStringValue(item[1]), "swap", [tokenIdOut, 1], [AttachedPayment(fromBase58String(tokenIdIn), inputAmount)]) | |
33 | 33 | else throw("Platform id does not match!") | |
34 | 34 | case _ => | |
35 | 35 | throw("value is not an int!") | |
36 | 36 | } | |
37 | 37 | } | |
38 | 38 | ||
39 | 39 | ||
40 | 40 | func processCfmms (swaps,tokenIdIn,tokenIdOut) = { | |
41 | 41 | func invokeSwap (accum,next) = { | |
42 | 42 | let $t022642291 = accum | |
43 | 43 | let result = $t022642291._1 | |
44 | 44 | let index = $t022642291._2 | |
45 | 45 | if ((size(swaps) > index)) | |
46 | 46 | then $Tuple2(determinePlatform(next, tokenIdIn, tokenIdOut), (index + 1)) | |
47 | 47 | else $Tuple2(result, index) | |
48 | 48 | } | |
49 | 49 | ||
50 | 50 | let $l = swaps | |
51 | 51 | let $s = size($l) | |
52 | 52 | let $acc0 = $Tuple2(nil, 0) | |
53 | 53 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
54 | 54 | then $a | |
55 | 55 | else invokeSwap($a, $l[$i]) | |
56 | 56 | ||
57 | 57 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
58 | 58 | then $a | |
59 | 59 | else throw("List size exceeds 40") | |
60 | 60 | ||
61 | 61 | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($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), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20), 21), 22), 23), 24), 25), 26), 27), 28), 29), 30), 31), 32), 33), 34), 35), 36), 37), 38), 39), 40) | |
62 | 62 | } | |
63 | 63 | ||
64 | 64 | ||
65 | 65 | func distributeDifference (swaps,diff) = { | |
66 | 66 | let totalSwaps = size(swaps) | |
67 | 67 | func adjustAmounts (accum,next) = { | |
68 | 68 | let $t026322674 = accum | |
69 | 69 | let adjustedSwaps = $t026322674._1 | |
70 | 70 | let remainingDiff = $t026322674._2 | |
71 | 71 | let item = splitCfmmJson(next) | |
72 | 72 | let inputAmount = parseInt(item[2]) | |
73 | 73 | match inputAmount { | |
74 | 74 | case input: Int => | |
75 | 75 | let amountToAdjust = { | |
76 | 76 | let remainDiff = (remainingDiff / ((totalSwaps - size(adjustedSwaps)) + 1)) | |
77 | 77 | match remainDiff { | |
78 | 78 | case x: Int => | |
79 | 79 | if ((remainingDiff > 0)) | |
80 | 80 | then min([input, x]) | |
81 | 81 | else if ((0 > remainingDiff)) | |
82 | 82 | then max([(-(input) + 1), x]) | |
83 | 83 | else 0 | |
84 | 84 | case _ => | |
85 | 85 | throw("Wrong datatype") | |
86 | 86 | } | |
87 | 87 | } | |
88 | 88 | let newInputAmount = max([1, (input + amountToAdjust)]) | |
89 | 89 | let newItem = ((((item[0] + "/") + item[1]) + "/") + toString(newInputAmount)) | |
90 | 90 | $Tuple2((adjustedSwaps :+ newItem), (remainingDiff - (amountToAdjust * ((totalSwaps - size(adjustedSwaps)) + 1)))) | |
91 | 91 | case _ => | |
92 | 92 | throw("Input has wrong datatype!") | |
93 | 93 | } | |
94 | 94 | } | |
95 | 95 | ||
96 | 96 | let $l = swaps | |
97 | 97 | let $s = size($l) | |
98 | 98 | let $acc0 = $Tuple2(nil, diff) | |
99 | 99 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
100 | 100 | then $a | |
101 | 101 | else adjustAmounts($a, $l[$i]) | |
102 | 102 | ||
103 | 103 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
104 | 104 | then $a | |
105 | 105 | else throw("List size exceeds 40") | |
106 | 106 | ||
107 | 107 | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($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), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20), 21), 22), 23), 24), 25), 26), 27), 28), 29), 30), 31), 32), 33), 34), 35), 36), 37), 38), 39), 40) | |
108 | 108 | } | |
109 | 109 | ||
110 | 110 | ||
111 | 111 | func handleSecondInputAmount (predeterminedAmount,availableAmount,swaps) = { | |
112 | 112 | let diff = (availableAmount - predeterminedAmount) | |
113 | 113 | let adjustedSwaps = if ((diff != 0)) | |
114 | 114 | then distributeDifference(swaps, diff)._1 | |
115 | 115 | else swaps | |
116 | 116 | adjustedSwaps | |
117 | 117 | } | |
118 | 118 | ||
119 | 119 | ||
120 | 120 | @Callable(i) | |
121 | - | func setup ( | |
122 | - | then [writeString("admin", | |
121 | + | func setup () = if (!(isDefined(getString(this, "admin")))) | |
122 | + | then [writeString("admin", toBase58String(i.caller.bytes))] | |
123 | 123 | else throw("Dapp already setup!") | |
124 | 124 | ||
125 | 125 | ||
126 | 126 | ||
127 | 127 | @Callable(i) | |
128 | 128 | func basicArb (startAmount,secondAmountIn,firstToken,secondToken,firstSwap,secondSwap) = if (isAdmin(i.caller.bytes)) | |
129 | 129 | then { | |
130 | 130 | let firstTokenId = { | |
131 | 131 | let tId = fromBase58String(firstToken) | |
132 | 132 | match tId { | |
133 | 133 | case tId: ByteVector => | |
134 | 134 | tId | |
135 | 135 | case _ => | |
136 | 136 | throw("Invalid datatype") | |
137 | 137 | } | |
138 | 138 | } | |
139 | 139 | let availableAmountFirstToken = assetBalance(this, firstTokenId) | |
140 | 140 | if ((availableAmountFirstToken >= startAmount)) | |
141 | 141 | then { | |
142 | 142 | let result = processCfmms(firstSwap, firstToken, secondToken) | |
143 | 143 | let secondTokenId = { | |
144 | 144 | let id = fromBase58String(secondToken) | |
145 | 145 | match id { | |
146 | 146 | case id: ByteVector => | |
147 | 147 | id | |
148 | 148 | case _ => | |
149 | 149 | throw("Invalid datatype") | |
150 | 150 | } | |
151 | 151 | } | |
152 | 152 | let availableAmountSecondToken = assetBalance(this, secondTokenId) | |
153 | 153 | let secondSwaps = if ((availableAmountSecondToken == secondAmountIn)) | |
154 | 154 | then secondSwap | |
155 | 155 | else handleSecondInputAmount(secondAmountIn, availableAmountSecondToken, secondSwap) | |
156 | 156 | let resultTwo = processCfmms(secondSwaps, secondToken, firstToken) | |
157 | 157 | let currentStartTokenBalance = assetBalance(this, firstTokenId) | |
158 | 158 | if ((currentStartTokenBalance > startAmount)) | |
159 | 159 | then nil | |
160 | 160 | else throw("Trade was not profitable!") | |
161 | 161 | } | |
162 | 162 | else throw("Available input amount is not sufficient!") | |
163 | 163 | } | |
164 | 164 | else throw("Address does not match with admin address!") | |
165 | 165 | ||
166 | 166 | ||
167 | 167 | ||
168 | 168 | @Callable(i) | |
169 | 169 | func updateStringEntry (key,stringValue) = if (isAdmin(i.caller.bytes)) | |
170 | 170 | then [writeString(key, stringValue)] | |
171 | 171 | else throw("Address does not match with admin address!") | |
172 | 172 | ||
173 | 173 | ||
174 | 174 | ||
175 | 175 | @Callable(i) | |
176 | 176 | func updateIntegerEntry (key,integerValue) = if (isAdmin(i.caller.bytes)) | |
177 | 177 | then [writeInteger(key, integerValue)] | |
178 | 178 | else throw("Address does not match with admin address!") | |
179 | 179 | ||
180 | 180 | ||
181 | 181 | ||
182 | 182 | @Callable(i) | |
183 | 183 | func deleteStorageEntry (key) = if (isAdmin(i.caller.bytes)) | |
184 | 184 | then [DeleteEntry(key)] | |
185 | 185 | else throw("Address does not match with admin address!") | |
186 | 186 | ||
187 | 187 | ||
188 | 188 | @Verifier(tx) | |
189 | 189 | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
190 | 190 |
github/deemru/w8io/873ac7e 32.40 ms ◑![]()