tx · CmgfveUTAkgppt9vgHqbXeD5pMHGG81sPPp7xFqt9D7r 3P3qCUfvbDUjRnjrfM5XFMrXrzxxiad94Ez: -0.01000000 Waves 2023.02.06 19:11 [3503550] smart account 3P3qCUfvbDUjRnjrfM5XFMrXrzxxiad94Ez > SELF 0.00000000 Waves
{ "type": 13, "id": "CmgfveUTAkgppt9vgHqbXeD5pMHGG81sPPp7xFqt9D7r", "fee": 1000000, "feeAssetId": null, "timestamp": 1675699915559, "version": 2, "chainId": 87, "sender": "3P3qCUfvbDUjRnjrfM5XFMrXrzxxiad94Ez", "senderPublicKey": "3zaQerEjh4SK1xhin9zzs5qr337aLRFhz7z1ckjFGhMz", "proofs": [ "e299jVuS6K9vZRX8rt2Ca2WPaJyyJYDRBiUbhSpTHBKiy9oXLsQXog3J6botSAFxmLrCSmccUrhKEtagHsieLrd" ], "script": "base64:BgLoBAgCEgMKAQESBAoCCAgSAwoBCCIEYm9zcyIOYWRtaW5QdWJsaWNLZXkiCWdldFB1dEdldCIJaXNfc3RhYmxlIgdwdXRGdW5jIgdnZXRGdW5jIgpnZXRCYWxhbmNlIgdhc3NldElkIgckbWF0Y2gwIgFiIghnZXRCYXNlMSIEZGF0YSIGcF9kYXRhIgFhIgJhMiIHYXNzZXRJbiIIYW1vdW50SW4iCGdldEJhc2UyIgJwMSIDbHAxIgtpc19zdGFibGVfMSIBaSIDa2V5IgN2YWwiCmRhdGFfYXJyYXkiCyR0MDE0ODIxNTM4IgskdDAxNTQzMTU5NSILJHQwMTYwMDE2NTIiAnAyIgNscDIiC2lzX3N0YWJsZV8yIgskdDAxNjU3MTcwOSICcDMiA2xwMyILaXNfc3RhYmxlXzMiCyR0MDE3MTUxNzgxIghwdXRGdW5jMSIIZ2V0RnVuYzEiCyR0MDE3ODYxODUyIghwdXRGdW5jMiIIZ2V0RnVuYzIiCyR0MDE4NTcyMjMxIghwdXRGdW5jMyIIZ2V0RnVuYzMiEWFtb3VudF9iZWZfYXNzZXQxIgRwdXQxIgtscDFfYXNzZXRpZCILbHBCYWxhbmNlXzEiBGdldDEiAm5iIhFhbW91bnRfYmVmX2Fzc2V0MiIEcHV0MiILbHAyX2Fzc2V0aWQiC2xwQmFsYW5jZV8yIgRnZXQyIgNuYjIiFWFtb3VudF9iZWZfYmFzZV9hc3NldCIEcHV0MyILbHAzX2Fzc2V0aWQiC2xwQmFsYW5jZV8zIgRnZXQzIgNuYjMiAnR4IgZ2ZXJpZnkGAAFhCQERQGV4dHJOYXRpdmUoMTA2MikBAiMzUFJFNUtIOW9QR2ZGUHM3ZkduUWNKNHdOc2hFRFVQR2oxdAABYgEgr/8efHaHn138Hq+fsexc54494j5bIbLgBnFNFv+bFW0BAWMBAWQEAWUDCQAAAgUBZAABAgtwdXRPbmVUa25WMgIJcHV0T25lVGtuBAFmAwkAAAIFAWQAAQILZ2V0T25lVGtuVjICCWdldE9uZVRrbgkAlAoCBQFlBQFmAQFnAQFoBAFpBQFoAwkAAQIFAWkCCkJ5dGVWZWN0b3IEAWoFAWkJAPAHAgUEdGhpcwUBaggJAO8HAQUEdGhpcwlhdmFpbGFibGUBAWsBAWwEAW0JALUJAgUBbAIBXwQBbgkAkQMCBQFtAAAEAW8JAJEDAgUBbQABBAFwCQCRAwIFAW0AAgQBcQkAkQMCBQFtAAMJAJYKBAUBbgUBbwUBcAUBcQEBcgEBbAQBbQkAtQkCBQFsAgFfBAFzCQCRAwIFAW0AAAQBdAkAkQMCBQFtAAEEAXUJAJEDAgUBbQACCQCVCgMFAXMFAXQFAXUDAXYBCHNldEFtb3V0AQFuAwkBAiE9AggFAXYGY2FsbGVyBQR0aGlzCQACAQIbeW91IGFyZSBub3QgYWxsb3dlZCB0byBzZXQhCQDMCAIJAQxJbnRlZ2VyRW50cnkCAgdtb250YW50BQFuBQNuaWwBdgEPc2V0S2V5VmFsU3RyaW5nAgF3AXgDCQECIT0CCAUBdgZjYWxsZXIFBHRoaXMJAAIBAht5b3UgYXJlIG5vdCBhbGxvd2VkIHRvIHNldCEJAMwIAgkBC1N0cmluZ0VudHJ5AgUBdwUBeAUDbmlsAXYBAncyAQFsAwMJAQIhPQIIBQF2BmNhbGxlcgUEdGhpcwkBAiE9AggFAXYGY2FsbGVyBQFhBwkAAgECG3lvdSBhcmUgbm90IGFsbG93ZWQgdG8gYXJiIQQBeQkAvAkCBQFsAgF8BAF6CQEBawEJAJEDAgUBeQAABAFuCAUBegJfMQQBbwgFAXoCXzIEAXAIBQF6Al8zBAFxCAUBegJfNAQBQQkBAXIBCQCRAwIFAXkAAQQBcwgFAUECXzEEAXQIBQFBAl8yBAF1CAUBQQJfMwQBQgkBAXIBCQCRAwIFAXkAAgQBQwgFAUICXzEEAUQIBQFCAl8yBAFFCAUBQgJfMwQBRgkBAXIBCQCRAwIFAXkAAwQBRwgFAUYCXzEEAUgIBQFGAl8yBAFJCAUBRgJfMwQBSgkBAWMBCQEFdmFsdWUBCQC2CQEFAXUEAUsIBQFKAl8xBAFMCAUBSgJfMgQBTQkBAWMBCQEFdmFsdWUBCQC2CQEFAUUEAU4IBQFNAl8xBAFPCAUBTQJfMgQBUAkBAWMBCQEFdmFsdWUBCQC2CQEFAUkEAVEIBQFQAl8xBAFSCAUBUAJfMgQBUwkBAWcBCQDZBAEFAW4DCQAAAgUBUwUBUwQBVAkA/AcECQEHQWRkcmVzcwEJANkEAQUBcwUBSwkAzAgCAAEJAMwIAgcFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgMJAAACBQFwAgVXQVZFUwUEdW5pdAkA2QQBBQFwCQEFdmFsdWUBCQC2CQEFAXEFA25pbAMJAAACBQFUBQFUBAFVCQDZBAEFAXQEAVYJAQFnAQUBVQMJAAACBQFWBQFWBAFXCQD8BwQJAQdBZGRyZXNzAQkA2QQBBQFzBQFMCQDMCAIFAW4JAMwIAgABBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFAVUFAVYFA25pbAMJAAACBQFXBQFXBAFYCQBlAgkBAWcBCQDZBAEFAW4FAVMDCQAAAgUBWAUBWAQBWQkBAWcBCQDZBAEFAW8DCQAAAgUBWQUBWQQBWgkA/AcECQEHQWRkcmVzcwEJANkEAQUBQwUBTgkAzAgCAAEJAMwIAgcFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgMJAAACBQFuAgVXQVZFUwUEdW5pdAkA2QQBBQFuBQFYBQNuaWwDCQAAAgUBWgUBWgQCYWEJANkEAQUBRAQCYWIJAQFnAQUCYWEDCQAAAgUCYWIFAmFiBAJhYwkA/AcECQEHQWRkcmVzcwEJANkEAQUBQwUBTwkAzAgCBQFvCQDMCAIAAQUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQJhYQUCYWIFA25pbAMJAAACBQJhYwUCYWMEAmFkCQBlAgkBAWcBCQDZBAEFAW8FAVkDCQAAAgUCYWQFAmFkBAJhZQkBAWcBCQDZBAEFAXADCQAAAgUCYWUFAmFlBAJhZgkA/AcECQEHQWRkcmVzcwEJANkEAQUBRwUBUgkAzAgCAAEJAMwIAgcFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgMJAAACBQFvAgVXQVZFUwUEdW5pdAkA2QQBBQFvBQJhZAUDbmlsAwkAAAIFAmFmBQJhZgQCYWcJANkEAQUBSAQCYWgJAQFnAQUCYWcDCQAAAgUCYWgFAmFoBAJhaQkA/AcECQEHQWRkcmVzcwEJANkEAQUBRwUBUgkAzAgCBQFwCQDMCAIAAQUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQJhZwUCYWgFA25pbAMJAAACBQJhaQUCYWkEAmFqCQBlAgkBAWcBCQDZBAEFAXAFAmFlAwkAAAIFAmFqBQJhagMGCQACAQkApAMBBQJhagMJAGYCBQJhagBkCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQF2BmNhbGxlcgUCYWoJANkEAQUBcAUDbmlsCQACAQkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAgthbW91bnRJbiA9IAUBcQIMLCBuZXdCYWxfMTogCQCkAwEFAVgCDCwgbmV3QmFsXzI6IAkApAMBBQJhZAIMLCBuZXdCYWxfMzogCQCkAwEFAmFqCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJhawECYWwAAwkAyBMDCAUCYWsJYm9keUJ5dGVzCQCRAwIIBQJhawZwcm9vZnMAAAgFAmFrD3NlbmRlclB1YmxpY0tleQYJAMgTAwgFAmFrCWJvZHlCeXRlcwkAkQMCCAUCYWsGcHJvb2ZzAAAFAWKrBUp6", "height": 3503550, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: AVedHQ9kNNaFeNTanfA6SC2dbR4q6YrAp5Be8gRRhTzp Next: HJJTokyYMcRdfqRZAzmyxh9WbbUZppuGyCoMVnEovCVF Diff:
Old | New | Differences | |
---|---|---|---|
93 | 93 | let amount_bef_asset1 = getBalance(fromBase58String(a)) | |
94 | 94 | if ((amount_bef_asset1 == amount_bef_asset1)) | |
95 | 95 | then { | |
96 | - | let put1 = invoke(Address(fromBase58String(p1)), putFunc1, [1, false], [AttachedPayment(fromBase58String(assetIn), value(parseInt(amountIn)))]) | |
96 | + | let put1 = invoke(Address(fromBase58String(p1)), putFunc1, [1, false], [AttachedPayment(if ((assetIn == "WAVES")) | |
97 | + | then unit | |
98 | + | else fromBase58String(assetIn), value(parseInt(amountIn)))]) | |
97 | 99 | if ((put1 == put1)) | |
98 | 100 | then { | |
99 | 101 | let lp1_assetid = fromBase58String(lp1) | |
109 | 111 | let amount_bef_asset2 = getBalance(fromBase58String(a2)) | |
110 | 112 | if ((amount_bef_asset2 == amount_bef_asset2)) | |
111 | 113 | then { | |
112 | - | let put2 = invoke(Address(fromBase58String(p2)), putFunc2, [1, false], [AttachedPayment(fromBase58String(a), nb)]) | |
114 | + | let put2 = invoke(Address(fromBase58String(p2)), putFunc2, [1, false], [AttachedPayment(if ((a == "WAVES")) | |
115 | + | then unit | |
116 | + | else fromBase58String(a), nb)]) | |
113 | 117 | if ((put2 == put2)) | |
114 | 118 | then { | |
115 | 119 | let lp2_assetid = fromBase58String(lp2) | |
125 | 129 | let amount_bef_base_asset = getBalance(fromBase58String(assetIn)) | |
126 | 130 | if ((amount_bef_base_asset == amount_bef_base_asset)) | |
127 | 131 | then { | |
128 | - | let put3 = invoke(Address(fromBase58String(p3)), getFunc3, [1, false], [AttachedPayment(fromBase58String(a2), nb2)]) | |
132 | + | let put3 = invoke(Address(fromBase58String(p3)), getFunc3, [1, false], [AttachedPayment(if ((a2 == "WAVES")) | |
133 | + | then unit | |
134 | + | else fromBase58String(a2), nb2)]) | |
129 | 135 | if ((put3 == put3)) | |
130 | 136 | then { | |
131 | 137 | let lp3_assetid = fromBase58String(lp3) | |
132 | 138 | let lpBalance_3 = getBalance(lp3_assetid) | |
133 | 139 | if ((lpBalance_3 == lpBalance_3)) | |
134 | - | then if (true) | |
135 | - | 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)) | |
136 | - | else { | |
137 | - | let get3 = invoke(Address(fromBase58String(p3)), getFunc3, [assetIn, 1], [AttachedPayment(lp3_assetid, lpBalance_3)]) | |
138 | - | if ((get3 == get3)) | |
139 | - | then { | |
140 | - | let nb3 = (getBalance(fromBase58String(assetIn)) - amount_bef_base_asset) | |
141 | - | if ((nb3 == nb3)) | |
142 | - | then if (true) | |
143 | - | then throw(toString(nb3)) | |
144 | - | else if ((nb3 > 100)) | |
145 | - | then [ScriptTransfer(i.caller, nb3, fromBase58String(assetIn))] | |
146 | - | else throw(((((((("amountIn = " + amountIn) + ", newBal_1: ") + toString(nb)) + ", newBal_2: ") + toString(nb2)) + ", newBal_3: ") + toString(nb3))) | |
147 | - | else throw("Strict value is not equal to itself.") | |
148 | - | } | |
149 | - | else throw("Strict value is not equal to itself.") | |
150 | - | } | |
140 | + | then { | |
141 | + | let get3 = invoke(Address(fromBase58String(p3)), getFunc3, [assetIn, 1], [AttachedPayment(lp3_assetid, lpBalance_3)]) | |
142 | + | if ((get3 == get3)) | |
143 | + | then { | |
144 | + | let nb3 = (getBalance(fromBase58String(assetIn)) - amount_bef_base_asset) | |
145 | + | if ((nb3 == nb3)) | |
146 | + | then if (true) | |
147 | + | then throw(toString(nb3)) | |
148 | + | else if ((nb3 > 100)) | |
149 | + | then [ScriptTransfer(i.caller, nb3, fromBase58String(assetIn))] | |
150 | + | else throw(((((((("amountIn = " + amountIn) + ", newBal_1: ") + toString(nb)) + ", newBal_2: ") + toString(nb2)) + ", newBal_3: ") + toString(nb3))) | |
151 | + | else throw("Strict value is not equal to itself.") | |
152 | + | } | |
153 | + | else throw("Strict value is not equal to itself.") | |
154 | + | } | |
151 | 155 | else throw("Strict value is not equal to itself.") | |
152 | 156 | } | |
153 | 157 | 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 | @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 $t018572231 = getPutGet(value(parseInt(is_stable_3))) | |
91 | 91 | let putFunc3 = $t018572231._1 | |
92 | 92 | let getFunc3 = $t018572231._2 | |
93 | 93 | let amount_bef_asset1 = getBalance(fromBase58String(a)) | |
94 | 94 | if ((amount_bef_asset1 == amount_bef_asset1)) | |
95 | 95 | then { | |
96 | - | let put1 = invoke(Address(fromBase58String(p1)), putFunc1, [1, false], [AttachedPayment(fromBase58String(assetIn), value(parseInt(amountIn)))]) | |
96 | + | let put1 = invoke(Address(fromBase58String(p1)), putFunc1, [1, false], [AttachedPayment(if ((assetIn == "WAVES")) | |
97 | + | then unit | |
98 | + | else fromBase58String(assetIn), value(parseInt(amountIn)))]) | |
97 | 99 | if ((put1 == put1)) | |
98 | 100 | then { | |
99 | 101 | let lp1_assetid = fromBase58String(lp1) | |
100 | 102 | let lpBalance_1 = getBalance(lp1_assetid) | |
101 | 103 | if ((lpBalance_1 == lpBalance_1)) | |
102 | 104 | then { | |
103 | 105 | let get1 = invoke(Address(fromBase58String(p1)), getFunc1, [a, 1], [AttachedPayment(lp1_assetid, lpBalance_1)]) | |
104 | 106 | if ((get1 == get1)) | |
105 | 107 | then { | |
106 | 108 | let nb = (getBalance(fromBase58String(a)) - amount_bef_asset1) | |
107 | 109 | if ((nb == nb)) | |
108 | 110 | then { | |
109 | 111 | let amount_bef_asset2 = getBalance(fromBase58String(a2)) | |
110 | 112 | if ((amount_bef_asset2 == amount_bef_asset2)) | |
111 | 113 | then { | |
112 | - | let put2 = invoke(Address(fromBase58String(p2)), putFunc2, [1, false], [AttachedPayment(fromBase58String(a), nb)]) | |
114 | + | let put2 = invoke(Address(fromBase58String(p2)), putFunc2, [1, false], [AttachedPayment(if ((a == "WAVES")) | |
115 | + | then unit | |
116 | + | else fromBase58String(a), nb)]) | |
113 | 117 | if ((put2 == put2)) | |
114 | 118 | then { | |
115 | 119 | let lp2_assetid = fromBase58String(lp2) | |
116 | 120 | let lpBalance_2 = getBalance(lp2_assetid) | |
117 | 121 | if ((lpBalance_2 == lpBalance_2)) | |
118 | 122 | then { | |
119 | 123 | let get2 = invoke(Address(fromBase58String(p2)), getFunc2, [a2, 1], [AttachedPayment(lp2_assetid, lpBalance_2)]) | |
120 | 124 | if ((get2 == get2)) | |
121 | 125 | then { | |
122 | 126 | let nb2 = (getBalance(fromBase58String(a2)) - amount_bef_asset2) | |
123 | 127 | if ((nb2 == nb2)) | |
124 | 128 | then { | |
125 | 129 | let amount_bef_base_asset = getBalance(fromBase58String(assetIn)) | |
126 | 130 | if ((amount_bef_base_asset == amount_bef_base_asset)) | |
127 | 131 | then { | |
128 | - | let put3 = invoke(Address(fromBase58String(p3)), getFunc3, [1, false], [AttachedPayment(fromBase58String(a2), nb2)]) | |
132 | + | let put3 = invoke(Address(fromBase58String(p3)), getFunc3, [1, false], [AttachedPayment(if ((a2 == "WAVES")) | |
133 | + | then unit | |
134 | + | else fromBase58String(a2), nb2)]) | |
129 | 135 | if ((put3 == put3)) | |
130 | 136 | then { | |
131 | 137 | let lp3_assetid = fromBase58String(lp3) | |
132 | 138 | let lpBalance_3 = getBalance(lp3_assetid) | |
133 | 139 | if ((lpBalance_3 == lpBalance_3)) | |
134 | - | then if (true) | |
135 | - | 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)) | |
136 | - | else { | |
137 | - | let get3 = invoke(Address(fromBase58String(p3)), getFunc3, [assetIn, 1], [AttachedPayment(lp3_assetid, lpBalance_3)]) | |
138 | - | if ((get3 == get3)) | |
139 | - | then { | |
140 | - | let nb3 = (getBalance(fromBase58String(assetIn)) - amount_bef_base_asset) | |
141 | - | if ((nb3 == nb3)) | |
142 | - | then if (true) | |
143 | - | then throw(toString(nb3)) | |
144 | - | else if ((nb3 > 100)) | |
145 | - | then [ScriptTransfer(i.caller, nb3, fromBase58String(assetIn))] | |
146 | - | else throw(((((((("amountIn = " + amountIn) + ", newBal_1: ") + toString(nb)) + ", newBal_2: ") + toString(nb2)) + ", newBal_3: ") + toString(nb3))) | |
147 | - | else throw("Strict value is not equal to itself.") | |
148 | - | } | |
149 | - | else throw("Strict value is not equal to itself.") | |
150 | - | } | |
140 | + | then { | |
141 | + | let get3 = invoke(Address(fromBase58String(p3)), getFunc3, [assetIn, 1], [AttachedPayment(lp3_assetid, lpBalance_3)]) | |
142 | + | if ((get3 == get3)) | |
143 | + | then { | |
144 | + | let nb3 = (getBalance(fromBase58String(assetIn)) - amount_bef_base_asset) | |
145 | + | if ((nb3 == nb3)) | |
146 | + | then if (true) | |
147 | + | then throw(toString(nb3)) | |
148 | + | else if ((nb3 > 100)) | |
149 | + | then [ScriptTransfer(i.caller, nb3, fromBase58String(assetIn))] | |
150 | + | else throw(((((((("amountIn = " + amountIn) + ", newBal_1: ") + toString(nb)) + ", newBal_2: ") + toString(nb2)) + ", newBal_3: ") + toString(nb3))) | |
151 | + | else throw("Strict value is not equal to itself.") | |
152 | + | } | |
153 | + | else throw("Strict value is not equal to itself.") | |
154 | + | } | |
151 | 155 | else throw("Strict value is not equal to itself.") | |
152 | 156 | } | |
153 | 157 | else throw("Strict value is not equal to itself.") | |
154 | 158 | } | |
155 | 159 | else throw("Strict value is not equal to itself.") | |
156 | 160 | } | |
157 | 161 | else throw("Strict value is not equal to itself.") | |
158 | 162 | } | |
159 | 163 | else throw("Strict value is not equal to itself.") | |
160 | 164 | } | |
161 | 165 | else throw("Strict value is not equal to itself.") | |
162 | 166 | } | |
163 | 167 | else throw("Strict value is not equal to itself.") | |
164 | 168 | } | |
165 | 169 | else throw("Strict value is not equal to itself.") | |
166 | 170 | } | |
167 | 171 | else throw("Strict value is not equal to itself.") | |
168 | 172 | } | |
169 | 173 | else throw("Strict value is not equal to itself.") | |
170 | 174 | } | |
171 | 175 | else throw("Strict value is not equal to itself.") | |
172 | 176 | } | |
173 | 177 | else throw("Strict value is not equal to itself.") | |
174 | 178 | } | |
175 | 179 | else throw("Strict value is not equal to itself.") | |
176 | 180 | } | |
177 | 181 | ||
178 | 182 | ||
179 | 183 | @Verifier(tx) | |
180 | 184 | func verify () = if (sigVerify_128Kb(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)) | |
181 | 185 | then true | |
182 | 186 | else sigVerify_128Kb(tx.bodyBytes, tx.proofs[0], adminPublicKey) | |
183 | 187 |
github/deemru/w8io/3ef1775 70.86 ms ◑