tx · 6uRiAvMKQsmAC6RAS1humPvcjfgwAd7RViQYa22bFoq6 3P3qCUfvbDUjRnjrfM5XFMrXrzxxiad94Ez: -0.01000000 Waves 2023.02.06 18:40 [3503520] smart account 3P3qCUfvbDUjRnjrfM5XFMrXrzxxiad94Ez > SELF 0.00000000 Waves
{ "type": 13, "id": "6uRiAvMKQsmAC6RAS1humPvcjfgwAd7RViQYa22bFoq6", "fee": 1000000, "feeAssetId": null, "timestamp": 1675698038061, "version": 2, "chainId": 87, "sender": "3P3qCUfvbDUjRnjrfM5XFMrXrzxxiad94Ez", "senderPublicKey": "3zaQerEjh4SK1xhin9zzs5qr337aLRFhz7z1ckjFGhMz", "proofs": [ "4BuaNujLiWAhjpbRpJq6DUf7W8CzrxHbX8supKoRKL3FycKFguepaLAkMAnwuu5wFh14iRTDSWe6EPj8uDKK1G3W" ], "script": "base64:BgLoBAgCEgMKAQESBAoCCAgSAwoBCCIEYm9zcyIOYWRtaW5QdWJsaWNLZXkiCWdldFB1dEdldCIJaXNfc3RhYmxlIgdwdXRGdW5jIgdnZXRGdW5jIgpnZXRCYWxhbmNlIgdhc3NldElkIgckbWF0Y2gwIgFiIghnZXRCYXNlMSIEZGF0YSIGcF9kYXRhIgFhIgJhMiIHYXNzZXRJbiIIYW1vdW50SW4iCGdldEJhc2UyIgJwMSIDbHAxIgtpc19zdGFibGVfMSIBaSIDa2V5IgN2YWwiCmRhdGFfYXJyYXkiCyR0MDE0ODIxNTM4IgskdDAxNTQzMTU5NSILJHQwMTYwMDE2NTIiAnAyIgNscDIiC2lzX3N0YWJsZV8yIgskdDAxNjU3MTcwOSICcDMiA2xwMyILaXNfc3RhYmxlXzMiCyR0MDE3MTUxNzgxIghwdXRGdW5jMSIIZ2V0RnVuYzEiCyR0MDE3ODYxODUyIghwdXRGdW5jMiIIZ2V0RnVuYzIiCyR0MDE4NTcxOTIzIghwdXRGdW5jMyIIZ2V0RnVuYzMiEWFtb3VudF9iZWZfYXNzZXQxIgRwdXQxIgtscDFfYXNzZXRpZCILbHBCYWxhbmNlXzEiBGdldDEiAm5iIhFhbW91bnRfYmVmX2Fzc2V0MiIEcHV0MiILbHAyX2Fzc2V0aWQiC2xwQmFsYW5jZV8yIgRnZXQyIgNuYjIiFWFtb3VudF9iZWZfYmFzZV9hc3NldCIEcHV0MyILbHAzX2Fzc2V0aWQiC2xwQmFsYW5jZV8zIgRnZXQzIgNuYjMiAnR4IgZ2ZXJpZnkGAAFhCQERQGV4dHJOYXRpdmUoMTA2MikBAiMzUFJFNUtIOW9QR2ZGUHM3ZkduUWNKNHdOc2hFRFVQR2oxdAABYgEgr/8efHaHn138Hq+fsexc54494j5bIbLgBnFNFv+bFW0BAWMBAWQEAWUDCQAAAgUBZAABAgtwdXRPbmVUa25WMgIJcHV0T25lVGtuBAFmAwkAAAIFAWQAAQILZ2V0T25lVGtuVjICCWdldE9uZVRrbgkAlAoCBQFlBQFmAQFnAQFoBAFpBQFoAwkAAQIFAWkCCkJ5dGVWZWN0b3IEAWoFAWkJAPAHAgUEdGhpcwUBaggJAO8HAQUEdGhpcwlhdmFpbGFibGUBAWsBAWwEAW0JALUJAgUBbAIBXwQBbgkAkQMCBQFtAAAEAW8JAJEDAgUBbQABBAFwCQCRAwIFAW0AAgQBcQkAkQMCBQFtAAMJAJYKBAUBbgUBbwUBcAUBcQEBcgEBbAQBbQkAtQkCBQFsAgFfBAFzCQCRAwIFAW0AAAQBdAkAkQMCBQFtAAEEAXUJAJEDAgUBbQACCQCVCgMFAXMFAXQFAXUDAXYBCHNldEFtb3V0AQFuAwkBAiE9AggFAXYGY2FsbGVyBQR0aGlzCQACAQIbeW91IGFyZSBub3QgYWxsb3dlZCB0byBzZXQhCQDMCAIJAQxJbnRlZ2VyRW50cnkCAgdtb250YW50BQFuBQNuaWwBdgEPc2V0S2V5VmFsU3RyaW5nAgF3AXgDCQECIT0CCAUBdgZjYWxsZXIFBHRoaXMJAAIBAht5b3UgYXJlIG5vdCBhbGxvd2VkIHRvIHNldCEJAMwIAgkBC1N0cmluZ0VudHJ5AgUBdwUBeAUDbmlsAXYBAncyAQFsAwMJAQIhPQIIBQF2BmNhbGxlcgUEdGhpcwkBAiE9AggFAXYGY2FsbGVyBQFhBwkAAgECG3lvdSBhcmUgbm90IGFsbG93ZWQgdG8gYXJiIQQBeQkAvAkCBQFsAgF8BAF6CQEBawEJAJEDAgUBeQAABAFuCAUBegJfMQQBbwgFAXoCXzIEAXAIBQF6Al8zBAFxCAUBegJfNAQBQQkBAXIBCQCRAwIFAXkAAQQBcwgFAUECXzEEAXQIBQFBAl8yBAF1CAUBQQJfMwQBQgkBAXIBCQCRAwIFAXkAAgQBQwgFAUICXzEEAUQIBQFCAl8yBAFFCAUBQgJfMwQBRgkBAXIBCQCRAwIFAXkAAwQBRwgFAUYCXzEEAUgIBQFGAl8yBAFJCAUBRgJfMwQBSgkBAWMBCQEFdmFsdWUBCQC2CQEFAXUEAUsIBQFKAl8xBAFMCAUBSgJfMgQBTQkBAWMBCQEFdmFsdWUBCQC2CQEFAUUEAU4IBQFNAl8xBAFPCAUBTQJfMgQBUAkBAWMBCQEFdmFsdWUBCQC2CQEFAUkEAVEIBQFQAl8xBAFSCAUBUAJfMgMGCQACAQkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUBbgUBbwUBcAUBcQUBcwUBdAUBdQUBQwUBRAUBRQUBRwUBSAUBSQUBSwUBTAUBTgUBTwUBUQUBUgQBUwkBAWcBCQDZBAEFAW4EAVQJAPwHBAkBB0FkZHJlc3MBCQDZBAEFAXMFAUsJAMwIAgABCQDMCAIHBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJANkEAQUBcAkBBXZhbHVlAQkAtgkBBQFxBQNuaWwDCQAAAgUBVAUBVAQBVQkA2QQBBQF0BAFWCQEBZwEFAVUDCQAAAgUBVgUBVgQBVwkA/AcECQEHQWRkcmVzcwEJANkEAQUBcwUBTAkAzAgCBQFuCQDMCAIAAQUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQFVBQFWBQNuaWwDCQAAAgUBVwUBVwQBWAkAZQIJAQFnAQkA2QQBBQFuBQFTAwkAAAIFAVgFAVgEAVkJAQFnAQkA2QQBBQFvAwkAAAIFAVkFAVkEAVoJAPwHBAkBB0FkZHJlc3MBCQDZBAEFAUMFAU4JAMwIAgABCQDMCAIHBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJANkEAQUBbgUBWAUDbmlsAwkAAAIFAVoFAVoEAmFhCQDZBAEFAUQEAmFiCQEBZwEFAmFhAwkAAAIFAmFiBQJhYgQCYWMJAPwHBAkBB0FkZHJlc3MBCQDZBAEFAUMFAU8JAMwIAgUBbwkAzAgCAAEFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUCYWEFAmFiBQNuaWwDCQAAAgUCYWMFAmFjBAJhZAkAZQIJAQFnAQkA2QQBBQFvBQFZAwkAAAIFAmFkBQJhZAQCYWUJAQFnAQkA2QQBBQFwAwkAAAIFAmFlBQJhZQQCYWYJAPwHBAkBB0FkZHJlc3MBCQDZBAEFAUcFAVIJAMwIAgABCQDMCAIHBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJANkEAQUBbwUCYWQFA25pbAMJAAACBQJhZgUCYWYEAmFnCQDZBAEFAUgEAmFoCQEBZwEFAmFnAwkAAAIFAmFoBQJhaAQCYWkJAPwHBAkBB0FkZHJlc3MBCQDZBAEFAUcFAVIJAMwIAgUBcAkAzAgCAAEFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUCYWcFAmFoBQNuaWwDCQAAAgUCYWkFAmFpBAJhagkAZQIJAQFnAQkA2QQBBQFwBQJhZQMJAAACBQJhagUCYWoDCQBmAgUCYWoAZAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBdgZjYWxsZXIFAmFqCQDZBAEFAXAFA25pbAkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgILYW1vdW50SW4gPSAFAXECDCwgbmV3QmFsXzE6IAkApAMBBQFYAgwsIG5ld0JhbF8yOiAJAKQDAQUCYWQCDCwgbmV3QmFsXzM6IAkApAMBBQJhagkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgECYWsBAmFsAAMJAMgTAwgFAmFrCWJvZHlCeXRlcwkAkQMCCAUCYWsGcHJvb2ZzAAAIBQJhaw9zZW5kZXJQdWJsaWNLZXkGCQDIEwMIBQJhawlib2R5Qnl0ZXMJAJEDAggFAmFrBnByb29mcwAABQFi5yVcsQ==", "height": 3503520, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 5yodXP3AEZxy6MTLZ3xfCABR6GPpyHQDeq3yHGNcwHsz Next: 2Ctym7NZ486yoDMiK86YpGJByu6eZTeGMbzug2bxCsqh Diff:
Old | New | Differences | |
---|---|---|---|
90 | 90 | let $t018571923 = getPutGet(value(parseInt(is_stable_3))) | |
91 | 91 | let putFunc3 = $t018571923._1 | |
92 | 92 | let getFunc3 = $t018571923._2 | |
93 | - | let amount_bef_asset1 = getBalance(fromBase58String(a)) | |
94 | - | let put1 = invoke(Address(fromBase58String(p1)), putFunc1, [1, false], [AttachedPayment(fromBase58String(assetIn), value(parseInt(amountIn)))]) | |
95 | - | if ((put1 == put1)) | |
96 | - | then { | |
97 | - | let lp1_assetid = fromBase58String(lp1) | |
98 | - | let lpBalance_1 = getBalance(lp1_assetid) | |
99 | - | if ((lpBalance_1 == lpBalance_1)) | |
93 | + | if (true) | |
94 | + | then throw(((((((((((((((((((a + a2) + assetIn) + amountIn) + p1) + lp1) + is_stable_1) + p2) + lp2) + is_stable_2) + p3) + lp3) + is_stable_3) + putFunc1) + getFunc1) + putFunc2) + getFunc2) + putFunc3) + getFunc3)) | |
95 | + | else { | |
96 | + | let amount_bef_asset1 = getBalance(fromBase58String(a)) | |
97 | + | let put1 = invoke(Address(fromBase58String(p1)), putFunc1, [1, false], [AttachedPayment(fromBase58String(assetIn), value(parseInt(amountIn)))]) | |
98 | + | if ((put1 == put1)) | |
100 | 99 | then { | |
101 | - | let get1 = invoke(Address(fromBase58String(p1)), getFunc1, [a, 1], [AttachedPayment(lp1_assetid, lpBalance_1)]) | |
102 | - | if ((get1 == get1)) | |
100 | + | let lp1_assetid = fromBase58String(lp1) | |
101 | + | let lpBalance_1 = getBalance(lp1_assetid) | |
102 | + | if ((lpBalance_1 == lpBalance_1)) | |
103 | 103 | then { | |
104 | - | let | |
105 | - | if (( | |
104 | + | let get1 = invoke(Address(fromBase58String(p1)), getFunc1, [a, 1], [AttachedPayment(lp1_assetid, lpBalance_1)]) | |
105 | + | if ((get1 == get1)) | |
106 | 106 | then { | |
107 | - | let amount_bef_ | |
108 | - | if (( | |
107 | + | let nb = (getBalance(fromBase58String(a)) - amount_bef_asset1) | |
108 | + | if ((nb == nb)) | |
109 | 109 | then { | |
110 | - | let | |
111 | - | if (( | |
110 | + | let amount_bef_asset2 = getBalance(fromBase58String(a2)) | |
111 | + | if ((amount_bef_asset2 == amount_bef_asset2)) | |
112 | 112 | then { | |
113 | - | let lp2_assetid = fromBase58String(lp2) | |
114 | - | let lpBalance_2 = getBalance(lp2_assetid) | |
115 | - | if ((lpBalance_2 == lpBalance_2)) | |
113 | + | let put2 = invoke(Address(fromBase58String(p2)), putFunc2, [1, false], [AttachedPayment(fromBase58String(a), nb)]) | |
114 | + | if ((put2 == put2)) | |
116 | 115 | then { | |
117 | - | let get2 = invoke(Address(fromBase58String(p2)), getFunc2, [a2, 1], [AttachedPayment(lp2_assetid, lpBalance_2)]) | |
118 | - | if ((get2 == get2)) | |
116 | + | let lp2_assetid = fromBase58String(lp2) | |
117 | + | let lpBalance_2 = getBalance(lp2_assetid) | |
118 | + | if ((lpBalance_2 == lpBalance_2)) | |
119 | 119 | then { | |
120 | - | let | |
121 | - | if (( | |
120 | + | let get2 = invoke(Address(fromBase58String(p2)), getFunc2, [a2, 1], [AttachedPayment(lp2_assetid, lpBalance_2)]) | |
121 | + | if ((get2 == get2)) | |
122 | 122 | then { | |
123 | - | let amount_bef_ | |
124 | - | if (( | |
123 | + | let nb2 = (getBalance(fromBase58String(a2)) - amount_bef_asset2) | |
124 | + | if ((nb2 == nb2)) | |
125 | 125 | then { | |
126 | - | let | |
127 | - | if (( | |
126 | + | let amount_bef_base_asset = getBalance(fromBase58String(assetIn)) | |
127 | + | if ((amount_bef_base_asset == amount_bef_base_asset)) | |
128 | 128 | then { | |
129 | - | let lp3_assetid = fromBase58String(lp3) | |
130 | - | let lpBalance_3 = getBalance(lp3_assetid) | |
131 | - | if ((lpBalance_3 == lpBalance_3)) | |
129 | + | let put3 = invoke(Address(fromBase58String(p3)), getFunc3, [1, false], [AttachedPayment(fromBase58String(a2), nb2)]) | |
130 | + | if ((put3 == put3)) | |
132 | 131 | then { | |
133 | - | let get3 = invoke(Address(fromBase58String(p3)), getFunc3, [assetIn, 1], [AttachedPayment(lp3_assetid, lpBalance_3)]) | |
134 | - | if ((get3 == get3)) | |
132 | + | let lp3_assetid = fromBase58String(lp3) | |
133 | + | let lpBalance_3 = getBalance(lp3_assetid) | |
134 | + | if ((lpBalance_3 == lpBalance_3)) | |
135 | 135 | then { | |
136 | - | let nb3 = (getBalance(fromBase58String(assetIn)) - amount_bef_base_asset) | |
137 | - | if ((nb3 == nb3)) | |
138 | - | then if ((nb3 > 100)) | |
139 | - | then [ScriptTransfer(i.caller, nb3, fromBase58String(assetIn))] | |
140 | - | else throw(((((((("amountIn = " + amountIn) + ", newBal_1: ") + toString(nb)) + ", newBal_2: ") + toString(nb2)) + ", newBal_3: ") + toString(nb3))) | |
136 | + | let get3 = invoke(Address(fromBase58String(p3)), getFunc3, [assetIn, 1], [AttachedPayment(lp3_assetid, lpBalance_3)]) | |
137 | + | if ((get3 == get3)) | |
138 | + | then { | |
139 | + | let nb3 = (getBalance(fromBase58String(assetIn)) - amount_bef_base_asset) | |
140 | + | if ((nb3 == nb3)) | |
141 | + | then if ((nb3 > 100)) | |
142 | + | then [ScriptTransfer(i.caller, nb3, fromBase58String(assetIn))] | |
143 | + | else throw(((((((("amountIn = " + amountIn) + ", newBal_1: ") + toString(nb)) + ", newBal_2: ") + toString(nb2)) + ", newBal_3: ") + toString(nb3))) | |
144 | + | else throw("Strict value is not equal to itself.") | |
145 | + | } | |
141 | 146 | else throw("Strict value is not equal to itself.") | |
142 | 147 | } | |
143 | 148 | else throw("Strict value is not equal to itself.") | |
164 | 169 | } | |
165 | 170 | else throw("Strict value is not equal to itself.") | |
166 | 171 | } | |
167 | - | else throw("Strict value is not equal to itself.") | |
168 | 172 | } | |
169 | 173 | ||
170 | 174 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let boss = addressFromStringValue("3PRE5KH9oPGfFPs7fGnQcJ4wNshEDUPGj1t") | |
5 | 5 | ||
6 | 6 | let adminPublicKey = base58'Cr1ybL2JGg9GwJHA2JwqxBPfSW6Q7Jg4HvNrsEiCsHu6' | |
7 | 7 | ||
8 | 8 | func getPutGet (is_stable) = { | |
9 | 9 | let putFunc = if ((is_stable == 1)) | |
10 | 10 | then "putOneTknV2" | |
11 | 11 | else "putOneTkn" | |
12 | 12 | let getFunc = if ((is_stable == 1)) | |
13 | 13 | then "getOneTknV2" | |
14 | 14 | else "getOneTkn" | |
15 | 15 | $Tuple2(putFunc, getFunc) | |
16 | 16 | } | |
17 | 17 | ||
18 | 18 | ||
19 | 19 | func getBalance (assetId) = match assetId { | |
20 | 20 | case b: ByteVector => | |
21 | 21 | assetBalance(this, b) | |
22 | 22 | case _ => | |
23 | 23 | wavesBalance(this).available | |
24 | 24 | } | |
25 | 25 | ||
26 | 26 | ||
27 | 27 | func getBase1 (data) = { | |
28 | 28 | let p_data = split(data, "_") | |
29 | 29 | let a = p_data[0] | |
30 | 30 | let a2 = p_data[1] | |
31 | 31 | let assetIn = p_data[2] | |
32 | 32 | let amountIn = p_data[3] | |
33 | 33 | $Tuple4(a, a2, assetIn, amountIn) | |
34 | 34 | } | |
35 | 35 | ||
36 | 36 | ||
37 | 37 | func getBase2 (data) = { | |
38 | 38 | let p_data = split(data, "_") | |
39 | 39 | let p1 = p_data[0] | |
40 | 40 | let lp1 = p_data[1] | |
41 | 41 | let is_stable_1 = p_data[2] | |
42 | 42 | $Tuple3(p1, lp1, is_stable_1) | |
43 | 43 | } | |
44 | 44 | ||
45 | 45 | ||
46 | 46 | @Callable(i) | |
47 | 47 | func setAmout (a) = if ((i.caller != this)) | |
48 | 48 | then throw("you are not allowed to set!") | |
49 | 49 | else [IntegerEntry("montant", a)] | |
50 | 50 | ||
51 | 51 | ||
52 | 52 | ||
53 | 53 | @Callable(i) | |
54 | 54 | func setKeyValString (key,val) = if ((i.caller != this)) | |
55 | 55 | then throw("you are not allowed to set!") | |
56 | 56 | else [StringEntry(key, val)] | |
57 | 57 | ||
58 | 58 | ||
59 | 59 | ||
60 | 60 | @Callable(i) | |
61 | 61 | func w2 (data) = if (if ((i.caller != this)) | |
62 | 62 | then (i.caller != boss) | |
63 | 63 | else false) | |
64 | 64 | then throw("you are not allowed to arb!") | |
65 | 65 | else { | |
66 | 66 | let data_array = split_4C(data, "|") | |
67 | 67 | let $t014821538 = getBase1(data_array[0]) | |
68 | 68 | let a = $t014821538._1 | |
69 | 69 | let a2 = $t014821538._2 | |
70 | 70 | let assetIn = $t014821538._3 | |
71 | 71 | let amountIn = $t014821538._4 | |
72 | 72 | let $t015431595 = getBase2(data_array[1]) | |
73 | 73 | let p1 = $t015431595._1 | |
74 | 74 | let lp1 = $t015431595._2 | |
75 | 75 | let is_stable_1 = $t015431595._3 | |
76 | 76 | let $t016001652 = getBase2(data_array[2]) | |
77 | 77 | let p2 = $t016001652._1 | |
78 | 78 | let lp2 = $t016001652._2 | |
79 | 79 | let is_stable_2 = $t016001652._3 | |
80 | 80 | let $t016571709 = getBase2(data_array[3]) | |
81 | 81 | let p3 = $t016571709._1 | |
82 | 82 | let lp3 = $t016571709._2 | |
83 | 83 | let is_stable_3 = $t016571709._3 | |
84 | 84 | let $t017151781 = getPutGet(value(parseInt(is_stable_1))) | |
85 | 85 | let putFunc1 = $t017151781._1 | |
86 | 86 | let getFunc1 = $t017151781._2 | |
87 | 87 | let $t017861852 = getPutGet(value(parseInt(is_stable_2))) | |
88 | 88 | let putFunc2 = $t017861852._1 | |
89 | 89 | let getFunc2 = $t017861852._2 | |
90 | 90 | let $t018571923 = getPutGet(value(parseInt(is_stable_3))) | |
91 | 91 | let putFunc3 = $t018571923._1 | |
92 | 92 | let getFunc3 = $t018571923._2 | |
93 | - | let amount_bef_asset1 = getBalance(fromBase58String(a)) | |
94 | - | let put1 = invoke(Address(fromBase58String(p1)), putFunc1, [1, false], [AttachedPayment(fromBase58String(assetIn), value(parseInt(amountIn)))]) | |
95 | - | if ((put1 == put1)) | |
96 | - | then { | |
97 | - | let lp1_assetid = fromBase58String(lp1) | |
98 | - | let lpBalance_1 = getBalance(lp1_assetid) | |
99 | - | if ((lpBalance_1 == lpBalance_1)) | |
93 | + | if (true) | |
94 | + | then throw(((((((((((((((((((a + a2) + assetIn) + amountIn) + p1) + lp1) + is_stable_1) + p2) + lp2) + is_stable_2) + p3) + lp3) + is_stable_3) + putFunc1) + getFunc1) + putFunc2) + getFunc2) + putFunc3) + getFunc3)) | |
95 | + | else { | |
96 | + | let amount_bef_asset1 = getBalance(fromBase58String(a)) | |
97 | + | let put1 = invoke(Address(fromBase58String(p1)), putFunc1, [1, false], [AttachedPayment(fromBase58String(assetIn), value(parseInt(amountIn)))]) | |
98 | + | if ((put1 == put1)) | |
100 | 99 | then { | |
101 | - | let get1 = invoke(Address(fromBase58String(p1)), getFunc1, [a, 1], [AttachedPayment(lp1_assetid, lpBalance_1)]) | |
102 | - | if ((get1 == get1)) | |
100 | + | let lp1_assetid = fromBase58String(lp1) | |
101 | + | let lpBalance_1 = getBalance(lp1_assetid) | |
102 | + | if ((lpBalance_1 == lpBalance_1)) | |
103 | 103 | then { | |
104 | - | let | |
105 | - | if (( | |
104 | + | let get1 = invoke(Address(fromBase58String(p1)), getFunc1, [a, 1], [AttachedPayment(lp1_assetid, lpBalance_1)]) | |
105 | + | if ((get1 == get1)) | |
106 | 106 | then { | |
107 | - | let amount_bef_ | |
108 | - | if (( | |
107 | + | let nb = (getBalance(fromBase58String(a)) - amount_bef_asset1) | |
108 | + | if ((nb == nb)) | |
109 | 109 | then { | |
110 | - | let | |
111 | - | if (( | |
110 | + | let amount_bef_asset2 = getBalance(fromBase58String(a2)) | |
111 | + | if ((amount_bef_asset2 == amount_bef_asset2)) | |
112 | 112 | then { | |
113 | - | let lp2_assetid = fromBase58String(lp2) | |
114 | - | let lpBalance_2 = getBalance(lp2_assetid) | |
115 | - | if ((lpBalance_2 == lpBalance_2)) | |
113 | + | let put2 = invoke(Address(fromBase58String(p2)), putFunc2, [1, false], [AttachedPayment(fromBase58String(a), nb)]) | |
114 | + | if ((put2 == put2)) | |
116 | 115 | then { | |
117 | - | let get2 = invoke(Address(fromBase58String(p2)), getFunc2, [a2, 1], [AttachedPayment(lp2_assetid, lpBalance_2)]) | |
118 | - | if ((get2 == get2)) | |
116 | + | let lp2_assetid = fromBase58String(lp2) | |
117 | + | let lpBalance_2 = getBalance(lp2_assetid) | |
118 | + | if ((lpBalance_2 == lpBalance_2)) | |
119 | 119 | then { | |
120 | - | let | |
121 | - | if (( | |
120 | + | let get2 = invoke(Address(fromBase58String(p2)), getFunc2, [a2, 1], [AttachedPayment(lp2_assetid, lpBalance_2)]) | |
121 | + | if ((get2 == get2)) | |
122 | 122 | then { | |
123 | - | let amount_bef_ | |
124 | - | if (( | |
123 | + | let nb2 = (getBalance(fromBase58String(a2)) - amount_bef_asset2) | |
124 | + | if ((nb2 == nb2)) | |
125 | 125 | then { | |
126 | - | let | |
127 | - | if (( | |
126 | + | let amount_bef_base_asset = getBalance(fromBase58String(assetIn)) | |
127 | + | if ((amount_bef_base_asset == amount_bef_base_asset)) | |
128 | 128 | then { | |
129 | - | let lp3_assetid = fromBase58String(lp3) | |
130 | - | let lpBalance_3 = getBalance(lp3_assetid) | |
131 | - | if ((lpBalance_3 == lpBalance_3)) | |
129 | + | let put3 = invoke(Address(fromBase58String(p3)), getFunc3, [1, false], [AttachedPayment(fromBase58String(a2), nb2)]) | |
130 | + | if ((put3 == put3)) | |
132 | 131 | then { | |
133 | - | let get3 = invoke(Address(fromBase58String(p3)), getFunc3, [assetIn, 1], [AttachedPayment(lp3_assetid, lpBalance_3)]) | |
134 | - | if ((get3 == get3)) | |
132 | + | let lp3_assetid = fromBase58String(lp3) | |
133 | + | let lpBalance_3 = getBalance(lp3_assetid) | |
134 | + | if ((lpBalance_3 == lpBalance_3)) | |
135 | 135 | then { | |
136 | - | let nb3 = (getBalance(fromBase58String(assetIn)) - amount_bef_base_asset) | |
137 | - | if ((nb3 == nb3)) | |
138 | - | then if ((nb3 > 100)) | |
139 | - | then [ScriptTransfer(i.caller, nb3, fromBase58String(assetIn))] | |
140 | - | else throw(((((((("amountIn = " + amountIn) + ", newBal_1: ") + toString(nb)) + ", newBal_2: ") + toString(nb2)) + ", newBal_3: ") + toString(nb3))) | |
136 | + | let get3 = invoke(Address(fromBase58String(p3)), getFunc3, [assetIn, 1], [AttachedPayment(lp3_assetid, lpBalance_3)]) | |
137 | + | if ((get3 == get3)) | |
138 | + | then { | |
139 | + | let nb3 = (getBalance(fromBase58String(assetIn)) - amount_bef_base_asset) | |
140 | + | if ((nb3 == nb3)) | |
141 | + | then if ((nb3 > 100)) | |
142 | + | then [ScriptTransfer(i.caller, nb3, fromBase58String(assetIn))] | |
143 | + | else throw(((((((("amountIn = " + amountIn) + ", newBal_1: ") + toString(nb)) + ", newBal_2: ") + toString(nb2)) + ", newBal_3: ") + toString(nb3))) | |
144 | + | else throw("Strict value is not equal to itself.") | |
145 | + | } | |
141 | 146 | else throw("Strict value is not equal to itself.") | |
142 | 147 | } | |
143 | 148 | else throw("Strict value is not equal to itself.") | |
144 | 149 | } | |
145 | 150 | else throw("Strict value is not equal to itself.") | |
146 | 151 | } | |
147 | 152 | else throw("Strict value is not equal to itself.") | |
148 | 153 | } | |
149 | 154 | else throw("Strict value is not equal to itself.") | |
150 | 155 | } | |
151 | 156 | else throw("Strict value is not equal to itself.") | |
152 | 157 | } | |
153 | 158 | else throw("Strict value is not equal to itself.") | |
154 | 159 | } | |
155 | 160 | else throw("Strict value is not equal to itself.") | |
156 | 161 | } | |
157 | 162 | else throw("Strict value is not equal to itself.") | |
158 | 163 | } | |
159 | 164 | else throw("Strict value is not equal to itself.") | |
160 | 165 | } | |
161 | 166 | else throw("Strict value is not equal to itself.") | |
162 | 167 | } | |
163 | 168 | else throw("Strict value is not equal to itself.") | |
164 | 169 | } | |
165 | 170 | else throw("Strict value is not equal to itself.") | |
166 | 171 | } | |
167 | - | else throw("Strict value is not equal to itself.") | |
168 | 172 | } | |
169 | 173 | ||
170 | 174 | ||
171 | 175 | @Verifier(tx) | |
172 | 176 | func verify () = if (sigVerify_128Kb(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)) | |
173 | 177 | then true | |
174 | 178 | else sigVerify_128Kb(tx.bodyBytes, tx.proofs[0], adminPublicKey) | |
175 | 179 |
github/deemru/w8io/3ef1775 122.22 ms ◑