tx · BaDt7auFcqgeKhxQycJt6jBM9GwxZJW7Uh5ACSuFUHZZ 3P3qCUfvbDUjRnjrfM5XFMrXrzxxiad94Ez: -0.01000000 Waves 2023.02.07 09:40 [3504406] smart account 3P3qCUfvbDUjRnjrfM5XFMrXrzxxiad94Ez > SELF 0.00000000 Waves
{ "type": 13, "id": "BaDt7auFcqgeKhxQycJt6jBM9GwxZJW7Uh5ACSuFUHZZ", "fee": 1000000, "feeAssetId": null, "timestamp": 1675752101838, "version": 2, "chainId": 87, "sender": "3P3qCUfvbDUjRnjrfM5XFMrXrzxxiad94Ez", "senderPublicKey": "3zaQerEjh4SK1xhin9zzs5qr337aLRFhz7z1ckjFGhMz", "proofs": [ "mGmiT4LFdGiHv9ok14WTBYaSGTnPjzxTCtNsk8AVn8Sp2S92xEFvms9j2ThXxPpVaoXfvY2yaGrJbtu3gytbd4F" ], "script": "base64:BgKbBQgCEgMKAQESBAoCCAgSAwoBCCIEYm9zcyIOYWRtaW5QdWJsaWNLZXkiCWdldFB1dEdldCIJaXNfc3RhYmxlIgdwdXRGdW5jIgdnZXRGdW5jIgpnZXRCYWxhbmNlIgdhc3NldElkIgckbWF0Y2gwIgFiIghnZXRCYXNlMSIEZGF0YSIGcF9kYXRhIgFhIgJhMiIHYXNzZXRJbiIIYW1vdW50SW4iCGdldEJhc2UyIgJwMSIDbHAxIgtpc19zdGFibGVfMSINZ2V0QXNzZXRCeXRlcyIBaSIDa2V5IgAiA3ZhbCIKZGF0YV9hcnJheSILJHQwMTU4NjE2NDIiCyR0MDE2NDcxNjk5IgskdDAxNzA0MTc1NiICcDIiA2xwMiILaXNfc3RhYmxlXzIiCyR0MDE3NjExODEzIgJwMyIDbHAzIgtpc19zdGFibGVfMyILJHQwMTgxOTE4ODUiCHB1dEZ1bmMxIghnZXRGdW5jMSILJHQwMTg5MDE5NTYiCHB1dEZ1bmMyIghnZXRGdW5jMiILJHQwMTk2MTIwMjciCHB1dEZ1bmMzIghnZXRGdW5jMyISYW1vdW50X2JlZl9hc3NldEluIgxuZXdfYW1vdW50SW4iEWFtb3VudF9iZWZfYXNzZXQxIgRwdXQxIgtscDFfYXNzZXRpZCILbHBCYWxhbmNlXzEiBGdldDEiAm5iIhFhbW91bnRfYmVmX2Fzc2V0MiIEcHV0MiILbHAyX2Fzc2V0aWQiC2xwQmFsYW5jZV8yIgRnZXQyIgNuYjIiFWFtb3VudF9iZWZfYmFzZV9hc3NldCIEcHV0MyILbHAzX2Fzc2V0aWQiC2xwQmFsYW5jZV8zIgRnZXQzIgNuYjMiAnR4IgZ2ZXJpZnkHAAFhCQERQGV4dHJOYXRpdmUoMTA2MikBAiMzUFJFNUtIOW9QR2ZGUHM3ZkduUWNKNHdOc2hFRFVQR2oxdAABYgEgr/8efHaHn138Hq+fsexc54494j5bIbLgBnFNFv+bFW0BAWMBAWQEAWUDCQAAAgUBZAABAgtwdXRPbmVUa25WMgIJcHV0T25lVGtuBAFmAwkAAAIFAWQAAQILZ2V0T25lVGtuVjICCWdldE9uZVRrbgkAlAoCBQFlBQFmAQFnAQFoBAFpBQFoAwkAAQIFAWkCCkJ5dGVWZWN0b3IEAWoFAWkJAPAHAgUEdGhpcwUBaggJAO8HAQUEdGhpcwlhdmFpbGFibGUBAWsBAWwEAW0JALUJAgUBbAIBXwQBbgkAkQMCBQFtAAAEAW8JAJEDAgUBbQABBAFwCQCRAwIFAW0AAgQBcQkAkQMCBQFtAAMJAJYKBAUBbgUBbwUBcAUBcQEBcgEBbAQBbQkAtQkCBQFsAgFfBAFzCQCRAwIFAW0AAAQBdAkAkQMCBQFtAAEEAXUJAJEDAgUBbQACCQCVCgMFAXMFAXQFAXUBAXYBAWgDCQAAAgUBaAIFV0FWRVMFBHVuaXQJANkEAQUBaAMBdwEIc2V0QW1vdXQBAW4DCQECIT0CCAUBdwZjYWxsZXIFBHRoaXMJAAIBAht5b3UgYXJlIG5vdCBhbGxvd2VkIHRvIHNldCEJAMwIAgkBDEludGVnZXJFbnRyeQICB21vbnRhbnQFAW4FA25pbAF3AQ9zZXRLZXlWYWxTdHJpbmcCAXgBegMJAQIhPQIIBQF3BmNhbGxlcgUEdGhpcwkAAgECG3lvdSBhcmUgbm90IGFsbG93ZWQgdG8gc2V0IQkAzAgCCQELU3RyaW5nRW50cnkCBQF4BQF6BQNuaWwBdwEBeQEBbAMDCQECIT0CCAUBdwZjYWxsZXIFBHRoaXMJAQIhPQIIBQF3BmNhbGxlcgUBYQcJAAIBAht5b3UgYXJlIG5vdCBhbGxvd2VkIHRvIGFyYiEEAUEJALwJAgUBbAIBfAQBQgkBAWsBCQCRAwIFAUEAAAQBbggFAUICXzEEAW8IBQFCAl8yBAFwCAUBQgJfMwQBcQgFAUICXzQEAUMJAQFyAQkAkQMCBQFBAAEEAXMIBQFDAl8xBAF0CAUBQwJfMgQBdQgFAUMCXzMEAUQJAQFyAQkAkQMCBQFBAAIEAUUIBQFEAl8xBAFGCAUBRAJfMgQBRwgFAUQCXzMEAUgJAQFyAQkAkQMCBQFBAAMEAUkIBQFIAl8xBAFKCAUBSAJfMgQBSwgFAUgCXzMEAUwJAQFjAQkBBXZhbHVlAQkAtgkBBQF1BAFNCAUBTAJfMQQBTggFAUwCXzIEAU8JAQFjAQkBBXZhbHVlAQkAtgkBBQFHBAFQCAUBTwJfMQQBUQgFAU8CXzIEAVIJAQFjAQkBBXZhbHVlAQkAtgkBBQFLBAFTCAUBUgJfMQQBVAgFAVICXzIEAVUJAQFnAQkBAXYBBQFwAwkAAAIFAVUFAVUEAVYDCQBmAgkBBXZhbHVlAQkAtgkBBQFxBQFVBQFVCQEFdmFsdWUBCQC2CQEFAXEDCQAAAgUBVgUBVgQBVwkBAWcBCQEBdgEFAW4DCQAAAgUBVwUBVwQBWAkA/AcECQEHQWRkcmVzcwEJANkEAQUBcwUBTQkAzAgCAAEJAMwIAgcFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkBAXYBBQFwBQFWBQNuaWwDCQAAAgUBWAUBWAQBWQkA2QQBBQF0BAFaCQEBZwEFAVkDCQAAAgUBWgUBWgQCYWEJAPwHBAkBB0FkZHJlc3MBCQDZBAEFAXMFAU4JAMwIAgUBbgkAzAgCAAEFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUBWQUBWgUDbmlsAwkAAAIFAmFhBQJhYQQCYWIJAGUCCQEBZwEJAQF2AQUBbgUBVwMJAAACBQJhYgUCYWIEAmFjCQEBZwEJAQF2AQUBbwMJAAACBQJhYwUCYWMEAmFkCQD8BwQJAQdBZGRyZXNzAQkA2QQBBQFFBQFQCQDMCAIAAQkAzAgCBwUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQEBdgEFAW4FAmFiBQNuaWwDCQAAAgUCYWQFAmFkBAJhZQkA2QQBBQFGBAJhZgkBAWcBBQJhZQMJAAACBQJhZgUCYWYEAmFnCQD8BwQJAQdBZGRyZXNzAQkA2QQBBQFFBQFRCQDMCAIFAW8JAMwIAgABBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFAmFlBQJhZgUDbmlsAwkAAAIFAmFnBQJhZwQCYWgJAGUCCQEBZwEJAQF2AQUBbwUCYWMDCQAAAgUCYWgFAmFoBAJhaQkBAWcBCQEBdgEFAXADCQAAAgUCYWkFAmFpBAJhagkA/AcECQEHQWRkcmVzcwEJANkEAQUBSQUBUwkAzAgCAAEJAMwIAgcFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkBAXYBBQFvBQJhaAUDbmlsAwkAAAIFAmFqBQJhagQCYWsJANkEAQUBSgQCYWwJAQFnAQUCYWsDCQAAAgUCYWwFAmFsBAJhbQkA/AcECQEHQWRkcmVzcwEJANkEAQUBSQUBVAkAzAgCBQFwCQDMCAIAAQUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQJhawUCYWwFA25pbAMJAAACBQJhbQUCYW0EAmFuCQBlAgkBAWcBCQEBdgEFAXAFAmFpAwkAAAIFAmFuBQJhbgMJAGYCBQJhbgkAZAIFAVYAZAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBdwZjYWxsZXIJAGUCBQJhbgUBVgkBAXYBBQFwBQNuaWwJAAIBCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICD25ld19hbW91bnRJbiA9IAUBcQIMLCBuZXdCYWxfMTogCQCkAwEFAmFiAgwsIG5ld0JhbF8yOiAJAKQDAQUCYWgCDCwgbmV3QmFsXzM6IAkApAMBBQJhbgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgECYW8BAmFwAAMJAMgTAwgFAmFvCWJvZHlCeXRlcwkAkQMCCAUCYW8GcHJvb2ZzAAAIBQJhbw9zZW5kZXJQdWJsaWNLZXkGCQDIEwMIBQJhbwlib2R5Qnl0ZXMJAJEDAggFAmFvBnByb29mcwAABQFiRd1llg==", "height": 3504406, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 78enuEArFwzWNJHJAjeVAJAMZwWdbrfsBvFBrUNGMEwo Next: BJPrBKu2F3pUjfzE5y44EbVMgNNqXrbKnBhrQcAhcfeg Diff:
Old | New | Differences | |
---|---|---|---|
101 | 101 | let new_amountIn = if ((value(parseInt(amountIn)) > amount_bef_assetIn)) | |
102 | 102 | then amount_bef_assetIn | |
103 | 103 | else value(parseInt(amountIn)) | |
104 | - | let amount_bef_asset1 = getBalance(getAssetBytes(a)) | |
105 | - | if ((amount_bef_asset1 == amount_bef_asset1)) | |
104 | + | if ((new_amountIn == new_amountIn)) | |
106 | 105 | then { | |
107 | - | let | |
108 | - | if (( | |
106 | + | let amount_bef_asset1 = getBalance(getAssetBytes(a)) | |
107 | + | if ((amount_bef_asset1 == amount_bef_asset1)) | |
109 | 108 | then { | |
110 | - | let lp1_assetid = fromBase58String(lp1) | |
111 | - | let lpBalance_1 = getBalance(lp1_assetid) | |
112 | - | if ((lpBalance_1 == lpBalance_1)) | |
109 | + | let put1 = invoke(Address(fromBase58String(p1)), putFunc1, [1, false], [AttachedPayment(getAssetBytes(assetIn), new_amountIn)]) | |
110 | + | if ((put1 == put1)) | |
113 | 111 | then { | |
114 | - | let get1 = invoke(Address(fromBase58String(p1)), getFunc1, [a, 1], [AttachedPayment(lp1_assetid, lpBalance_1)]) | |
115 | - | if ((get1 == get1)) | |
112 | + | let lp1_assetid = fromBase58String(lp1) | |
113 | + | let lpBalance_1 = getBalance(lp1_assetid) | |
114 | + | if ((lpBalance_1 == lpBalance_1)) | |
116 | 115 | then { | |
117 | - | let | |
118 | - | if (( | |
116 | + | let get1 = invoke(Address(fromBase58String(p1)), getFunc1, [a, 1], [AttachedPayment(lp1_assetid, lpBalance_1)]) | |
117 | + | if ((get1 == get1)) | |
119 | 118 | then { | |
120 | - | let amount_bef_ | |
121 | - | if (( | |
119 | + | let nb = (getBalance(getAssetBytes(a)) - amount_bef_asset1) | |
120 | + | if ((nb == nb)) | |
122 | 121 | then { | |
123 | - | let | |
124 | - | if (( | |
122 | + | let amount_bef_asset2 = getBalance(getAssetBytes(a2)) | |
123 | + | if ((amount_bef_asset2 == amount_bef_asset2)) | |
125 | 124 | then { | |
126 | - | let lp2_assetid = fromBase58String(lp2) | |
127 | - | let lpBalance_2 = getBalance(lp2_assetid) | |
128 | - | if ((lpBalance_2 == lpBalance_2)) | |
125 | + | let put2 = invoke(Address(fromBase58String(p2)), putFunc2, [1, false], [AttachedPayment(getAssetBytes(a), nb)]) | |
126 | + | if ((put2 == put2)) | |
129 | 127 | then { | |
130 | - | let get2 = invoke(Address(fromBase58String(p2)), getFunc2, [a2, 1], [AttachedPayment(lp2_assetid, lpBalance_2)]) | |
131 | - | if ((get2 == get2)) | |
128 | + | let lp2_assetid = fromBase58String(lp2) | |
129 | + | let lpBalance_2 = getBalance(lp2_assetid) | |
130 | + | if ((lpBalance_2 == lpBalance_2)) | |
132 | 131 | then { | |
133 | - | let | |
134 | - | if (( | |
132 | + | let get2 = invoke(Address(fromBase58String(p2)), getFunc2, [a2, 1], [AttachedPayment(lp2_assetid, lpBalance_2)]) | |
133 | + | if ((get2 == get2)) | |
135 | 134 | then { | |
136 | - | let amount_bef_ | |
137 | - | if (( | |
135 | + | let nb2 = (getBalance(getAssetBytes(a2)) - amount_bef_asset2) | |
136 | + | if ((nb2 == nb2)) | |
138 | 137 | then { | |
139 | - | let | |
140 | - | if (( | |
138 | + | let amount_bef_base_asset = getBalance(getAssetBytes(assetIn)) | |
139 | + | if ((amount_bef_base_asset == amount_bef_base_asset)) | |
141 | 140 | then { | |
142 | - | let lp3_assetid = fromBase58String(lp3) | |
143 | - | let lpBalance_3 = getBalance(lp3_assetid) | |
144 | - | if ((lpBalance_3 == lpBalance_3)) | |
141 | + | let put3 = invoke(Address(fromBase58String(p3)), putFunc3, [1, false], [AttachedPayment(getAssetBytes(a2), nb2)]) | |
142 | + | if ((put3 == put3)) | |
145 | 143 | then { | |
146 | - | let get3 = invoke(Address(fromBase58String(p3)), getFunc3, [assetIn, 1], [AttachedPayment(lp3_assetid, lpBalance_3)]) | |
147 | - | if ((get3 == get3)) | |
144 | + | let lp3_assetid = fromBase58String(lp3) | |
145 | + | let lpBalance_3 = getBalance(lp3_assetid) | |
146 | + | if ((lpBalance_3 == lpBalance_3)) | |
148 | 147 | then { | |
149 | - | let nb3 = (getBalance(getAssetBytes(assetIn)) - amount_bef_base_asset) | |
150 | - | if ((nb3 == nb3)) | |
151 | - | then if ((nb3 > (new_amountIn + 100))) | |
152 | - | then [ScriptTransfer(i.caller, (nb3 - new_amountIn), getAssetBytes(assetIn))] | |
153 | - | else throw(((((((("new_amountIn = " + amountIn) + ", newBal_1: ") + toString(nb)) + ", newBal_2: ") + toString(nb2)) + ", newBal_3: ") + toString(nb3))) | |
148 | + | let get3 = invoke(Address(fromBase58String(p3)), getFunc3, [assetIn, 1], [AttachedPayment(lp3_assetid, lpBalance_3)]) | |
149 | + | if ((get3 == get3)) | |
150 | + | then { | |
151 | + | let nb3 = (getBalance(getAssetBytes(assetIn)) - amount_bef_base_asset) | |
152 | + | if ((nb3 == nb3)) | |
153 | + | then if ((nb3 > (new_amountIn + 100))) | |
154 | + | then [ScriptTransfer(i.caller, (nb3 - new_amountIn), getAssetBytes(assetIn))] | |
155 | + | else throw(((((((("new_amountIn = " + amountIn) + ", newBal_1: ") + toString(nb)) + ", newBal_2: ") + toString(nb2)) + ", newBal_3: ") + toString(nb3))) | |
156 | + | else throw("Strict value is not equal to itself.") | |
157 | + | } | |
154 | 158 | else throw("Strict value is not equal to itself.") | |
155 | 159 | } | |
156 | 160 | else throw("Strict value is not equal to itself.") |
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 | func getAssetBytes (assetId) = if ((assetId == "WAVES")) | |
47 | 47 | then unit | |
48 | 48 | else fromBase58String(assetId) | |
49 | 49 | ||
50 | 50 | ||
51 | 51 | @Callable(i) | |
52 | 52 | func setAmout (a) = if ((i.caller != this)) | |
53 | 53 | then throw("you are not allowed to set!") | |
54 | 54 | else [IntegerEntry("montant", a)] | |
55 | 55 | ||
56 | 56 | ||
57 | 57 | ||
58 | 58 | @Callable(i) | |
59 | 59 | func setKeyValString (key,val) = if ((i.caller != this)) | |
60 | 60 | then throw("you are not allowed to set!") | |
61 | 61 | else [StringEntry(key, val)] | |
62 | 62 | ||
63 | 63 | ||
64 | 64 | ||
65 | 65 | @Callable(i) | |
66 | 66 | func y (data) = if (if ((i.caller != this)) | |
67 | 67 | then (i.caller != boss) | |
68 | 68 | else false) | |
69 | 69 | then throw("you are not allowed to arb!") | |
70 | 70 | else { | |
71 | 71 | let data_array = split_4C(data, "|") | |
72 | 72 | let $t015861642 = getBase1(data_array[0]) | |
73 | 73 | let a = $t015861642._1 | |
74 | 74 | let a2 = $t015861642._2 | |
75 | 75 | let assetIn = $t015861642._3 | |
76 | 76 | let amountIn = $t015861642._4 | |
77 | 77 | let $t016471699 = getBase2(data_array[1]) | |
78 | 78 | let p1 = $t016471699._1 | |
79 | 79 | let lp1 = $t016471699._2 | |
80 | 80 | let is_stable_1 = $t016471699._3 | |
81 | 81 | let $t017041756 = getBase2(data_array[2]) | |
82 | 82 | let p2 = $t017041756._1 | |
83 | 83 | let lp2 = $t017041756._2 | |
84 | 84 | let is_stable_2 = $t017041756._3 | |
85 | 85 | let $t017611813 = getBase2(data_array[3]) | |
86 | 86 | let p3 = $t017611813._1 | |
87 | 87 | let lp3 = $t017611813._2 | |
88 | 88 | let is_stable_3 = $t017611813._3 | |
89 | 89 | let $t018191885 = getPutGet(value(parseInt(is_stable_1))) | |
90 | 90 | let putFunc1 = $t018191885._1 | |
91 | 91 | let getFunc1 = $t018191885._2 | |
92 | 92 | let $t018901956 = getPutGet(value(parseInt(is_stable_2))) | |
93 | 93 | let putFunc2 = $t018901956._1 | |
94 | 94 | let getFunc2 = $t018901956._2 | |
95 | 95 | let $t019612027 = getPutGet(value(parseInt(is_stable_3))) | |
96 | 96 | let putFunc3 = $t019612027._1 | |
97 | 97 | let getFunc3 = $t019612027._2 | |
98 | 98 | let amount_bef_assetIn = getBalance(getAssetBytes(assetIn)) | |
99 | 99 | if ((amount_bef_assetIn == amount_bef_assetIn)) | |
100 | 100 | then { | |
101 | 101 | let new_amountIn = if ((value(parseInt(amountIn)) > amount_bef_assetIn)) | |
102 | 102 | then amount_bef_assetIn | |
103 | 103 | else value(parseInt(amountIn)) | |
104 | - | let amount_bef_asset1 = getBalance(getAssetBytes(a)) | |
105 | - | if ((amount_bef_asset1 == amount_bef_asset1)) | |
104 | + | if ((new_amountIn == new_amountIn)) | |
106 | 105 | then { | |
107 | - | let | |
108 | - | if (( | |
106 | + | let amount_bef_asset1 = getBalance(getAssetBytes(a)) | |
107 | + | if ((amount_bef_asset1 == amount_bef_asset1)) | |
109 | 108 | then { | |
110 | - | let lp1_assetid = fromBase58String(lp1) | |
111 | - | let lpBalance_1 = getBalance(lp1_assetid) | |
112 | - | if ((lpBalance_1 == lpBalance_1)) | |
109 | + | let put1 = invoke(Address(fromBase58String(p1)), putFunc1, [1, false], [AttachedPayment(getAssetBytes(assetIn), new_amountIn)]) | |
110 | + | if ((put1 == put1)) | |
113 | 111 | then { | |
114 | - | let get1 = invoke(Address(fromBase58String(p1)), getFunc1, [a, 1], [AttachedPayment(lp1_assetid, lpBalance_1)]) | |
115 | - | if ((get1 == get1)) | |
112 | + | let lp1_assetid = fromBase58String(lp1) | |
113 | + | let lpBalance_1 = getBalance(lp1_assetid) | |
114 | + | if ((lpBalance_1 == lpBalance_1)) | |
116 | 115 | then { | |
117 | - | let | |
118 | - | if (( | |
116 | + | let get1 = invoke(Address(fromBase58String(p1)), getFunc1, [a, 1], [AttachedPayment(lp1_assetid, lpBalance_1)]) | |
117 | + | if ((get1 == get1)) | |
119 | 118 | then { | |
120 | - | let amount_bef_ | |
121 | - | if (( | |
119 | + | let nb = (getBalance(getAssetBytes(a)) - amount_bef_asset1) | |
120 | + | if ((nb == nb)) | |
122 | 121 | then { | |
123 | - | let | |
124 | - | if (( | |
122 | + | let amount_bef_asset2 = getBalance(getAssetBytes(a2)) | |
123 | + | if ((amount_bef_asset2 == amount_bef_asset2)) | |
125 | 124 | then { | |
126 | - | let lp2_assetid = fromBase58String(lp2) | |
127 | - | let lpBalance_2 = getBalance(lp2_assetid) | |
128 | - | if ((lpBalance_2 == lpBalance_2)) | |
125 | + | let put2 = invoke(Address(fromBase58String(p2)), putFunc2, [1, false], [AttachedPayment(getAssetBytes(a), nb)]) | |
126 | + | if ((put2 == put2)) | |
129 | 127 | then { | |
130 | - | let get2 = invoke(Address(fromBase58String(p2)), getFunc2, [a2, 1], [AttachedPayment(lp2_assetid, lpBalance_2)]) | |
131 | - | if ((get2 == get2)) | |
128 | + | let lp2_assetid = fromBase58String(lp2) | |
129 | + | let lpBalance_2 = getBalance(lp2_assetid) | |
130 | + | if ((lpBalance_2 == lpBalance_2)) | |
132 | 131 | then { | |
133 | - | let | |
134 | - | if (( | |
132 | + | let get2 = invoke(Address(fromBase58String(p2)), getFunc2, [a2, 1], [AttachedPayment(lp2_assetid, lpBalance_2)]) | |
133 | + | if ((get2 == get2)) | |
135 | 134 | then { | |
136 | - | let amount_bef_ | |
137 | - | if (( | |
135 | + | let nb2 = (getBalance(getAssetBytes(a2)) - amount_bef_asset2) | |
136 | + | if ((nb2 == nb2)) | |
138 | 137 | then { | |
139 | - | let | |
140 | - | if (( | |
138 | + | let amount_bef_base_asset = getBalance(getAssetBytes(assetIn)) | |
139 | + | if ((amount_bef_base_asset == amount_bef_base_asset)) | |
141 | 140 | then { | |
142 | - | let lp3_assetid = fromBase58String(lp3) | |
143 | - | let lpBalance_3 = getBalance(lp3_assetid) | |
144 | - | if ((lpBalance_3 == lpBalance_3)) | |
141 | + | let put3 = invoke(Address(fromBase58String(p3)), putFunc3, [1, false], [AttachedPayment(getAssetBytes(a2), nb2)]) | |
142 | + | if ((put3 == put3)) | |
145 | 143 | then { | |
146 | - | let get3 = invoke(Address(fromBase58String(p3)), getFunc3, [assetIn, 1], [AttachedPayment(lp3_assetid, lpBalance_3)]) | |
147 | - | if ((get3 == get3)) | |
144 | + | let lp3_assetid = fromBase58String(lp3) | |
145 | + | let lpBalance_3 = getBalance(lp3_assetid) | |
146 | + | if ((lpBalance_3 == lpBalance_3)) | |
148 | 147 | then { | |
149 | - | let nb3 = (getBalance(getAssetBytes(assetIn)) - amount_bef_base_asset) | |
150 | - | if ((nb3 == nb3)) | |
151 | - | then if ((nb3 > (new_amountIn + 100))) | |
152 | - | then [ScriptTransfer(i.caller, (nb3 - new_amountIn), getAssetBytes(assetIn))] | |
153 | - | else throw(((((((("new_amountIn = " + amountIn) + ", newBal_1: ") + toString(nb)) + ", newBal_2: ") + toString(nb2)) + ", newBal_3: ") + toString(nb3))) | |
148 | + | let get3 = invoke(Address(fromBase58String(p3)), getFunc3, [assetIn, 1], [AttachedPayment(lp3_assetid, lpBalance_3)]) | |
149 | + | if ((get3 == get3)) | |
150 | + | then { | |
151 | + | let nb3 = (getBalance(getAssetBytes(assetIn)) - amount_bef_base_asset) | |
152 | + | if ((nb3 == nb3)) | |
153 | + | then if ((nb3 > (new_amountIn + 100))) | |
154 | + | then [ScriptTransfer(i.caller, (nb3 - new_amountIn), getAssetBytes(assetIn))] | |
155 | + | else throw(((((((("new_amountIn = " + amountIn) + ", newBal_1: ") + toString(nb)) + ", newBal_2: ") + toString(nb2)) + ", newBal_3: ") + toString(nb3))) | |
156 | + | else throw("Strict value is not equal to itself.") | |
157 | + | } | |
154 | 158 | else throw("Strict value is not equal to itself.") | |
155 | 159 | } | |
156 | 160 | else throw("Strict value is not equal to itself.") | |
157 | 161 | } | |
158 | 162 | else throw("Strict value is not equal to itself.") | |
159 | 163 | } | |
160 | 164 | else throw("Strict value is not equal to itself.") | |
161 | 165 | } | |
162 | 166 | else throw("Strict value is not equal to itself.") | |
163 | 167 | } | |
164 | 168 | else throw("Strict value is not equal to itself.") | |
165 | 169 | } | |
166 | 170 | else throw("Strict value is not equal to itself.") | |
167 | 171 | } | |
168 | 172 | else throw("Strict value is not equal to itself.") | |
169 | 173 | } | |
170 | 174 | else throw("Strict value is not equal to itself.") | |
171 | 175 | } | |
172 | 176 | else throw("Strict value is not equal to itself.") | |
173 | 177 | } | |
174 | 178 | else throw("Strict value is not equal to itself.") | |
175 | 179 | } | |
176 | 180 | else throw("Strict value is not equal to itself.") | |
177 | 181 | } | |
178 | 182 | else throw("Strict value is not equal to itself.") | |
179 | 183 | } | |
180 | 184 | else throw("Strict value is not equal to itself.") | |
181 | 185 | } | |
182 | 186 | else throw("Strict value is not equal to itself.") | |
183 | 187 | } | |
184 | 188 | else throw("Strict value is not equal to itself.") | |
185 | 189 | } | |
186 | 190 | ||
187 | 191 | ||
188 | 192 | @Verifier(tx) | |
189 | 193 | func verify () = if (sigVerify_128Kb(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)) | |
190 | 194 | then true | |
191 | 195 | else sigVerify_128Kb(tx.bodyBytes, tx.proofs[0], adminPublicKey) | |
192 | 196 |
github/deemru/w8io/3ef1775 59.01 ms ◑