tx · FXCgC2wyMFUB4MWKkTKoAjQZWuWcmQrwXhXjgiEn1QqX 3PMqKakbsELgTxiAHNzm4ryEJBLKJcLetyj: -0.01000000 Waves 2023.10.09 01:09 [3856086] smart account 3PMqKakbsELgTxiAHNzm4ryEJBLKJcLetyj > SELF 0.00000000 Waves
{ "type": 13, "id": "FXCgC2wyMFUB4MWKkTKoAjQZWuWcmQrwXhXjgiEn1QqX", "fee": 1000000, "feeAssetId": null, "timestamp": 1696803003825, "version": 2, "chainId": 87, "sender": "3PMqKakbsELgTxiAHNzm4ryEJBLKJcLetyj", "senderPublicKey": "y6K4a5SRZdvLzRWHrhjBuh5BQqujMD5sLnAocMyZ3P3", "proofs": [ "2dSSxYUFsyMgiEExJoPMW2mRcgR2rqEEtaqDCsQiesJzV3mmPWHUAruhQpfj4bAMBoFjUugYj9Vps14TB1e1gRNf" ], "script": "base64:BgKaCggCEgASCAoGAQEICBgYEgQKAggIEgQKAggBEgMKAQgiDGFkbWluQWRkcmVzcyINd3hTd2FwQWRkcmVzcyILd3JpdGVTdHJpbmciA2tleSILc3RyaW5nVmFsdWUiDHdyaXRlSW50ZWdlciIMaW50ZWdlclZhbHVlIgdpc0FkbWluIg1jYWxsZXJBZGRyZXNzIg1zcGxpdENmbW1Kc29uIgVlbnRyeSIKaW52b2tlU3dvcCILcG9vbEFkZHJlc3MiB3Rva2VuSWQiC2lucHV0QW1vdW50IgZyZXN1bHQiByRtYXRjaDAiByRtYXRjaDEiAWEiCGludm9rZVd4Igl0b2tlbklkSW4iCnRva2VuSWRPdXQiDGludm9rZVB1enpsZSIRZGV0ZXJtaW5lUGxhdGZvcm0iBGNmbW0iBGl0ZW0iBWlucHV0Igxwcm9jZXNzQ2ZtbXMiBXN3YXBzIgppbnZva2VTd2FwIgVhY2N1bSIEbmV4dCILJHQwNjQ4MzY1MTAiBWluZGV4IgtyZXN1bHRUdXBsZSICJGwiAiRzIgUkYWNjMCIFJGYwXzEiAiRhIgIkaSIFJGYwXzIiH2NhbGNFeGNlc3NBbW91bnRQZXJDZm1tUG9zaXRpdmUiCmRpZmZlcmVuY2UiC251bWJlckNmbW1zIghxdW90aWVudCIWdG90YWxEaXN0cmlidXRlZEFtb3VudCIPcmVtYWluaW5nQW1vdW50Ih9jYWxjRXhjZXNzQW1vdW50UGVyQ2ZtbU5lZ2F0aXZlIhpkaXN0cmlidXRlQWRkaXRpb25hbFRva2VucyIEZGlmZiIKdG90YWxTd2FwcyILJHQwNzUyMTc2MDQiDWFkanVzdEFtb3VudHMiCyR0MDc2Nzc3NzE5Ig1hZGp1c3RlZFN3YXBzIg1yZW1haW5pbmdEaWZmIg5hbW91bnRUb0FkanVzdCIHbmV3SXRlbSIQbmV3UmVtYWluaW5nRGlmZiIYZGlzdHJpYnV0ZVJlbWFpbmluZ0RpZmZzIhZkaXN0cmlidXRlUHJvcG9ydGlvbmFsIgskdDA4NTk1ODYzNCIKcmVtYWluRGlmZiIQaW5wdXRBbW91bnRDaGVjayIPbWF4U3VidHJhY3RhYmxlIgskdDA5MDMyOTY0NiIVcmVtYWluaW5nU3VidHJhY3RhYmxlIhJzdWJ0cmFjdGFibGVBbW91bnQiGGRpc3RyaWJ1dGVOZWdhdGl2ZVRva2VucyINJHQwMTAwMTExMDA5NCINJHQwMTAxNjcxMDIwOSINJHQwMTAzNDYxMDY5NiINJHQwMTA4OTUxMDk4NiIOcmVtYWluaW5nRGlmZnMiDSR0MDEwOTkwMTEwNzAiCmZpbmFsU3dhcHMiBWRpZmZzIhdoYW5kbGVTZWNvbmRJbnB1dEFtb3VudCITcHJlZGV0ZXJtaW5lZEFtb3VudCIPYXZhaWxhYmxlQW1vdW50IgFpIgtzdGFydEFtb3VudCIOc2Vjb25kQW1vdW50SW4iCmZpcnN0VG9rZW4iC3NlY29uZFRva2VuIglmaXJzdFN3YXAiCnNlY29uZFN3YXAiDGZpcnN0VG9rZW5JZCIDdElkIg1zZWNvbmRUb2tlbklkIgJpZCIZYXZhaWxhYmxlQW1vdW50Rmlyc3RUb2tlbiILZmlyc3RSZXN1bHQiC3NlY29uZFN3YXBzIgxzZWNvbmRSZXN1bHQiAnR4IgZ2ZXJpZnkRAAFhCQELdmFsdWVPckVsc2UCCQCdCAIFBHRoaXMCBWFkbWluAgAAAWICIzNQNjh6Tml1ZnN1MXZpWnB1MWFZM2NkYWhSUktjdlY1TjkzAQFjAgFkAWUJAQtTdHJpbmdFbnRyeQIFAWQFAWUBAWYCAWQBZwkBDEludGVnZXJFbnRyeQIFAWQFAWcBAWgBAWkDCQAAAgUBaQkA2QQBBQFhBgcBAWoBAWsJALUJAgUBawIBLwEBbAMBbQFuAW8EAXAJAPwHBAkBEUBleHRyTmF0aXZlKDEwNjIpAQUBbQIIZXhjaGFuZ2UJAMwIAgABBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJANkEAQUBbgUBbwUDbmlsAwkAAAIFAXAFAXAEAXEFAXADCQABAgUBcQIJTGlzdFtBbnldBAFwBQFxBAFyCQCRAwIFAXAAAAMJAAECBQFyAgNJbnQEAXMFAXIFAXMJAAIBAhhMaXN0IGl0ZW0gaXMgbm90IGFuIGludCEJAAIBAilSZXN1bHQgb2Ygc3dvcCBpbnZva2F0aW9uIGRvZXMgbm90IG1hdGNoIQkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgEBdAMBdQF2AW8EAXAJAPwHBAkBEUBleHRyTmF0aXZlKDEwNjIpAQUBYgIEc3dhcAkAzAgCAAEJAMwIAgUBdgkAzAgCBQFhBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJANkEAQUBdQUBbwUDbmlsAwkAAAIFAXAFAXAEAXEFAXADCQABAgUBcQIDSW50BAFwBQFxBQFwCQACAQIpUmVzdWx0IG9mIHN3b3AgaW52b2thdGlvbiBkb2VzIG5vdCBtYXRjaCEJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BAXcEAW0BdQF2AW8EAXAJAPwHBAkBEUBleHRyTmF0aXZlKDEwNjIpAQUBbQIEc3dhcAkAzAgCBQF2CQDMCAIAAQUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQDZBAEFAXUFAW8FA25pbAMJAAACBQFwBQFwBAFxBQFwAwkAAQIFAXECA0ludAQBcAUBcQUBcAkAAgECKVJlc3VsdCBvZiBzd29wIGludm9rYXRpb24gZG9lcyBub3QgbWF0Y2ghCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQF4AwF5AXUBdgQBegkBAWoBBQF5BAFvCQC2CQEJAJEDAgUBegACBAFBBAFxBQFvAwkAAQIFAXECA0ludAQBbwUBcQUBbwkAAgECKERhdGF0eXBlIG9mIGlucHV0IGFtb3VudCBkb2VzIG5vdCBtYXRjaCEEAXADCQAAAgkAkQMCBQF6AAACBFNXT1AJAQFsAwkAkQMCBQF6AAEFAXUFAUEDCQAAAgkAkQMCBQF6AAACDldhdmVzIEV4Y2hhbmdlCQEBdAMFAXUFAXYFAUEDCQAAAgkAkQMCBQF6AAACC1B1enpsZSBTd2FwCQEBdwQJAJEDAgUBegABBQF1BQF2BQFBCQACAQIbUGxhdGZvcm0gaWQgZG9lcyBub3QgbWF0Y2ghBQFwAQFCAwFDAXUBdgoBAUQCAUUBRgQBRwUBRQQBcAgFAUcCXzEEAUgIBQFHAl8yAwkAZgIJAJADAQUBQwUBSAkAlAoCCQBkAgUBcAkBAXgDBQFGBQF1BQF2CQBkAgUBSAABCQCUCgIFAXAFAUgEAUkKAAFKBQFDCgABSwkAkAMBBQFKCgABTAkA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BQJhSgQCYVIJAQFCAwUCYVEFAmFIBQJhRwkAzAgCCQEBZgICEVJlc3VsdCBmaXJzdCBzd2FwBQJhUAkAzAgCCQEBZgICElJlc3VsdCBzZWNvbmQgc3dhcAUCYVIFA25pbAkAAgECKUF2YWlsYWJsZSBpbnB1dCBhbW91bnQgaXMgbm90IHN1ZmZpY2llbnQhCQACAQIqQWRkcmVzcyBkb2VzIG5vdCBtYXRjaCB3aXRoIGFkbWluIGFkZHJlc3MhAmFEARF1cGRhdGVTdHJpbmdFbnRyeQIBZAFlAwkBAWgBCAgFAmFEBmNhbGxlcgVieXRlcwkAzAgCCQEBYwIFAWQFAWUFA25pbAkAAgECKkFkZHJlc3MgZG9lcyBub3QgbWF0Y2ggd2l0aCBhZG1pbiBhZGRyZXNzIQJhRAESdXBkYXRlSW50ZWdlckVudHJ5AgFkAWcDCQEBaAEICAUCYUQGY2FsbGVyBWJ5dGVzCQDMCAIJAQFmAgUBZAUBZwUDbmlsCQACAQIqQWRkcmVzcyBkb2VzIG5vdCBtYXRjaCB3aXRoIGFkbWluIGFkZHJlc3MhAmFEARJkZWxldGVTdG9yYWdlRW50cnkBAWQDCQEBaAEICAUCYUQGY2FsbGVyBWJ5dGVzCQDMCAIJAQtEZWxldGVFbnRyeQEFAWQFA25pbAkAAgECKkFkZHJlc3MgZG9lcyBub3QgbWF0Y2ggd2l0aCBhZG1pbiBhZGRyZXNzIQECYVMBAmFUAAkA9AMDCAUCYVMJYm9keUJ5dGVzCQCRAwIIBQJhUwZwcm9vZnMAAAgFAmFTD3NlbmRlclB1YmxpY0tleXURceo=", "height": 3856086, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 8LtGZRGstycNm7p1XJGbnKnfqoH1b4mQq319CjA9F5HM Next: 2Pi13NX165pAdKey6HMfdF8Q7tuRn1D35NENmRqrxEVN Diff:
Old | New | Differences | |
---|---|---|---|
320 | 320 | if ((availableAmountFirstToken >= startAmount)) | |
321 | 321 | then { | |
322 | 322 | let firstResult = processCfmms(firstSwap, firstToken, secondToken) | |
323 | - | [writeInteger("Result first swap", firstResult)] | |
323 | + | let secondSwaps = if ((firstResult == secondAmountIn)) | |
324 | + | then secondSwap | |
325 | + | else handleSecondInputAmount(secondAmountIn, firstResult, secondSwap) | |
326 | + | let secondResult = processCfmms(secondSwaps, secondToken, firstToken) | |
327 | + | [writeInteger("Result first swap", firstResult), writeInteger("Result second swap", secondResult)] | |
324 | 328 | } | |
325 | 329 | else throw("Available input amount is not sufficient!") | |
326 | 330 | } |
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 invokeSwop (poolAddress,tokenId,inputAmount) = { | |
23 | 23 | let result = invoke(addressFromStringValue(poolAddress), "exchange", [1], [AttachedPayment(fromBase58String(tokenId), inputAmount)]) | |
24 | 24 | if ((result == result)) | |
25 | 25 | then match result { | |
26 | 26 | case result: List[Any] => | |
27 | 27 | match result[0] { | |
28 | 28 | case a: Int => | |
29 | 29 | a | |
30 | 30 | case _ => | |
31 | 31 | throw("List item is not an int!") | |
32 | 32 | } | |
33 | 33 | case _ => | |
34 | 34 | throw("Result of swop invokation does not match!") | |
35 | 35 | } | |
36 | 36 | else throw("Strict value is not equal to itself.") | |
37 | 37 | } | |
38 | 38 | ||
39 | 39 | ||
40 | 40 | func invokeWx (tokenIdIn,tokenIdOut,inputAmount) = { | |
41 | 41 | let result = invoke(addressFromStringValue(wxSwapAddress), "swap", [1, tokenIdOut, adminAddress], [AttachedPayment(fromBase58String(tokenIdIn), inputAmount)]) | |
42 | 42 | if ((result == result)) | |
43 | 43 | then match result { | |
44 | 44 | case result: Int => | |
45 | 45 | result | |
46 | 46 | case _ => | |
47 | 47 | throw("Result of swop invokation does not match!") | |
48 | 48 | } | |
49 | 49 | else throw("Strict value is not equal to itself.") | |
50 | 50 | } | |
51 | 51 | ||
52 | 52 | ||
53 | 53 | func invokePuzzle (poolAddress,tokenIdIn,tokenIdOut,inputAmount) = { | |
54 | 54 | let result = invoke(addressFromStringValue(poolAddress), "swap", [tokenIdOut, 1], [AttachedPayment(fromBase58String(tokenIdIn), inputAmount)]) | |
55 | 55 | if ((result == result)) | |
56 | 56 | then match result { | |
57 | 57 | case result: Int => | |
58 | 58 | result | |
59 | 59 | case _ => | |
60 | 60 | throw("Result of swop invokation does not match!") | |
61 | 61 | } | |
62 | 62 | else throw("Strict value is not equal to itself.") | |
63 | 63 | } | |
64 | 64 | ||
65 | 65 | ||
66 | 66 | func determinePlatform (cfmm,tokenIdIn,tokenIdOut) = { | |
67 | 67 | let item = splitCfmmJson(cfmm) | |
68 | 68 | let inputAmount = parseInt(item[2]) | |
69 | 69 | let input = match inputAmount { | |
70 | 70 | case inputAmount: Int => | |
71 | 71 | inputAmount | |
72 | 72 | case _ => | |
73 | 73 | throw("Datatype of input amount does not match!") | |
74 | 74 | } | |
75 | 75 | let result = if ((item[0] == "SWOP")) | |
76 | 76 | then invokeSwop(item[1], tokenIdIn, input) | |
77 | 77 | else if ((item[0] == "Waves Exchange")) | |
78 | 78 | then invokeWx(tokenIdIn, tokenIdOut, input) | |
79 | 79 | else if ((item[0] == "Puzzle Swap")) | |
80 | 80 | then invokePuzzle(item[1], tokenIdIn, tokenIdOut, input) | |
81 | 81 | else throw("Platform id does not match!") | |
82 | 82 | result | |
83 | 83 | } | |
84 | 84 | ||
85 | 85 | ||
86 | 86 | func processCfmms (swaps,tokenIdIn,tokenIdOut) = { | |
87 | 87 | func invokeSwap (accum,next) = { | |
88 | 88 | let $t064836510 = accum | |
89 | 89 | let result = $t064836510._1 | |
90 | 90 | let index = $t064836510._2 | |
91 | 91 | if ((size(swaps) > index)) | |
92 | 92 | then $Tuple2((result + determinePlatform(next, tokenIdIn, tokenIdOut)), (index + 1)) | |
93 | 93 | else $Tuple2(result, index) | |
94 | 94 | } | |
95 | 95 | ||
96 | 96 | let resultTuple = { | |
97 | 97 | let $l = swaps | |
98 | 98 | let $s = size($l) | |
99 | 99 | let $acc0 = $Tuple2(0, 0) | |
100 | 100 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
101 | 101 | then $a | |
102 | 102 | else invokeSwap($a, $l[$i]) | |
103 | 103 | ||
104 | 104 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
105 | 105 | then $a | |
106 | 106 | else throw("List size exceeds 40") | |
107 | 107 | ||
108 | 108 | $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) | |
109 | 109 | } | |
110 | 110 | resultTuple._1 | |
111 | 111 | } | |
112 | 112 | ||
113 | 113 | ||
114 | 114 | func calcExcessAmountPerCfmmPositive (difference,numberCfmms) = { | |
115 | 115 | let quotient = fraction(difference, 1, numberCfmms, DOWN) | |
116 | 116 | let totalDistributedAmount = (quotient * numberCfmms) | |
117 | 117 | let remainingAmount = (difference - totalDistributedAmount) | |
118 | 118 | if ((remainingAmount > 0)) | |
119 | 119 | then $Tuple2(quotient, remainingAmount) | |
120 | 120 | else $Tuple2(quotient, 0) | |
121 | 121 | } | |
122 | 122 | ||
123 | 123 | ||
124 | 124 | func calcExcessAmountPerCfmmNegative (difference,numberCfmms) = { | |
125 | 125 | let quotient = fraction(difference, 1, numberCfmms, DOWN) | |
126 | 126 | let totalDistributedAmount = (quotient * numberCfmms) | |
127 | 127 | let remainingAmount = (difference - totalDistributedAmount) | |
128 | 128 | if ((0 > remainingAmount)) | |
129 | 129 | then $Tuple2(quotient, remainingAmount) | |
130 | 130 | else $Tuple2(quotient, 0) | |
131 | 131 | } | |
132 | 132 | ||
133 | 133 | ||
134 | 134 | func distributeAdditionalTokens (swaps,diff) = { | |
135 | 135 | let totalSwaps = size(swaps) | |
136 | 136 | let $t075217604 = calcExcessAmountPerCfmmPositive(diff, totalSwaps) | |
137 | 137 | let quotient = $t075217604._1 | |
138 | 138 | let remainingAmount = $t075217604._2 | |
139 | 139 | func adjustAmounts (accum,next) = { | |
140 | 140 | let $t076777719 = accum | |
141 | 141 | let adjustedSwaps = $t076777719._1 | |
142 | 142 | let remainingDiff = $t076777719._2 | |
143 | 143 | let item = splitCfmmJson(next) | |
144 | 144 | let inputAmount = parseInt(item[2]) | |
145 | 145 | match inputAmount { | |
146 | 146 | case input: Int => | |
147 | 147 | let amountToAdjust = if ((remainingDiff > 0)) | |
148 | 148 | then ((input + quotient) + 1) | |
149 | 149 | else (input + quotient) | |
150 | 150 | let newItem = ((((item[0] + "/") + item[1]) + "/") + toString(amountToAdjust)) | |
151 | 151 | let newRemainingDiff = if ((remainingDiff > 0)) | |
152 | 152 | then (remainingDiff - 1) | |
153 | 153 | else remainingDiff | |
154 | 154 | $Tuple2((adjustedSwaps :+ newItem), newRemainingDiff) | |
155 | 155 | case _ => | |
156 | 156 | throw("Input has wrong datatype!") | |
157 | 157 | } | |
158 | 158 | } | |
159 | 159 | ||
160 | 160 | let result = { | |
161 | 161 | let $l = swaps | |
162 | 162 | let $s = size($l) | |
163 | 163 | let $acc0 = $Tuple2(nil, remainingAmount) | |
164 | 164 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
165 | 165 | then $a | |
166 | 166 | else adjustAmounts($a, $l[$i]) | |
167 | 167 | ||
168 | 168 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
169 | 169 | then $a | |
170 | 170 | else throw("List size exceeds 40") | |
171 | 171 | ||
172 | 172 | $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) | |
173 | 173 | } | |
174 | 174 | result._1 | |
175 | 175 | } | |
176 | 176 | ||
177 | 177 | ||
178 | 178 | func distributeRemainingDiffs (remainingDiff,swaps) = { | |
179 | 179 | func distributeProportional (accum,next) = { | |
180 | 180 | let $t085958634 = accum | |
181 | 181 | let adjustedSwaps = $t085958634._1 | |
182 | 182 | let remainDiff = $t085958634._2 | |
183 | 183 | let item = splitCfmmJson(next) | |
184 | 184 | let inputAmount = parseInt(item[2]) | |
185 | 185 | let inputAmountCheck = match inputAmount { | |
186 | 186 | case input: Int => | |
187 | 187 | input | |
188 | 188 | case _ => | |
189 | 189 | throw("Input amount has the wrong data type") | |
190 | 190 | } | |
191 | 191 | let maxSubtractable = if ((inputAmountCheck > 4)) | |
192 | 192 | then fraction(inputAmountCheck, 3, 4) | |
193 | 193 | else 0 | |
194 | 194 | let $t090329646 = if (if ((remainDiff == 0)) | |
195 | 195 | then true | |
196 | 196 | else (maxSubtractable == 0)) | |
197 | 197 | then $Tuple2(remainDiff, 0) | |
198 | 198 | else if (((remainDiff + maxSubtractable) > 0)) | |
199 | 199 | then { | |
200 | 200 | let remainingSubtractable = (remainDiff + maxSubtractable) | |
201 | 201 | $Tuple2(0, (maxSubtractable - remainingSubtractable)) | |
202 | 202 | } | |
203 | 203 | else if ((0 > (remainDiff + maxSubtractable))) | |
204 | 204 | then $Tuple2((remainDiff + maxSubtractable), maxSubtractable) | |
205 | 205 | else $Tuple2(0, maxSubtractable) | |
206 | 206 | let newRemainingDiff = $t090329646._1 | |
207 | 207 | let subtractableAmount = $t090329646._2 | |
208 | 208 | let amountToAdjust = (inputAmountCheck - subtractableAmount) | |
209 | 209 | let newItem = ((((item[0] + "/") + item[1]) + "/") + toString(amountToAdjust)) | |
210 | 210 | $Tuple2((adjustedSwaps :+ newItem), newRemainingDiff) | |
211 | 211 | } | |
212 | 212 | ||
213 | 213 | let $l = swaps | |
214 | 214 | let $s = size($l) | |
215 | 215 | let $acc0 = $Tuple2(nil, remainingDiff) | |
216 | 216 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
217 | 217 | then $a | |
218 | 218 | else distributeProportional($a, $l[$i]) | |
219 | 219 | ||
220 | 220 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
221 | 221 | then $a | |
222 | 222 | else throw("List size exceeds 40") | |
223 | 223 | ||
224 | 224 | $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) | |
225 | 225 | } | |
226 | 226 | ||
227 | 227 | ||
228 | 228 | func distributeNegativeTokens (swaps,diff) = { | |
229 | 229 | let totalSwaps = size(swaps) | |
230 | 230 | let $t01001110094 = calcExcessAmountPerCfmmNegative(diff, totalSwaps) | |
231 | 231 | let quotient = $t01001110094._1 | |
232 | 232 | let remainingAmount = $t01001110094._2 | |
233 | 233 | func adjustAmounts (accum,next) = { | |
234 | 234 | let $t01016710209 = accum | |
235 | 235 | let adjustedSwaps = $t01016710209._1 | |
236 | 236 | let remainingDiff = $t01016710209._2 | |
237 | 237 | let item = splitCfmmJson(next) | |
238 | 238 | let inputAmount = parseInt(item[2]) | |
239 | 239 | match inputAmount { | |
240 | 240 | case input: Int => | |
241 | 241 | let $t01034610696 = if (((input + quotient) >= 1)) | |
242 | 242 | then if (if ((remainingDiff > 0)) | |
243 | 243 | then (((input + quotient) - 1) >= 1) | |
244 | 244 | else false) | |
245 | 245 | then $Tuple2(((input + quotient) - 1), (remainingDiff - 1)) | |
246 | 246 | else $Tuple2((input + quotient), remainingDiff) | |
247 | 247 | else $Tuple2(input, (remainingDiff + quotient)) | |
248 | 248 | let amountToAdjust = $t01034610696._1 | |
249 | 249 | let newRemainingDiff = $t01034610696._2 | |
250 | 250 | let newItem = ((((item[0] + "/") + item[1]) + "/") + toString(amountToAdjust)) | |
251 | 251 | $Tuple2((adjustedSwaps :+ newItem), newRemainingDiff) | |
252 | 252 | case _ => | |
253 | 253 | throw("Input has wrong datatype!") | |
254 | 254 | } | |
255 | 255 | } | |
256 | 256 | ||
257 | 257 | let $t01089510986 = { | |
258 | 258 | let $l = swaps | |
259 | 259 | let $s = size($l) | |
260 | 260 | let $acc0 = $Tuple2(nil, remainingAmount) | |
261 | 261 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
262 | 262 | then $a | |
263 | 263 | else adjustAmounts($a, $l[$i]) | |
264 | 264 | ||
265 | 265 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
266 | 266 | then $a | |
267 | 267 | else throw("List size exceeds 40") | |
268 | 268 | ||
269 | 269 | $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) | |
270 | 270 | } | |
271 | 271 | let adjustedSwaps = $t01089510986._1 | |
272 | 272 | let remainingDiffs = $t01089510986._2 | |
273 | 273 | let $t01099011070 = distributeRemainingDiffs(remainingDiffs, adjustedSwaps) | |
274 | 274 | let finalSwaps = $t01099011070._1 | |
275 | 275 | let diffs = $t01099011070._2 | |
276 | 276 | finalSwaps | |
277 | 277 | } | |
278 | 278 | ||
279 | 279 | ||
280 | 280 | func handleSecondInputAmount (predeterminedAmount,availableAmount,swaps) = { | |
281 | 281 | let diff = (availableAmount - predeterminedAmount) | |
282 | 282 | let adjustedSwaps = if ((diff > 0)) | |
283 | 283 | then distributeAdditionalTokens(swaps, diff) | |
284 | 284 | else if ((0 > diff)) | |
285 | 285 | then distributeNegativeTokens(swaps, diff) | |
286 | 286 | else swaps | |
287 | 287 | adjustedSwaps | |
288 | 288 | } | |
289 | 289 | ||
290 | 290 | ||
291 | 291 | @Callable(i) | |
292 | 292 | func setup () = if (!(isDefined(getString(this, "admin")))) | |
293 | 293 | then [writeString("admin", toBase58String(i.caller.bytes))] | |
294 | 294 | else throw("Dapp already setup!") | |
295 | 295 | ||
296 | 296 | ||
297 | 297 | ||
298 | 298 | @Callable(i) | |
299 | 299 | func basicArb (startAmount,secondAmountIn,firstToken,secondToken,firstSwap,secondSwap) = if (isAdmin(i.caller.bytes)) | |
300 | 300 | then { | |
301 | 301 | let firstTokenId = { | |
302 | 302 | let tId = fromBase58String(firstToken) | |
303 | 303 | match tId { | |
304 | 304 | case tId: ByteVector => | |
305 | 305 | tId | |
306 | 306 | case _ => | |
307 | 307 | throw("Invalid datatype") | |
308 | 308 | } | |
309 | 309 | } | |
310 | 310 | let secondTokenId = { | |
311 | 311 | let id = fromBase58String(secondToken) | |
312 | 312 | match id { | |
313 | 313 | case id: ByteVector => | |
314 | 314 | id | |
315 | 315 | case _ => | |
316 | 316 | throw("Invalid datatype") | |
317 | 317 | } | |
318 | 318 | } | |
319 | 319 | let availableAmountFirstToken = assetBalance(this, firstTokenId) | |
320 | 320 | if ((availableAmountFirstToken >= startAmount)) | |
321 | 321 | then { | |
322 | 322 | let firstResult = processCfmms(firstSwap, firstToken, secondToken) | |
323 | - | [writeInteger("Result first swap", firstResult)] | |
323 | + | let secondSwaps = if ((firstResult == secondAmountIn)) | |
324 | + | then secondSwap | |
325 | + | else handleSecondInputAmount(secondAmountIn, firstResult, secondSwap) | |
326 | + | let secondResult = processCfmms(secondSwaps, secondToken, firstToken) | |
327 | + | [writeInteger("Result first swap", firstResult), writeInteger("Result second swap", secondResult)] | |
324 | 328 | } | |
325 | 329 | else throw("Available input amount is not sufficient!") | |
326 | 330 | } | |
327 | 331 | else throw("Address does not match with admin address!") | |
328 | 332 | ||
329 | 333 | ||
330 | 334 | ||
331 | 335 | @Callable(i) | |
332 | 336 | func updateStringEntry (key,stringValue) = if (isAdmin(i.caller.bytes)) | |
333 | 337 | then [writeString(key, stringValue)] | |
334 | 338 | else throw("Address does not match with admin address!") | |
335 | 339 | ||
336 | 340 | ||
337 | 341 | ||
338 | 342 | @Callable(i) | |
339 | 343 | func updateIntegerEntry (key,integerValue) = if (isAdmin(i.caller.bytes)) | |
340 | 344 | then [writeInteger(key, integerValue)] | |
341 | 345 | else throw("Address does not match with admin address!") | |
342 | 346 | ||
343 | 347 | ||
344 | 348 | ||
345 | 349 | @Callable(i) | |
346 | 350 | func deleteStorageEntry (key) = if (isAdmin(i.caller.bytes)) | |
347 | 351 | then [DeleteEntry(key)] | |
348 | 352 | else throw("Address does not match with admin address!") | |
349 | 353 | ||
350 | 354 | ||
351 | 355 | @Verifier(tx) | |
352 | 356 | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
353 | 357 |
github/deemru/w8io/3ef1775 61.63 ms ◑