tx · 9XfY5HBmozGAMw2TN2Pty11z8nv8LAi3yD5uprRQZmrA 3P3qCUfvbDUjRnjrfM5XFMrXrzxxiad94Ez: -0.01000000 Waves 2023.05.17 16:41 [3647457] smart account 3P3qCUfvbDUjRnjrfM5XFMrXrzxxiad94Ez > SELF 0.00000000 Waves
{ "type": 13, "id": "9XfY5HBmozGAMw2TN2Pty11z8nv8LAi3yD5uprRQZmrA", "fee": 1000000, "feeAssetId": null, "timestamp": 1684330877441, "version": 2, "chainId": 87, "sender": "3P3qCUfvbDUjRnjrfM5XFMrXrzxxiad94Ez", "senderPublicKey": "3zaQerEjh4SK1xhin9zzs5qr337aLRFhz7z1ckjFGhMz", "proofs": [ "4kgsCmTBt92rLS99pHhFWUB5eBiyoGaG4TNVzjrdsSAtwanQYyF1na9nkZLxj1RavEkhLKjHvi7tFcd161WiYSsp" ], "script": "base64:BgKyBAgCEgMKAQESAwoBARIDCgEIIg5mcmVlX3RvX2JvcnJvbSINVVNETl9BU1NFVF9JRCIEYm9zcyIOYWRtaW5QdWJsaWNLZXkiDFdYX1NXQVBfREFQUCIJYXNzZXRzX2luIgpnZXRCYWxhbmNlIgdhc3NldElkIgckbWF0Y2gwIgFiIghnZXRCYXNlMSIEZGF0YSIGcF9kYXRhIgFhIgJhMiIHYXNzZXRJbiIIYW1vdW50SW4iCGdldEJhc2UyIgJwMSIBdCINZ2V0QXNzZXRCeXRlcyIHc3dhcF93eCIBcCIFYXNzZXQiACIGYW1vdW50IgRjYWxsIglzd2FwX3N3b3AiBHN3YXAiC3N3YXBfcHV6emxlIghhc3NldE91dCIGdWNoZWNrIgJpZCIBaCIBaSIEYW1udCIKY3VycmVudEJhbCIKZGF0YV9hcnJheSILJHQwMzQzMzM0ODkiCyR0MDM0OTQzNTMyIgJ0MSILJHQwMzUzNzM1NzUiAnAyIgJ0MiILJHQwMzU4MDM2MTgiAnAzIgJ0MyIDaWR1IhJhbW91bnRfYmVmX2Fzc2V0SW4iDG5ld19hbW91bnRJbiIRYW1vdW50X2JlZl9hc3NldDEiBXN3YXAxIgJuYiIRYW1vdW50X2JlZl9hc3NldDIiBXN3YXAyIgNuYjIiFWFtb3VudF9iZWZfYmFzZV9hc3NldCIFc3dhcDMiA25iMyIIdHJlc2hvbGQiAnR4IgZ2ZXJpZnkOAAFhCQERQGV4dHJOYXRpdmUoMTA2MikBAiMzUEc3Q0h2QmF0SHBDaHdtOHJlSDc0d2ZFd2sxUEhjOFJxeQABYgEgtiYpwwT1zlORpA5LdSQvZIxRsfrfr1QpvUjSHSqyqtEAAWMJARFAZXh0ck5hdGl2ZSgxMDYyKQECIzNQUkU1S0g5b1BHZkZQczdmR25RY0o0d05zaEVEVVBHajF0AAFkASCv/x58doefXfwer5+x7Fznjj3iPlshsuAGcU0W/5sVbQABZQkBB0FkZHJlc3MBARoBVy4qNTWxDbfxeT7ht0bQnnRSTXsx0IOuBgABZgkAzAgCAixERzJ4RmtQZER3S1VvQmt6R0FoUXRMcFNHemZYTGlDWVBFemVLSDJBZDI0cAUDbmlsAQFnAQFoBAFpBQFoAwkAAQIFAWkCCkJ5dGVWZWN0b3IEAWoFAWkJAPAHAgUEdGhpcwUBaggJAO8HAQUEdGhpcwlhdmFpbGFibGUBAWsBAWwEAW0JALwJAgUBbAIBXwQBbgkAkQMCBQFtAAAEAW8JAJEDAgUBbQABBAFwCQCRAwIFAWYJAQV2YWx1ZQEJALYJAQkAkQMCBQFtAAIEAXEJAJEDAgUBbQADCQCWCgQFAW4FAW8FAXAFAXEBAXIBAWwEAW0JALUJAgUBbAIBXwQBcwkAkQMCBQFtAAAEAXQJAJEDAgUBbQABCQCUCgIFAXMFAXQBAXUBAWgDCQAAAgUBaAIFV0FWRVMFBHVuaXQJANkEAQUBaAEBdgQBdwF4AXoBbgQBQQkA/AcEBQFlAgRzd2FwCQDMCAIAAQkAzAgCBQFuCQDMCAIJAKUIAQUEdGhpcwUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQEBdQEFAXgFAXoFA25pbAMJAAACBQFBBQFBBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BAUIDAXcBeAF6BAFDCQD8BwQJAQdBZGRyZXNzAQkA2QQBBQF3AghleGNoYW5nZQkAzAgCAAEFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkBAXUBBQF4BQF6BQNuaWwDCQAAAgUBQwUBQwUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQFEBAF3AXgBegFFBAFDCQD8BwQJAQdBZGRyZXNzAQkA2QQBBQF3AgRzd2FwCQDMCAIFAUUJAMwIAgABBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJAQF1AQUBeAUBegUDbmlsAwkAAAIFAUMFAUMFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgEBRgEBRwQBaQkA6QcBBQFHAwkAAQIFAWkCA0ludAQBSAUBaQUBSAAAAwFJAQZib3Jyb3cBAUoDCQEBIQEJAQ9jb250YWluc0VsZW1lbnQCCQDMCAIFAWEJAMwIAgUBYwkAzAgCBQR0aGlzBQNuaWwIBQFJBmNhbGxlcgkAAgECHnlvdSBhcmUgbm90IGFsbG93ZWQgdG8gYm9ycm93IQQBSwkBAWcBBQFiAwkAZgIFAUoFAUsJAAIBAhxZb3UgY2Fubm5vdCBib3Jyb3cgdGhhdCBtdWNoCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFJBmNhbGxlcgUBSgUBYgUDbmlsAUkBC3NldFRyZXNob2xkAQFKAwkBASEBCQEPY29udGFpbnNFbGVtZW50AgkAzAgCBQFhCQDMCAIFAWMJAMwIAgUEdGhpcwUDbmlsCAUBSQZjYWxsZXIJAAIBAh95b3UgYXJlIG5vdCBhbGxvd2VkIHRvIGRvIHRoYXQhCQDMCAIJAQxJbnRlZ2VyRW50cnkCAgh0cmVzaG9sZAUBSgUDbmlsAUkBAXkBAWwDAwkBAiE9AggFAUkGY2FsbGVyBQR0aGlzCQECIT0CCAUBSQZjYWxsZXIFAWMHCQACAQIbeW91IGFyZSBub3QgYWxsb3dlZCB0byBhcmIhBAFMCQC8CQIFAWwCAXwEAU0JAQFrAQkAkQMCBQFMAAAEAW4IBQFNAl8xBAFvCAUBTQJfMgQBcAgFAU0CXzMEAXEIBQFNAl80BAFOCQEBcgEJAJEDAgUBTAABBAFzCAUBTgJfMQQBTwgFAU4CXzIEAVAJAQFyAQkAkQMCBQFMAAIEAVEIBQFQAl8xBAFSCAUBUAJfMgQBUwkBAXIBCQCRAwIFAUwAAwQBVAgFAVMCXzEEAVUIBQFTAl8yBAFWAwkAZgIJALECAQkAkQMCBQFMAAQAAQkAvAkCCQCRAwIFAUwABAIBLQUDbmlsAwMDCQBmAgkAkAMBBQFWAAAJAGYCCQEBRgEJANkEAQkAkQMCBQFWAAAAAAcGCQBnAgABCQCxAgEJAJEDAgUBTAAEBAFXCQEBZwEJAQF1AQUBcAMJAAACBQFXBQFXBAFYAwkAZgIJAQV2YWx1ZQEJALYJAQUBcQUBVwUBVwkBBXZhbHVlAQkAtgkBBQFxAwkAAAIFAVgFAVgEAVkJAQFnAQkBAXUBBQFuAwkAAAIFAVkFAVkEAVoDCQAAAgUBTwIBVwkBAXYEBQFzBQFwBQFYBQFuAwkAAAIFAU8CAVMJAQFCAwUBcwUBcAUBWAkBAUQEBQFzBQFwBQFYBQFuAwkAAAIFAVoFAVoEAmFhCQBlAgkBAWcBCQEBdQEFAW4FAVkDCQAAAgUCYWEFAmFhBAJhYgkBAWcBCQEBdQEFAW8DCQAAAgUCYWIFAmFiBAJhYwMJAAACBQFSAgFXCQEBdgQFAVEFAW4FAmFhBQFvAwkAAAIFAVICAVMJAQFCAwUBUQUBbgUCYWEJAQFEBAUBUQUBbgUCYWEFAW8DCQAAAgUCYWMFAmFjBAJhZAkAZQIJAQFnAQkBAXUBBQFvBQJhYgMJAAACBQJhZAUCYWQEAmFlCQEBZwEJAQF1AQUBcAMJAAACBQJhZQUCYWUEAmFmAwkAAAIFAVUCAVcJAQF2BAUBVAUBbwUCYWQFAXADCQAAAgUBVQIBUwkBAUIDBQFUBQFvBQJhZAkBAUQEBQFUBQFvBQJhZAUBcAMJAAACBQJhZgUCYWYEAmFnCQBlAgkBAWcBCQEBdQEFAXAFAmFlAwkAAAIFAmFnBQJhZwQCYWgJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwIIdHJlc2hvbGQA8JMJAwkAZgIFAmFnCQBkAgUBWAUCYWgJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAUkGY2FsbGVyCQBlAgUCYWcFAVgJAQF1AQUBcAUDbmlsCQACAQkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgISb3JpZ2luIGFtb3VudEluID0gBQFxAhEsIG5ld19hbW91bnRJbiA9IAkApAMBBQFYAgwsIG5ld0JhbF8xOiAJAKQDAQUCYWECDCwgbmV3QmFsXzI6IAkApAMBBQJhZAIMLCBuZXdCYWxfMzogCQCkAwEFAmFnCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuBQNuaWwBAmFpAQJhagADCQDIEwMIBQJhaQlib2R5Qnl0ZXMJAJEDAggFAmFpBnByb29mcwAACAUCYWkPc2VuZGVyUHVibGljS2V5BgkAyBMDCAUCYWkJYm9keUJ5dGVzCQCRAwIIBQJhaQZwcm9vZnMAAAUBZO7XlTU=", "height": 3647457, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: H8HH31pmcwgAD87pa5sTUBqBmoYc6U3oyxL1UZ7bngGJ Next: GWVK25QaqWovGAgHhDoZqrdTC149bXD18DPKAascV4zf Diff:
Old | New | Differences | |
---|---|---|---|
12 | 12 | let WX_SWAP_DAPP = Address(base58'3P68zNiufsu1viZpu1aY3cdahRRKcvV5N93') | |
13 | 13 | ||
14 | 14 | let assets_in = ["DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p"] | |
15 | - | ||
16 | - | let blacklisted_generators = ["3PA1KvFfq9VuJjg45p2ytGgaNjrgnLSgf4r", "3P23fi1qfVw6RVDn4CH2a5nNouEtWNQ4THs"] | |
17 | - | ||
18 | - | func check_generator (h) = match blockInfoByHeight(h) { | |
19 | - | case block: BlockInfo => | |
20 | - | toString(block.generator) | |
21 | - | case _ => | |
22 | - | throw("Can't find block") | |
23 | - | } | |
24 | - | ||
25 | 15 | ||
26 | 16 | func getBalance (assetId) = match assetId { | |
27 | 17 | case b: ByteVector => | |
111 | 101 | else false) | |
112 | 102 | then throw("you are not allowed to arb!") | |
113 | 103 | else { | |
114 | - | let current_generator = check_generator(height) | |
115 | - | if (containsElement(blacklisted_generators, current_generator)) | |
116 | - | then throw("..I..") | |
117 | - | else { | |
118 | - | let data_array = split_4C(data, "|") | |
119 | - | let $t034303486 = getBase1(data_array[0]) | |
120 | - | let a = $t034303486._1 | |
121 | - | let a2 = $t034303486._2 | |
122 | - | let assetIn = $t034303486._3 | |
123 | - | let amountIn = $t034303486._4 | |
124 | - | let $t034913529 = getBase2(data_array[1]) | |
125 | - | let p1 = $t034913529._1 | |
126 | - | let t1 = $t034913529._2 | |
127 | - | let $t035343572 = getBase2(data_array[2]) | |
128 | - | let p2 = $t035343572._1 | |
129 | - | let t2 = $t035343572._2 | |
130 | - | let $t035773615 = getBase2(data_array[3]) | |
131 | - | let p3 = $t035773615._1 | |
132 | - | let t3 = $t035773615._2 | |
133 | - | let idu = if ((size(data_array[4]) > 1)) | |
134 | - | then split_4C(data_array[4], "-") | |
135 | - | else nil | |
136 | - | if (if (if ((size(idu) > 0)) | |
137 | - | then (ucheck(fromBase58String(idu[0])) > 0) | |
138 | - | else false) | |
139 | - | then true | |
140 | - | else (1 >= size(data_array[4]))) | |
104 | + | let data_array = split_4C(data, "|") | |
105 | + | let $t034333489 = getBase1(data_array[0]) | |
106 | + | let a = $t034333489._1 | |
107 | + | let a2 = $t034333489._2 | |
108 | + | let assetIn = $t034333489._3 | |
109 | + | let amountIn = $t034333489._4 | |
110 | + | let $t034943532 = getBase2(data_array[1]) | |
111 | + | let p1 = $t034943532._1 | |
112 | + | let t1 = $t034943532._2 | |
113 | + | let $t035373575 = getBase2(data_array[2]) | |
114 | + | let p2 = $t035373575._1 | |
115 | + | let t2 = $t035373575._2 | |
116 | + | let $t035803618 = getBase2(data_array[3]) | |
117 | + | let p3 = $t035803618._1 | |
118 | + | let t3 = $t035803618._2 | |
119 | + | let idu = if ((size(data_array[4]) > 1)) | |
120 | + | then split_4C(data_array[4], "-") | |
121 | + | else nil | |
122 | + | if (if (if ((size(idu) > 0)) | |
123 | + | then (ucheck(fromBase58String(idu[0])) > 0) | |
124 | + | else false) | |
125 | + | then true | |
126 | + | else (1 >= size(data_array[4]))) | |
127 | + | then { | |
128 | + | let amount_bef_assetIn = getBalance(getAssetBytes(assetIn)) | |
129 | + | if ((amount_bef_assetIn == amount_bef_assetIn)) | |
141 | 130 | then { | |
142 | - | let amount_bef_assetIn = getBalance(getAssetBytes(assetIn)) | |
143 | - | if ((amount_bef_assetIn == amount_bef_assetIn)) | |
131 | + | let new_amountIn = if ((value(parseInt(amountIn)) > amount_bef_assetIn)) | |
132 | + | then amount_bef_assetIn | |
133 | + | else value(parseInt(amountIn)) | |
134 | + | if ((new_amountIn == new_amountIn)) | |
144 | 135 | then { | |
145 | - | let new_amountIn = if ((value(parseInt(amountIn)) > amount_bef_assetIn)) | |
146 | - | then amount_bef_assetIn | |
147 | - | else value(parseInt(amountIn)) | |
148 | - | if ((new_amountIn == new_amountIn)) | |
136 | + | let amount_bef_asset1 = getBalance(getAssetBytes(a)) | |
137 | + | if ((amount_bef_asset1 == amount_bef_asset1)) | |
149 | 138 | then { | |
150 | - | let amount_bef_asset1 = getBalance(getAssetBytes(a)) | |
151 | - | if ((amount_bef_asset1 == amount_bef_asset1)) | |
139 | + | let swap1 = if ((t1 == "W")) | |
140 | + | then swap_wx(p1, assetIn, new_amountIn, a) | |
141 | + | else if ((t1 == "S")) | |
142 | + | then swap_swop(p1, assetIn, new_amountIn) | |
143 | + | else swap_puzzle(p1, assetIn, new_amountIn, a) | |
144 | + | if ((swap1 == swap1)) | |
152 | 145 | then { | |
153 | - | let swap1 = if ((t1 == "W")) | |
154 | - | then swap_wx(p1, assetIn, new_amountIn, a) | |
155 | - | else if ((t1 == "S")) | |
156 | - | then swap_swop(p1, assetIn, new_amountIn) | |
157 | - | else swap_puzzle(p1, assetIn, new_amountIn, a) | |
158 | - | if ((swap1 == swap1)) | |
146 | + | let nb = (getBalance(getAssetBytes(a)) - amount_bef_asset1) | |
147 | + | if ((nb == nb)) | |
159 | 148 | then { | |
160 | - | let | |
161 | - | if (( | |
149 | + | let amount_bef_asset2 = getBalance(getAssetBytes(a2)) | |
150 | + | if ((amount_bef_asset2 == amount_bef_asset2)) | |
162 | 151 | then { | |
163 | - | let amount_bef_asset2 = getBalance(getAssetBytes(a2)) | |
164 | - | if ((amount_bef_asset2 == amount_bef_asset2)) | |
152 | + | let swap2 = if ((t2 == "W")) | |
153 | + | then swap_wx(p2, a, nb, a2) | |
154 | + | else if ((t2 == "S")) | |
155 | + | then swap_swop(p2, a, nb) | |
156 | + | else swap_puzzle(p2, a, nb, a2) | |
157 | + | if ((swap2 == swap2)) | |
165 | 158 | then { | |
166 | - | let swap2 = if ((t2 == "W")) | |
167 | - | then swap_wx(p2, a, nb, a2) | |
168 | - | else if ((t2 == "S")) | |
169 | - | then swap_swop(p2, a, nb) | |
170 | - | else swap_puzzle(p2, a, nb, a2) | |
171 | - | if ((swap2 == swap2)) | |
159 | + | let nb2 = (getBalance(getAssetBytes(a2)) - amount_bef_asset2) | |
160 | + | if ((nb2 == nb2)) | |
172 | 161 | then { | |
173 | - | let | |
174 | - | if (( | |
162 | + | let amount_bef_base_asset = getBalance(getAssetBytes(assetIn)) | |
163 | + | if ((amount_bef_base_asset == amount_bef_base_asset)) | |
175 | 164 | then { | |
176 | - | let amount_bef_base_asset = getBalance(getAssetBytes(assetIn)) | |
177 | - | if ((amount_bef_base_asset == amount_bef_base_asset)) | |
165 | + | let swap3 = if ((t3 == "W")) | |
166 | + | then swap_wx(p3, a2, nb2, assetIn) | |
167 | + | else if ((t3 == "S")) | |
168 | + | then swap_swop(p3, a2, nb2) | |
169 | + | else swap_puzzle(p3, a2, nb2, assetIn) | |
170 | + | if ((swap3 == swap3)) | |
178 | 171 | then { | |
179 | - | let swap3 = if ((t3 == "W")) | |
180 | - | then swap_wx(p3, a2, nb2, assetIn) | |
181 | - | else if ((t3 == "S")) | |
182 | - | then swap_swop(p3, a2, nb2) | |
183 | - | else swap_puzzle(p3, a2, nb2, assetIn) | |
184 | - | if ((swap3 == swap3)) | |
172 | + | let nb3 = (getBalance(getAssetBytes(assetIn)) - amount_bef_base_asset) | |
173 | + | if ((nb3 == nb3)) | |
185 | 174 | then { | |
186 | - | let nb3 = (getBalance(getAssetBytes(assetIn)) - amount_bef_base_asset) | |
187 | - | if ((nb3 == nb3)) | |
188 | - | then { | |
189 | - | let treshold = valueOrElse(getInteger(this, "treshold"), 150000) | |
190 | - | if ((nb3 > (new_amountIn + treshold))) | |
191 | - | then [ScriptTransfer(i.caller, (nb3 - new_amountIn), getAssetBytes(assetIn))] | |
192 | - | else throw(((((((((("origin amountIn = " + amountIn) + ", new_amountIn = ") + toString(new_amountIn)) + ", newBal_1: ") + toString(nb)) + ", newBal_2: ") + toString(nb2)) + ", newBal_3: ") + toString(nb3))) | |
193 | - | } | |
194 | - | else throw("Strict value is not equal to itself.") | |
175 | + | let treshold = valueOrElse(getInteger(this, "treshold"), 150000) | |
176 | + | if ((nb3 > (new_amountIn + treshold))) | |
177 | + | then [ScriptTransfer(i.caller, (nb3 - new_amountIn), getAssetBytes(assetIn))] | |
178 | + | else throw(((((((((("origin amountIn = " + amountIn) + ", new_amountIn = ") + toString(new_amountIn)) + ", newBal_1: ") + toString(nb)) + ", newBal_2: ") + toString(nb2)) + ", newBal_3: ") + toString(nb3))) | |
195 | 179 | } | |
196 | 180 | else throw("Strict value is not equal to itself.") | |
197 | 181 | } | |
213 | 197 | } | |
214 | 198 | else throw("Strict value is not equal to itself.") | |
215 | 199 | } | |
216 | - | else | |
200 | + | else throw("Strict value is not equal to itself.") | |
217 | 201 | } | |
202 | + | else nil | |
218 | 203 | } | |
219 | 204 | ||
220 | 205 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let free_to_borrom = addressFromStringValue("3PG7CHvBatHpChwm8reH74wfEwk1PHc8Rqy") | |
5 | 5 | ||
6 | 6 | let USDN_ASSET_ID = base58'DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p' | |
7 | 7 | ||
8 | 8 | let boss = addressFromStringValue("3PRE5KH9oPGfFPs7fGnQcJ4wNshEDUPGj1t") | |
9 | 9 | ||
10 | 10 | let adminPublicKey = base58'Cr1ybL2JGg9GwJHA2JwqxBPfSW6Q7Jg4HvNrsEiCsHu6' | |
11 | 11 | ||
12 | 12 | let WX_SWAP_DAPP = Address(base58'3P68zNiufsu1viZpu1aY3cdahRRKcvV5N93') | |
13 | 13 | ||
14 | 14 | let assets_in = ["DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p"] | |
15 | - | ||
16 | - | let blacklisted_generators = ["3PA1KvFfq9VuJjg45p2ytGgaNjrgnLSgf4r", "3P23fi1qfVw6RVDn4CH2a5nNouEtWNQ4THs"] | |
17 | - | ||
18 | - | func check_generator (h) = match blockInfoByHeight(h) { | |
19 | - | case block: BlockInfo => | |
20 | - | toString(block.generator) | |
21 | - | case _ => | |
22 | - | throw("Can't find block") | |
23 | - | } | |
24 | - | ||
25 | 15 | ||
26 | 16 | func getBalance (assetId) = match assetId { | |
27 | 17 | case b: ByteVector => | |
28 | 18 | assetBalance(this, b) | |
29 | 19 | case _ => | |
30 | 20 | wavesBalance(this).available | |
31 | 21 | } | |
32 | 22 | ||
33 | 23 | ||
34 | 24 | func getBase1 (data) = { | |
35 | 25 | let p_data = split_4C(data, "_") | |
36 | 26 | let a = p_data[0] | |
37 | 27 | let a2 = p_data[1] | |
38 | 28 | let assetIn = assets_in[value(parseInt(p_data[2]))] | |
39 | 29 | let amountIn = p_data[3] | |
40 | 30 | $Tuple4(a, a2, assetIn, amountIn) | |
41 | 31 | } | |
42 | 32 | ||
43 | 33 | ||
44 | 34 | func getBase2 (data) = { | |
45 | 35 | let p_data = split(data, "_") | |
46 | 36 | let p1 = p_data[0] | |
47 | 37 | let t = p_data[1] | |
48 | 38 | $Tuple2(p1, t) | |
49 | 39 | } | |
50 | 40 | ||
51 | 41 | ||
52 | 42 | func getAssetBytes (assetId) = if ((assetId == "WAVES")) | |
53 | 43 | then unit | |
54 | 44 | else fromBase58String(assetId) | |
55 | 45 | ||
56 | 46 | ||
57 | 47 | func swap_wx (p,asset,amount,a) = { | |
58 | 48 | let call = invoke(WX_SWAP_DAPP, "swap", [1, a, toString(this)], [AttachedPayment(getAssetBytes(asset), amount)]) | |
59 | 49 | if ((call == call)) | |
60 | 50 | then nil | |
61 | 51 | else throw("Strict value is not equal to itself.") | |
62 | 52 | } | |
63 | 53 | ||
64 | 54 | ||
65 | 55 | func swap_swop (p,asset,amount) = { | |
66 | 56 | let swap = invoke(Address(fromBase58String(p)), "exchange", [1], [AttachedPayment(getAssetBytes(asset), amount)]) | |
67 | 57 | if ((swap == swap)) | |
68 | 58 | then nil | |
69 | 59 | else throw("Strict value is not equal to itself.") | |
70 | 60 | } | |
71 | 61 | ||
72 | 62 | ||
73 | 63 | func swap_puzzle (p,asset,amount,assetOut) = { | |
74 | 64 | let swap = invoke(Address(fromBase58String(p)), "swap", [assetOut, 1], [AttachedPayment(getAssetBytes(asset), amount)]) | |
75 | 65 | if ((swap == swap)) | |
76 | 66 | then nil | |
77 | 67 | else throw("Strict value is not equal to itself.") | |
78 | 68 | } | |
79 | 69 | ||
80 | 70 | ||
81 | 71 | func ucheck (id) = match transactionHeightById(id) { | |
82 | 72 | case h: Int => | |
83 | 73 | h | |
84 | 74 | case _ => | |
85 | 75 | 0 | |
86 | 76 | } | |
87 | 77 | ||
88 | 78 | ||
89 | 79 | @Callable(i) | |
90 | 80 | func borrow (amnt) = if (!(containsElement([free_to_borrom, boss, this], i.caller))) | |
91 | 81 | then throw("you are not allowed to borrow!") | |
92 | 82 | else { | |
93 | 83 | let currentBal = getBalance(USDN_ASSET_ID) | |
94 | 84 | if ((amnt > currentBal)) | |
95 | 85 | then throw("You cannnot borrow that much") | |
96 | 86 | else [ScriptTransfer(i.caller, amnt, USDN_ASSET_ID)] | |
97 | 87 | } | |
98 | 88 | ||
99 | 89 | ||
100 | 90 | ||
101 | 91 | @Callable(i) | |
102 | 92 | func setTreshold (amnt) = if (!(containsElement([free_to_borrom, boss, this], i.caller))) | |
103 | 93 | then throw("you are not allowed to do that!") | |
104 | 94 | else [IntegerEntry("treshold", amnt)] | |
105 | 95 | ||
106 | 96 | ||
107 | 97 | ||
108 | 98 | @Callable(i) | |
109 | 99 | func y (data) = if (if ((i.caller != this)) | |
110 | 100 | then (i.caller != boss) | |
111 | 101 | else false) | |
112 | 102 | then throw("you are not allowed to arb!") | |
113 | 103 | else { | |
114 | - | let current_generator = check_generator(height) | |
115 | - | if (containsElement(blacklisted_generators, current_generator)) | |
116 | - | then throw("..I..") | |
117 | - | else { | |
118 | - | let data_array = split_4C(data, "|") | |
119 | - | let $t034303486 = getBase1(data_array[0]) | |
120 | - | let a = $t034303486._1 | |
121 | - | let a2 = $t034303486._2 | |
122 | - | let assetIn = $t034303486._3 | |
123 | - | let amountIn = $t034303486._4 | |
124 | - | let $t034913529 = getBase2(data_array[1]) | |
125 | - | let p1 = $t034913529._1 | |
126 | - | let t1 = $t034913529._2 | |
127 | - | let $t035343572 = getBase2(data_array[2]) | |
128 | - | let p2 = $t035343572._1 | |
129 | - | let t2 = $t035343572._2 | |
130 | - | let $t035773615 = getBase2(data_array[3]) | |
131 | - | let p3 = $t035773615._1 | |
132 | - | let t3 = $t035773615._2 | |
133 | - | let idu = if ((size(data_array[4]) > 1)) | |
134 | - | then split_4C(data_array[4], "-") | |
135 | - | else nil | |
136 | - | if (if (if ((size(idu) > 0)) | |
137 | - | then (ucheck(fromBase58String(idu[0])) > 0) | |
138 | - | else false) | |
139 | - | then true | |
140 | - | else (1 >= size(data_array[4]))) | |
104 | + | let data_array = split_4C(data, "|") | |
105 | + | let $t034333489 = getBase1(data_array[0]) | |
106 | + | let a = $t034333489._1 | |
107 | + | let a2 = $t034333489._2 | |
108 | + | let assetIn = $t034333489._3 | |
109 | + | let amountIn = $t034333489._4 | |
110 | + | let $t034943532 = getBase2(data_array[1]) | |
111 | + | let p1 = $t034943532._1 | |
112 | + | let t1 = $t034943532._2 | |
113 | + | let $t035373575 = getBase2(data_array[2]) | |
114 | + | let p2 = $t035373575._1 | |
115 | + | let t2 = $t035373575._2 | |
116 | + | let $t035803618 = getBase2(data_array[3]) | |
117 | + | let p3 = $t035803618._1 | |
118 | + | let t3 = $t035803618._2 | |
119 | + | let idu = if ((size(data_array[4]) > 1)) | |
120 | + | then split_4C(data_array[4], "-") | |
121 | + | else nil | |
122 | + | if (if (if ((size(idu) > 0)) | |
123 | + | then (ucheck(fromBase58String(idu[0])) > 0) | |
124 | + | else false) | |
125 | + | then true | |
126 | + | else (1 >= size(data_array[4]))) | |
127 | + | then { | |
128 | + | let amount_bef_assetIn = getBalance(getAssetBytes(assetIn)) | |
129 | + | if ((amount_bef_assetIn == amount_bef_assetIn)) | |
141 | 130 | then { | |
142 | - | let amount_bef_assetIn = getBalance(getAssetBytes(assetIn)) | |
143 | - | if ((amount_bef_assetIn == amount_bef_assetIn)) | |
131 | + | let new_amountIn = if ((value(parseInt(amountIn)) > amount_bef_assetIn)) | |
132 | + | then amount_bef_assetIn | |
133 | + | else value(parseInt(amountIn)) | |
134 | + | if ((new_amountIn == new_amountIn)) | |
144 | 135 | then { | |
145 | - | let new_amountIn = if ((value(parseInt(amountIn)) > amount_bef_assetIn)) | |
146 | - | then amount_bef_assetIn | |
147 | - | else value(parseInt(amountIn)) | |
148 | - | if ((new_amountIn == new_amountIn)) | |
136 | + | let amount_bef_asset1 = getBalance(getAssetBytes(a)) | |
137 | + | if ((amount_bef_asset1 == amount_bef_asset1)) | |
149 | 138 | then { | |
150 | - | let amount_bef_asset1 = getBalance(getAssetBytes(a)) | |
151 | - | if ((amount_bef_asset1 == amount_bef_asset1)) | |
139 | + | let swap1 = if ((t1 == "W")) | |
140 | + | then swap_wx(p1, assetIn, new_amountIn, a) | |
141 | + | else if ((t1 == "S")) | |
142 | + | then swap_swop(p1, assetIn, new_amountIn) | |
143 | + | else swap_puzzle(p1, assetIn, new_amountIn, a) | |
144 | + | if ((swap1 == swap1)) | |
152 | 145 | then { | |
153 | - | let swap1 = if ((t1 == "W")) | |
154 | - | then swap_wx(p1, assetIn, new_amountIn, a) | |
155 | - | else if ((t1 == "S")) | |
156 | - | then swap_swop(p1, assetIn, new_amountIn) | |
157 | - | else swap_puzzle(p1, assetIn, new_amountIn, a) | |
158 | - | if ((swap1 == swap1)) | |
146 | + | let nb = (getBalance(getAssetBytes(a)) - amount_bef_asset1) | |
147 | + | if ((nb == nb)) | |
159 | 148 | then { | |
160 | - | let | |
161 | - | if (( | |
149 | + | let amount_bef_asset2 = getBalance(getAssetBytes(a2)) | |
150 | + | if ((amount_bef_asset2 == amount_bef_asset2)) | |
162 | 151 | then { | |
163 | - | let amount_bef_asset2 = getBalance(getAssetBytes(a2)) | |
164 | - | if ((amount_bef_asset2 == amount_bef_asset2)) | |
152 | + | let swap2 = if ((t2 == "W")) | |
153 | + | then swap_wx(p2, a, nb, a2) | |
154 | + | else if ((t2 == "S")) | |
155 | + | then swap_swop(p2, a, nb) | |
156 | + | else swap_puzzle(p2, a, nb, a2) | |
157 | + | if ((swap2 == swap2)) | |
165 | 158 | then { | |
166 | - | let swap2 = if ((t2 == "W")) | |
167 | - | then swap_wx(p2, a, nb, a2) | |
168 | - | else if ((t2 == "S")) | |
169 | - | then swap_swop(p2, a, nb) | |
170 | - | else swap_puzzle(p2, a, nb, a2) | |
171 | - | if ((swap2 == swap2)) | |
159 | + | let nb2 = (getBalance(getAssetBytes(a2)) - amount_bef_asset2) | |
160 | + | if ((nb2 == nb2)) | |
172 | 161 | then { | |
173 | - | let | |
174 | - | if (( | |
162 | + | let amount_bef_base_asset = getBalance(getAssetBytes(assetIn)) | |
163 | + | if ((amount_bef_base_asset == amount_bef_base_asset)) | |
175 | 164 | then { | |
176 | - | let amount_bef_base_asset = getBalance(getAssetBytes(assetIn)) | |
177 | - | if ((amount_bef_base_asset == amount_bef_base_asset)) | |
165 | + | let swap3 = if ((t3 == "W")) | |
166 | + | then swap_wx(p3, a2, nb2, assetIn) | |
167 | + | else if ((t3 == "S")) | |
168 | + | then swap_swop(p3, a2, nb2) | |
169 | + | else swap_puzzle(p3, a2, nb2, assetIn) | |
170 | + | if ((swap3 == swap3)) | |
178 | 171 | then { | |
179 | - | let swap3 = if ((t3 == "W")) | |
180 | - | then swap_wx(p3, a2, nb2, assetIn) | |
181 | - | else if ((t3 == "S")) | |
182 | - | then swap_swop(p3, a2, nb2) | |
183 | - | else swap_puzzle(p3, a2, nb2, assetIn) | |
184 | - | if ((swap3 == swap3)) | |
172 | + | let nb3 = (getBalance(getAssetBytes(assetIn)) - amount_bef_base_asset) | |
173 | + | if ((nb3 == nb3)) | |
185 | 174 | then { | |
186 | - | let nb3 = (getBalance(getAssetBytes(assetIn)) - amount_bef_base_asset) | |
187 | - | if ((nb3 == nb3)) | |
188 | - | then { | |
189 | - | let treshold = valueOrElse(getInteger(this, "treshold"), 150000) | |
190 | - | if ((nb3 > (new_amountIn + treshold))) | |
191 | - | then [ScriptTransfer(i.caller, (nb3 - new_amountIn), getAssetBytes(assetIn))] | |
192 | - | else throw(((((((((("origin amountIn = " + amountIn) + ", new_amountIn = ") + toString(new_amountIn)) + ", newBal_1: ") + toString(nb)) + ", newBal_2: ") + toString(nb2)) + ", newBal_3: ") + toString(nb3))) | |
193 | - | } | |
194 | - | else throw("Strict value is not equal to itself.") | |
175 | + | let treshold = valueOrElse(getInteger(this, "treshold"), 150000) | |
176 | + | if ((nb3 > (new_amountIn + treshold))) | |
177 | + | then [ScriptTransfer(i.caller, (nb3 - new_amountIn), getAssetBytes(assetIn))] | |
178 | + | else throw(((((((((("origin amountIn = " + amountIn) + ", new_amountIn = ") + toString(new_amountIn)) + ", newBal_1: ") + toString(nb)) + ", newBal_2: ") + toString(nb2)) + ", newBal_3: ") + toString(nb3))) | |
195 | 179 | } | |
196 | 180 | else throw("Strict value is not equal to itself.") | |
197 | 181 | } | |
198 | 182 | else throw("Strict value is not equal to itself.") | |
199 | 183 | } | |
200 | 184 | else throw("Strict value is not equal to itself.") | |
201 | 185 | } | |
202 | 186 | else throw("Strict value is not equal to itself.") | |
203 | 187 | } | |
204 | 188 | else throw("Strict value is not equal to itself.") | |
205 | 189 | } | |
206 | 190 | else throw("Strict value is not equal to itself.") | |
207 | 191 | } | |
208 | 192 | else throw("Strict value is not equal to itself.") | |
209 | 193 | } | |
210 | 194 | else throw("Strict value is not equal to itself.") | |
211 | 195 | } | |
212 | 196 | else throw("Strict value is not equal to itself.") | |
213 | 197 | } | |
214 | 198 | else throw("Strict value is not equal to itself.") | |
215 | 199 | } | |
216 | - | else | |
200 | + | else throw("Strict value is not equal to itself.") | |
217 | 201 | } | |
202 | + | else nil | |
218 | 203 | } | |
219 | 204 | ||
220 | 205 | ||
221 | 206 | @Verifier(tx) | |
222 | 207 | func verify () = if (sigVerify_128Kb(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)) | |
223 | 208 | then true | |
224 | 209 | else sigVerify_128Kb(tx.bodyBytes, tx.proofs[0], adminPublicKey) | |
225 | 210 |
github/deemru/w8io/3ef1775 50.28 ms ◑