tx · DdEJRFzxpRx4tA46mbGapGbrcLHV3GEs8wYpADiackLa 3N7psESThHV5T7gjWF2DLjztWtrhTF6FR3b: -0.03400000 Waves 2023.03.04 14:14 [2475234] smart account 3N7psESThHV5T7gjWF2DLjztWtrhTF6FR3b > SELF 0.00000000 Waves
{ "type": 13, "id": "DdEJRFzxpRx4tA46mbGapGbrcLHV3GEs8wYpADiackLa", "fee": 3400000, "feeAssetId": null, "timestamp": 1677928568204, "version": 2, "chainId": 84, "sender": "3N7psESThHV5T7gjWF2DLjztWtrhTF6FR3b", "senderPublicKey": "AgUKubvVDHDimcoQ6a6GnnzKdymyp2NYJRnjDFhiyM4e", "proofs": [ "iX5PbGW4Se99K8mL3k51ts4DgAeLAYV5883GgVuvKx4o29gnSWYPTU1PnBJfPckg19qqeHVTJs7e6ERmJz9Muho" ], "script": "base64:BgIdCAISBgoECAgICBIECgIIARIFCgMICAgSBAoCCAgJAA1rX2luaXRpYWxpemVkAg1rX2luaXRpYWxpemVkABRrX2Nvb3JkaW5hdG9yQWRkcmVzcwIUa19jb29yZGluYXRvckFkZHJlc3MAD2tfYWRtaW5fYWRkcmVzcwIPa19hZG1pbl9hZGRyZXNzAAhrX21hcmtldAIIa19tYXJrZXQBDGdldE1hcmtldEtleQIFX2Zyb20DX3RvCQCsAgIJAKwCAgkArAICCQCsAgIFCGtfbWFya2V0AgFfBQVfZnJvbQIBXwUDX3RvAQtjb29yZGluYXRvcgAJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwUUa19jb29yZGluYXRvckFkZHJlc3MCGENvb3JkaW5hdG9yIG5vdCBzZXQgU3dhcAIbQ29vcmRpbmF0b3IgYWRkcmVzcyBpbnZhbGlkAQxhZG1pbkFkZHJlc3MACQCmCAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCCQELY29vcmRpbmF0b3IABQ9rX2FkbWluX2FkZHJlc3MCFUFkbWluIGFkZHJlc3Mgbm90IHNldAELaW5pdGlhbGl6ZWQACQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMFDWtfaW5pdGlhbGl6ZWQHAQlnZXRNYXJrZXQCBV9mcm9tA190bwQDa2V5CQEMZ2V0TWFya2V0S2V5AgUFX2Zyb20FA190bwQIZnJvbU5hbWUICQEFdmFsdWUBCQDsBwEJANkEAQUFX2Zyb20EbmFtZQQGdG9OYW1lCAkBBXZhbHVlAQkA7AcBCQDZBAEFA190bwRuYW1lBAllcnJvckRlc2MJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUFX2Zyb20CAiBbBQhmcm9tTmFtZQIFXSAtPiAFA190bwICIFsFBnRvTmFtZQIBXQQKYWRkcmVzc1N0cgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMFA2tleQkArAICAhRObyBtYXJrZXQgZm9yIHN3YXA6IAUJZXJyb3JEZXNjCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQUKYWRkcmVzc1N0cgkArAICAiFJbnZhbGlkIG1hcmtldCBhZGRyZXNzIGZvciBzd2FwOiAFCWVycm9yRGVzYwQBaQEKaW5pdGlhbGl6ZQQMX2Nvb3JkaW5hdG9yC19mcm9tQXNzZXRzCV90b0Fzc2V0cwhfbWFya2V0cwMDCQELaW5pdGlhbGl6ZWQABgkBAiE9AggFAWkGY2FsbGVyBQR0aGlzCQACAQIUVW5hYmxlIHRvIGluaXRpYWxpemUECmZyb21Bc3NldHMJALUJAgULX2Zyb21Bc3NldHMCASwECHRvQXNzZXRzCQC1CQIFCV90b0Fzc2V0cwIBLAQHbWFya2V0cwkAtQkCBQhfbWFya2V0cwIBLAMDAwkBAiE9AgkAkAMBBQpmcm9tQXNzZXRzCQCQAwEFCHRvQXNzZXRzBgkBAiE9AgkAkAMBBQpmcm9tQXNzZXRzCQCQAwEFB21hcmtldHMGCQBmAgkAkAMBBQpmcm9tQXNzZXRzAAUJAAIBAi5VbmFibGUgdG8gaW5pdGlhbGl6ZTogaW52YWxpZCBhc3NldHMgLyBtYXJrZXRzCgEGaGFuZGxlAgRfYWNjBF9pZHgDCQBnAgUEX2lkeAkAkAMBBQpmcm9tQXNzZXRzBQRfYWNjBARmcm9tCQCRAwIFCmZyb21Bc3NldHMFBF9pZHgEAnRvCQCRAwIFCHRvQXNzZXRzBQRfaWR4BAZtYXJrZXQJAJEDAgUHbWFya2V0cwUEX2lkeAMDAwkAAAIFBGZyb20CAAYJAAACBQJ0bwIABgkBASEBCQEJaXNEZWZpbmVkAQkApggBBQZtYXJrZXQJAAIBCQCsAgICGUludmFsaWQgbWFya2V0IGF0IGluZGV4OiAJAKQDAQUEX2lkeAkAzggCBQRfYWNjCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQxnZXRNYXJrZXRLZXkCBQRmcm9tBQJ0bwUGbWFya2V0BQNuaWwED2RvQWRkQWxsTWFya2V0cwoAAiRsCQDMCAIAAAkAzAgCAAEJAMwIAgACCQDMCAIAAwkAzAgCAAQFA25pbAoAAiRzCQCQAwEFAiRsCgAFJGFjYzAFA25pbAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEGaGFuZGxlAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhNMaXN0IHNpemUgZXhjZWVkcyA1CQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQkAzggCCQDMCAIJAQtTdHJpbmdFbnRyeQIFFGtfY29vcmRpbmF0b3JBZGRyZXNzCQClCAEJARFAZXh0ck5hdGl2ZSgxMDYyKQEFDF9jb29yZGluYXRvcgkAzAgCCQEMQm9vbGVhbkVudHJ5AgUNa19pbml0aWFsaXplZAYFA25pbAUPZG9BZGRBbGxNYXJrZXRzAWkBBHN3YXACA190bwlfZXhwZWN0ZWQDAwMJAQEhAQkBC2luaXRpYWxpemVkAAYJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAQYJAGYCAAAFCV9leHBlY3RlZAkAAgECIkludmFsaWQgc3dhcCBwYXJhbXM6IHBheW1lbnQgY291bnQEB2Fzc2V0SWQICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAQEZnJvbQMJAQlpc0RlZmluZWQBBQdhc3NldElkCQDYBAEJAQV2YWx1ZQEFB2Fzc2V0SWQCBVdBVkVTBAZtYXJrZXQJAQlnZXRNYXJrZXQCBQRmcm9tBQNfdG8EEGFtb3VudEJlZm9yZVN3YXAJAPAHAgUEdGhpcwkA2QQBBQNfdG8DCQAAAgUQYW1vdW50QmVmb3JlU3dhcAUQYW1vdW50QmVmb3JlU3dhcAQGZG9Td2FwCQD8BwQFBm1hcmtldAIEc3dhcAkAzAgCBQNfdG8JAMwIAgUJX2V4cGVjdGVkBQNuaWwIBQFpCHBheW1lbnRzAwkAAAIFBmRvU3dhcAUGZG9Td2FwBA9hbW91bnRBZnRlclN3YXAJAPAHAgUEdGhpcwkA2QQBBQNfdG8DCQAAAgUPYW1vdW50QWZ0ZXJTd2FwBQ9hbW91bnRBZnRlclN3YXAEBWRlbHRhCQBlAgUPYW1vdW50QWZ0ZXJTd2FwBRBhbW91bnRCZWZvcmVTd2FwAwkAAAIFBWRlbHRhBQVkZWx0YQkAlAoCCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgUFZGVsdGEJANkEAQUDX3RvBQNuaWwFBWRlbHRhCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBCWFkZE1hcmtldAMFX2Zyb20DX3RvB19tYXJrZXQDAwMDAwMJAQIhPQIIBQFpBmNhbGxlcgkBDGFkbWluQWRkcmVzcwAJAQIhPQIIBQFpBmNhbGxlcgUEdGhpcwcGCQEBIQEJAQtpbml0aWFsaXplZAAGCQAAAgUFX2Zyb20CAAYJAAACBQNfdG8CAAYJAQEhAQkBCWlzRGVmaW5lZAEJAKYIAQUHX21hcmtldAkAAgECGEludmFsaWQgYWRkTWFya2V0IHBhcmFtcwkAzAgCCQELU3RyaW5nRW50cnkCCQEMZ2V0TWFya2V0S2V5AgUFX2Zyb20FA190bwUHX21hcmtldAUDbmlsAWkBDHJlbW92ZU1hcmtldAIFX2Zyb20DX3RvAwMDAwkBAiE9AggFAWkGY2FsbGVyCQEMYWRtaW5BZGRyZXNzAAYJAQEhAQkBC2luaXRpYWxpemVkAAYJAAACBQVfZnJvbQIABgkAAAIFA190bwIACQACAQIYSW52YWxpZCBhZGRNYXJrZXQgcGFyYW1zCQDMCAIJAQtEZWxldGVFbnRyeQEJAQxnZXRNYXJrZXRLZXkCBQVfZnJvbQUDX3RvBQNuaWwBAnR4AQZ2ZXJpZnkABA5jb29yZGluYXRvclN0cgkAnQgCBQR0aGlzBRRrX2Nvb3JkaW5hdG9yQWRkcmVzcwMJAQlpc0RlZmluZWQBBQ5jb29yZGluYXRvclN0cgQFYWRtaW4JAJ0IAgkBEUBleHRyTmF0aXZlKDEwNjIpAQkBBXZhbHVlAQUOY29vcmRpbmF0b3JTdHIFD2tfYWRtaW5fYWRkcmVzcwMJAQlpc0RlZmluZWQBBQVhZG1pbgkBC3ZhbHVlT3JFbHNlAgkAmwgCCQERQGV4dHJOYXRpdmUoMTA2MikBCQEFdmFsdWUBBQVhZG1pbgkArAICCQCsAgIJAKwCAgIHc3RhdHVzXwkApQgBBQR0aGlzAgFfCQDYBAEIBQJ0eAJpZAcJAAIBAi51bmFibGUgdG8gdmVyaWZ5OiBhZG1pbiBub3Qgc2V0IGluIGNvb3JkaW5hdG9yCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAACAUCdHgPc2VuZGVyUHVibGljS2V5ReNzdg==", "height": 2475234, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: none Next: 2jEweJXuiYX5zdXrsxjPp6Y7ub6HcqHtev8tiaS7QgoR Full:
Old | New | Differences | |
---|---|---|---|
1 | - | # no script | |
1 | + | {-# STDLIB_VERSION 6 #-} | |
2 | + | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | + | {-# CONTENT_TYPE DAPP #-} | |
4 | + | let k_initialized = "k_initialized" | |
5 | + | ||
6 | + | let k_coordinatorAddress = "k_coordinatorAddress" | |
7 | + | ||
8 | + | let k_admin_address = "k_admin_address" | |
9 | + | ||
10 | + | let k_market = "k_market" | |
11 | + | ||
12 | + | func getMarketKey (_from,_to) = ((((k_market + "_") + _from) + "_") + _to) | |
13 | + | ||
14 | + | ||
15 | + | func coordinator () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, k_coordinatorAddress), "Coordinator not set Swap")), "Coordinator address invalid") | |
16 | + | ||
17 | + | ||
18 | + | func adminAddress () = addressFromString(valueOrErrorMessage(getString(coordinator(), k_admin_address), "Admin address not set")) | |
19 | + | ||
20 | + | ||
21 | + | func initialized () = valueOrElse(getBoolean(this, k_initialized), false) | |
22 | + | ||
23 | + | ||
24 | + | func getMarket (_from,_to) = { | |
25 | + | let key = getMarketKey(_from, _to) | |
26 | + | let fromName = value(assetInfo(fromBase58String(_from))).name | |
27 | + | let toName = value(assetInfo(fromBase58String(_to))).name | |
28 | + | let errorDesc = (((((((_from + " [") + fromName) + "] -> ") + _to) + " [") + toName) + "]") | |
29 | + | let addressStr = valueOrErrorMessage(getString(this, key), ("No market for swap: " + errorDesc)) | |
30 | + | valueOrErrorMessage(addressFromString(addressStr), ("Invalid market address for swap: " + errorDesc)) | |
31 | + | } | |
32 | + | ||
33 | + | ||
34 | + | @Callable(i) | |
35 | + | func initialize (_coordinator,_fromAssets,_toAssets,_markets) = if (if (initialized()) | |
36 | + | then true | |
37 | + | else (i.caller != this)) | |
38 | + | then throw("Unable to initialize") | |
39 | + | else { | |
40 | + | let fromAssets = split(_fromAssets, ",") | |
41 | + | let toAssets = split(_toAssets, ",") | |
42 | + | let markets = split(_markets, ",") | |
43 | + | if (if (if ((size(fromAssets) != size(toAssets))) | |
44 | + | then true | |
45 | + | else (size(fromAssets) != size(markets))) | |
46 | + | then true | |
47 | + | else (size(fromAssets) > 5)) | |
48 | + | then throw("Unable to initialize: invalid assets / markets") | |
49 | + | else { | |
50 | + | func handle (_acc,_idx) = if ((_idx >= size(fromAssets))) | |
51 | + | then _acc | |
52 | + | else { | |
53 | + | let from = fromAssets[_idx] | |
54 | + | let to = toAssets[_idx] | |
55 | + | let market = markets[_idx] | |
56 | + | if (if (if ((from == "")) | |
57 | + | then true | |
58 | + | else (to == "")) | |
59 | + | then true | |
60 | + | else !(isDefined(addressFromString(market)))) | |
61 | + | then throw(("Invalid market at index: " + toString(_idx))) | |
62 | + | else (_acc ++ [StringEntry(getMarketKey(from, to), market)]) | |
63 | + | } | |
64 | + | ||
65 | + | let doAddAllMarkets = { | |
66 | + | let $l = [0, 1, 2, 3, 4] | |
67 | + | let $s = size($l) | |
68 | + | let $acc0 = nil | |
69 | + | func $f0_1 ($a,$i) = if (($i >= $s)) | |
70 | + | then $a | |
71 | + | else handle($a, $l[$i]) | |
72 | + | ||
73 | + | func $f0_2 ($a,$i) = if (($i >= $s)) | |
74 | + | then $a | |
75 | + | else throw("List size exceeds 5") | |
76 | + | ||
77 | + | $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5) | |
78 | + | } | |
79 | + | ([StringEntry(k_coordinatorAddress, toString(addressFromStringValue(_coordinator))), BooleanEntry(k_initialized, true)] ++ doAddAllMarkets) | |
80 | + | } | |
81 | + | } | |
82 | + | ||
83 | + | ||
84 | + | ||
85 | + | @Callable(i) | |
86 | + | func swap (_to,_expected) = if (if (if (!(initialized())) | |
87 | + | then true | |
88 | + | else (size(i.payments) != 1)) | |
89 | + | then true | |
90 | + | else (0 > _expected)) | |
91 | + | then throw("Invalid swap params: payment count") | |
92 | + | else { | |
93 | + | let assetId = i.payments[0].assetId | |
94 | + | let from = if (isDefined(assetId)) | |
95 | + | then toBase58String(value(assetId)) | |
96 | + | else "WAVES" | |
97 | + | let market = getMarket(from, _to) | |
98 | + | let amountBeforeSwap = assetBalance(this, fromBase58String(_to)) | |
99 | + | if ((amountBeforeSwap == amountBeforeSwap)) | |
100 | + | then { | |
101 | + | let doSwap = invoke(market, "swap", [_to, _expected], i.payments) | |
102 | + | if ((doSwap == doSwap)) | |
103 | + | then { | |
104 | + | let amountAfterSwap = assetBalance(this, fromBase58String(_to)) | |
105 | + | if ((amountAfterSwap == amountAfterSwap)) | |
106 | + | then { | |
107 | + | let delta = (amountAfterSwap - amountBeforeSwap) | |
108 | + | if ((delta == delta)) | |
109 | + | then $Tuple2([ScriptTransfer(i.caller, delta, fromBase58String(_to))], delta) | |
110 | + | else throw("Strict value is not equal to itself.") | |
111 | + | } | |
112 | + | else throw("Strict value is not equal to itself.") | |
113 | + | } | |
114 | + | else throw("Strict value is not equal to itself.") | |
115 | + | } | |
116 | + | else throw("Strict value is not equal to itself.") | |
117 | + | } | |
118 | + | ||
119 | + | ||
120 | + | ||
121 | + | @Callable(i) | |
122 | + | func addMarket (_from,_to,_market) = if (if (if (if (if (if ((i.caller != adminAddress())) | |
123 | + | then (i.caller != this) | |
124 | + | else false) | |
125 | + | then true | |
126 | + | else !(initialized())) | |
127 | + | then true | |
128 | + | else (_from == "")) | |
129 | + | then true | |
130 | + | else (_to == "")) | |
131 | + | then true | |
132 | + | else !(isDefined(addressFromString(_market)))) | |
133 | + | then throw("Invalid addMarket params") | |
134 | + | else [StringEntry(getMarketKey(_from, _to), _market)] | |
135 | + | ||
136 | + | ||
137 | + | ||
138 | + | @Callable(i) | |
139 | + | func removeMarket (_from,_to) = if (if (if (if ((i.caller != adminAddress())) | |
140 | + | then true | |
141 | + | else !(initialized())) | |
142 | + | then true | |
143 | + | else (_from == "")) | |
144 | + | then true | |
145 | + | else (_to == "")) | |
146 | + | then throw("Invalid addMarket params") | |
147 | + | else [DeleteEntry(getMarketKey(_from, _to))] | |
148 | + | ||
149 | + | ||
150 | + | @Verifier(tx) | |
151 | + | func verify () = { | |
152 | + | let coordinatorStr = getString(this, k_coordinatorAddress) | |
153 | + | if (isDefined(coordinatorStr)) | |
154 | + | then { | |
155 | + | let admin = getString(addressFromStringValue(value(coordinatorStr)), k_admin_address) | |
156 | + | if (isDefined(admin)) | |
157 | + | then valueOrElse(getBoolean(addressFromStringValue(value(admin)), ((("status_" + toString(this)) + "_") + toBase58String(tx.id))), false) | |
158 | + | else throw("unable to verify: admin not set in coordinator") | |
159 | + | } | |
160 | + | else sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
161 | + | } | |
162 | + |
github/deemru/w8io/03bedc9 17.79 ms ◑