tx · AWCT2y1W1AWX5PvSkp7Kv9i4w9qrTiYmM2a8Daeh3UGM 3MzhpxAKSeCcAYnwEQzd4v8xhuxEa7H79mA: -0.03700000 Waves 2022.11.10 12:43 [2310887] smart account 3MzhpxAKSeCcAYnwEQzd4v8xhuxEa7H79mA > SELF 0.00000000 Waves
{ "type": 13, "id": "AWCT2y1W1AWX5PvSkp7Kv9i4w9qrTiYmM2a8Daeh3UGM", "fee": 3700000, "feeAssetId": null, "timestamp": 1668073460109, "version": 2, "chainId": 84, "sender": "3MzhpxAKSeCcAYnwEQzd4v8xhuxEa7H79mA", "senderPublicKey": "A4jJoT1GfErs6Zq9p6jQrT43kuzivydaycZfLbuBCAhq", "proofs": [ "498p8VCA5ihKeyJfNwLYY2zqvGQbvDtsmmuaB48XX2f7YQvo8y5XTwMdqeMCr6vsCTk9bFkXQNxUtkSRMjA2KRhP" ], "script": "base64:BgIQCAISAwoBCBIDCgEBEgASABYAC2tfaW5zdXJhbmNlAgtrX2luc3VyYW5jZQAUa19jb29yZGluYXRvckFkZHJlc3MCFGtfY29vcmRpbmF0b3JBZGRyZXNzAAVrX2FtbQIFa19hbW0AD2tfYWRtaW5fYWRkcmVzcwIPa19hZG1pbl9hZGRyZXNzABJrX2FkbWluX3B1YmxpY19rZXkCEmtfYWRtaW5fcHVibGljX2tleQANa19xdW90ZV9hc3NldAINa19xdW90ZV9hc3NldAAPa19xdW90ZV9zdGFraW5nAg9rX3F1b3RlX3N0YWtpbmcAEWtfbWFuYWdlcl9hZGRyZXNzAhFrX21hbmFnZXJfYWRkcmVzcwAUa19jb2xsYXRlcmFsX2FkZHJlc3MCFGtfY29sbGF0ZXJhbF9hZGRyZXNzAA1rX2luaXRpYWxpemVkAg1rX2luaXRpYWxpemVkAQ50b0NvbXBvc2l0ZUtleQIEX2tleQhfYWRkcmVzcwkArAICCQCsAgIFBF9rZXkCAV8FCF9hZGRyZXNzAQlpbnN1cmFuY2UACQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMFC2tfaW5zdXJhbmNlAAABC2Nvb3JkaW5hdG9yAAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzBRRrX2Nvb3JkaW5hdG9yQWRkcmVzcwITQ29vcmRpbmF0b3Igbm90IHNldAITQ29vcmRpbmF0b3Igbm90IHNldAELaXNXaGl0ZWxpc3QBCF9hZGRyZXNzCQELdmFsdWVPckVsc2UCCQCbCAIJAQtjb29yZGluYXRvcgAJAQ50b0NvbXBvc2l0ZUtleQIFBWtfYW1tBQhfYWRkcmVzcwcBC2luaXRpYWxpemVkAAkBC3ZhbHVlT3JFbHNlAgkAmwgCBQR0aGlzBQ1rX2luaXRpYWxpemVkBwEMYWRtaW5BZGRyZXNzAAkApggBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgkBC2Nvb3JkaW5hdG9yAAUPa19hZG1pbl9hZGRyZXNzAhVBZG1pbiBhZGRyZXNzIG5vdCBzZXQBDmFkbWluUHVibGljS2V5AAkA2QQBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgkBC2Nvb3JkaW5hdG9yAAUSa19hZG1pbl9wdWJsaWNfa2V5AhhBZG1pbiBwdWJsaWMga2V5IG5vdCBzZXQBCnF1b3RlQXNzZXQACQDZBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCCQELY29vcmRpbmF0b3IABQ1rX3F1b3RlX2Fzc2V0AhNRdW90ZSBhc3NldCBub3Qgc2V0ARFxdW90ZUFzc2V0U3Rha2luZwAJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgkBC2Nvb3JkaW5hdG9yAAUPa19xdW90ZV9zdGFraW5nAhtRdW90ZSBhc3NldCBzdGFraW5nIG5vdCBzZXQCG1F1b3RlIGFzc2V0IHN0YWtpbmcgbm90IHNldAEObWFuYWdlckFkZHJlc3MACQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIJAQtjb29yZGluYXRvcgAFEWtfbWFuYWdlcl9hZGRyZXNzAg9NYW5hZ2VyIG5vdCBzZXQCD01hbmFnZXIgbm90IHNldAERY29sbGF0ZXJhbEFkZHJlc3MACQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIJAQtjb29yZGluYXRvcgAFFGtfY29sbGF0ZXJhbF9hZGRyZXNzAhJDb2xsYXRlcmFsIG5vdCBzZXQCEkNvbGxhdGVyYWwgbm90IHNldAEPdXBkYXRlSW5zdXJhbmNlAQFpCQDMCAIJAQxJbnRlZ2VyRW50cnkCBQtrX2luc3VyYW5jZQUBaQUDbmlsBAFpAQppbml0aWFsaXplAQxfY29vcmRpbmF0b3IDCQELaW5pdGlhbGl6ZWQACQACAQITQWxyZWFkeSBpbml0aWFsaXplZAkAzAgCCQELU3RyaW5nRW50cnkCBRRrX2Nvb3JkaW5hdG9yQWRkcmVzcwUMX2Nvb3JkaW5hdG9yCQDMCAIJAQxCb29sZWFuRW50cnkCBQ1rX2luaXRpYWxpemVkBgUDbmlsAWkBCHdpdGhkcmF3AQdfYW1vdW50AwMDCQEBIQEDCQELaXNXaGl0ZWxpc3QBCQClCAEIBQFpBmNhbGxlcgYJAAACCAUBaQZjYWxsZXIJARFjb2xsYXRlcmFsQWRkcmVzcwAGCQEBIQEJAQtpbml0aWFsaXplZAAGCQBmAgUHX2Ftb3VudAkBCWluc3VyYW5jZQAJAAIBCQCsAgIJAKwCAgkArAICAiRJbnZhbGlkIHdpdGhkcmF3IHBhcmFtcyAoaW5zdXJhbmNlKSAJAKQDAQUHX2Ftb3VudAIDID4gCQCkAwEJAQlpbnN1cmFuY2UABAd1bnN0YWtlCQD8BwQJAQ5tYW5hZ2VyQWRkcmVzcwACCHdpdGhkcmF3CQDMCAIJANgEAQkBCnF1b3RlQXNzZXQACQDMCAIFB19hbW91bnQFA25pbAUDbmlsAwkAAAIFB3Vuc3Rha2UFB3Vuc3Rha2UJAM4IAgkBD3VwZGF0ZUluc3VyYW5jZQEJAGUCCQEJaW5zdXJhbmNlAAUHX2Ftb3VudAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFB19hbW91bnQJAQpxdW90ZUFzc2V0AAUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBB2RlcG9zaXQABAdfYW1vdW50CAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAMDAwkBAiE9AggJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkCQEKcXVvdGVBc3NldAAGCQEBIQEJAQtpbml0aWFsaXplZAAGCQEBIQEDAwkBC2lzV2hpdGVsaXN0AQkApQgBCAUBaQZjYWxsZXIGCQAAAggFAWkGY2FsbGVyCQERY29sbGF0ZXJhbEFkZHJlc3MABgkAAAIIBQFpBmNhbGxlcgkBDGFkbWluQWRkcmVzcwAJAAIBAhZJbnZhbGlkIGRlcG9zaXQgcGFyYW1zBAVzdGFrZQkA/AcECQEObWFuYWdlckFkZHJlc3MAAgdkZXBvc2l0BQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJAQpxdW90ZUFzc2V0AAUHX2Ftb3VudAUDbmlsAwkAAAIFBXN0YWtlBQVzdGFrZQkBD3VwZGF0ZUluc3VyYW5jZQEJAGQCCQEJaW5zdXJhbmNlAAUHX2Ftb3VudAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpARBtaWdyYXRlTGlxdWlkaXR5AAQGYW1vdW50CQEJaW5zdXJhbmNlAAQHdW5zdGFrZQkA/AcECQERcXVvdGVBc3NldFN0YWtpbmcAAg51bmxvY2tOZXV0cmlubwkAzAgCBQZhbW91bnQJAMwIAgkA2AQBCQEKcXVvdGVBc3NldAAFA25pbAUDbmlsAwkAAAIFB3Vuc3Rha2UFB3Vuc3Rha2UEBXN0YWtlCQD8BwQJAQ5tYW5hZ2VyQWRkcmVzcwACB2RlcG9zaXQFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkBCnF1b3RlQXNzZXQABQZhbW91bnQFA25pbAMJAAACBQVzdGFrZQUFc3Rha2UFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgECdHgBBnZlcmlmeQAJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAJAQ5hZG1pblB1YmxpY0tleQAZ/N6k", "height": 2310887, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 9YowDJ7TTov1pEyDTGHY354Er17zncoR4A15pkC5C9yp Next: E2vKMkohJmUV57Qp1ShDoCseSkxr2582Kpgmn9mPPMRW Diff:
Old | New | Differences | |
---|---|---|---|
16 | 16 | let k_quote_staking = "k_quote_staking" | |
17 | 17 | ||
18 | 18 | let k_manager_address = "k_manager_address" | |
19 | + | ||
20 | + | let k_collateral_address = "k_collateral_address" | |
19 | 21 | ||
20 | 22 | let k_initialized = "k_initialized" | |
21 | 23 | ||
49 | 51 | func managerAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_manager_address), "Manager not set")), "Manager not set") | |
50 | 52 | ||
51 | 53 | ||
54 | + | func collateralAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_collateral_address), "Collateral not set")), "Collateral not set") | |
55 | + | ||
56 | + | ||
52 | 57 | func updateInsurance (i) = [IntegerEntry(k_insurance, i)] | |
53 | 58 | ||
54 | 59 | ||
60 | 65 | ||
61 | 66 | ||
62 | 67 | @Callable(i) | |
63 | - | func withdraw (_amount) = if (if (if (!(isWhitelist(toString(i.caller)))) | |
68 | + | func withdraw (_amount) = if (if (if (!(if (isWhitelist(toString(i.caller))) | |
69 | + | then true | |
70 | + | else (i.caller == collateralAddress()))) | |
64 | 71 | then true | |
65 | 72 | else !(initialized())) | |
66 | 73 | then true | |
67 | 74 | else (_amount > insurance())) | |
68 | - | then throw(((("Invalid withdraw params " + toString(_amount)) + " > ") + toString(insurance()))) | |
75 | + | then throw(((("Invalid withdraw params (insurance) " + toString(_amount)) + " > ") + toString(insurance()))) | |
69 | 76 | else { | |
70 | 77 | let unstake = invoke(managerAddress(), "withdraw", [toBase58String(quoteAsset()), _amount], nil) | |
71 | 78 | if ((unstake == unstake)) | |
82 | 89 | then true | |
83 | 90 | else !(initialized())) | |
84 | 91 | then true | |
85 | - | else if (!(isWhitelist(toString(i.caller)))) | |
86 | - | then (i.caller != adminAddress()) | |
87 | - | else false) | |
92 | + | else !(if (if (isWhitelist(toString(i.caller))) | |
93 | + | then true | |
94 | + | else (i.caller == collateralAddress())) | |
95 | + | then true | |
96 | + | else (i.caller == adminAddress()))) | |
88 | 97 | then throw("Invalid deposit params") | |
89 | 98 | else { | |
90 | 99 | let stake = invoke(managerAddress(), "deposit", nil, [AttachedPayment(quoteAsset(), _amount)]) |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let k_insurance = "k_insurance" | |
5 | 5 | ||
6 | 6 | let k_coordinatorAddress = "k_coordinatorAddress" | |
7 | 7 | ||
8 | 8 | let k_amm = "k_amm" | |
9 | 9 | ||
10 | 10 | let k_admin_address = "k_admin_address" | |
11 | 11 | ||
12 | 12 | let k_admin_public_key = "k_admin_public_key" | |
13 | 13 | ||
14 | 14 | let k_quote_asset = "k_quote_asset" | |
15 | 15 | ||
16 | 16 | let k_quote_staking = "k_quote_staking" | |
17 | 17 | ||
18 | 18 | let k_manager_address = "k_manager_address" | |
19 | + | ||
20 | + | let k_collateral_address = "k_collateral_address" | |
19 | 21 | ||
20 | 22 | let k_initialized = "k_initialized" | |
21 | 23 | ||
22 | 24 | func toCompositeKey (_key,_address) = ((_key + "_") + _address) | |
23 | 25 | ||
24 | 26 | ||
25 | 27 | func insurance () = valueOrElse(getInteger(this, k_insurance), 0) | |
26 | 28 | ||
27 | 29 | ||
28 | 30 | func coordinator () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, k_coordinatorAddress), "Coordinator not set")), "Coordinator not set") | |
29 | 31 | ||
30 | 32 | ||
31 | 33 | func isWhitelist (_address) = valueOrElse(getBoolean(coordinator(), toCompositeKey(k_amm, _address)), false) | |
32 | 34 | ||
33 | 35 | ||
34 | 36 | func initialized () = valueOrElse(getBoolean(this, k_initialized), false) | |
35 | 37 | ||
36 | 38 | ||
37 | 39 | func adminAddress () = addressFromString(valueOrErrorMessage(getString(coordinator(), k_admin_address), "Admin address not set")) | |
38 | 40 | ||
39 | 41 | ||
40 | 42 | func adminPublicKey () = fromBase58String(valueOrErrorMessage(getString(coordinator(), k_admin_public_key), "Admin public key not set")) | |
41 | 43 | ||
42 | 44 | ||
43 | 45 | func quoteAsset () = fromBase58String(valueOrErrorMessage(getString(coordinator(), k_quote_asset), "Quote asset not set")) | |
44 | 46 | ||
45 | 47 | ||
46 | 48 | func quoteAssetStaking () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_quote_staking), "Quote asset staking not set")), "Quote asset staking not set") | |
47 | 49 | ||
48 | 50 | ||
49 | 51 | func managerAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_manager_address), "Manager not set")), "Manager not set") | |
50 | 52 | ||
51 | 53 | ||
54 | + | func collateralAddress () = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(coordinator(), k_collateral_address), "Collateral not set")), "Collateral not set") | |
55 | + | ||
56 | + | ||
52 | 57 | func updateInsurance (i) = [IntegerEntry(k_insurance, i)] | |
53 | 58 | ||
54 | 59 | ||
55 | 60 | @Callable(i) | |
56 | 61 | func initialize (_coordinator) = if (initialized()) | |
57 | 62 | then throw("Already initialized") | |
58 | 63 | else [StringEntry(k_coordinatorAddress, _coordinator), BooleanEntry(k_initialized, true)] | |
59 | 64 | ||
60 | 65 | ||
61 | 66 | ||
62 | 67 | @Callable(i) | |
63 | - | func withdraw (_amount) = if (if (if (!(isWhitelist(toString(i.caller)))) | |
68 | + | func withdraw (_amount) = if (if (if (!(if (isWhitelist(toString(i.caller))) | |
69 | + | then true | |
70 | + | else (i.caller == collateralAddress()))) | |
64 | 71 | then true | |
65 | 72 | else !(initialized())) | |
66 | 73 | then true | |
67 | 74 | else (_amount > insurance())) | |
68 | - | then throw(((("Invalid withdraw params " + toString(_amount)) + " > ") + toString(insurance()))) | |
75 | + | then throw(((("Invalid withdraw params (insurance) " + toString(_amount)) + " > ") + toString(insurance()))) | |
69 | 76 | else { | |
70 | 77 | let unstake = invoke(managerAddress(), "withdraw", [toBase58String(quoteAsset()), _amount], nil) | |
71 | 78 | if ((unstake == unstake)) | |
72 | 79 | then (updateInsurance((insurance() - _amount)) ++ [ScriptTransfer(i.caller, _amount, quoteAsset())]) | |
73 | 80 | else throw("Strict value is not equal to itself.") | |
74 | 81 | } | |
75 | 82 | ||
76 | 83 | ||
77 | 84 | ||
78 | 85 | @Callable(i) | |
79 | 86 | func deposit () = { | |
80 | 87 | let _amount = i.payments[0].amount | |
81 | 88 | if (if (if ((i.payments[0].assetId != quoteAsset())) | |
82 | 89 | then true | |
83 | 90 | else !(initialized())) | |
84 | 91 | then true | |
85 | - | else if (!(isWhitelist(toString(i.caller)))) | |
86 | - | then (i.caller != adminAddress()) | |
87 | - | else false) | |
92 | + | else !(if (if (isWhitelist(toString(i.caller))) | |
93 | + | then true | |
94 | + | else (i.caller == collateralAddress())) | |
95 | + | then true | |
96 | + | else (i.caller == adminAddress()))) | |
88 | 97 | then throw("Invalid deposit params") | |
89 | 98 | else { | |
90 | 99 | let stake = invoke(managerAddress(), "deposit", nil, [AttachedPayment(quoteAsset(), _amount)]) | |
91 | 100 | if ((stake == stake)) | |
92 | 101 | then updateInsurance((insurance() + _amount)) | |
93 | 102 | else throw("Strict value is not equal to itself.") | |
94 | 103 | } | |
95 | 104 | } | |
96 | 105 | ||
97 | 106 | ||
98 | 107 | ||
99 | 108 | @Callable(i) | |
100 | 109 | func migrateLiquidity () = { | |
101 | 110 | let amount = insurance() | |
102 | 111 | let unstake = invoke(quoteAssetStaking(), "unlockNeutrino", [amount, toBase58String(quoteAsset())], nil) | |
103 | 112 | if ((unstake == unstake)) | |
104 | 113 | then { | |
105 | 114 | let stake = invoke(managerAddress(), "deposit", nil, [AttachedPayment(quoteAsset(), amount)]) | |
106 | 115 | if ((stake == stake)) | |
107 | 116 | then nil | |
108 | 117 | else throw("Strict value is not equal to itself.") | |
109 | 118 | } | |
110 | 119 | else throw("Strict value is not equal to itself.") | |
111 | 120 | } | |
112 | 121 | ||
113 | 122 | ||
114 | 123 | @Verifier(tx) | |
115 | 124 | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], adminPublicKey()) | |
116 | 125 |
github/deemru/w8io/169f3d6 27.56 ms ◑