tx · CejJNuSNQadgkTEHPMQ3NhKkv5tXQ6xqSaYtAjNHcrbT 3MqkoGVxf9wAeNTiksudck7HuNKruh3W9yg: -0.04000000 Waves 2021.08.24 01:09 [1671557] smart account 3MqkoGVxf9wAeNTiksudck7HuNKruh3W9yg > SELF 0.00000000 Waves
{ "type": 13, "id": "CejJNuSNQadgkTEHPMQ3NhKkv5tXQ6xqSaYtAjNHcrbT", "fee": 4000000, "feeAssetId": null, "timestamp": 1629756631160, "version": 2, "chainId": 84, "sender": "3MqkoGVxf9wAeNTiksudck7HuNKruh3W9yg", "senderPublicKey": "4adRtnahFnRGxzn67XppfF97pKLyUFPtNw5aCZ4NM9UV", "proofs": [ "a8C5pY8nJEpcNdAhduscRAAz4JUXNFXWytBj9EshgDL7jgcwtszyXuyyccJTYwqzfvaR6sDiCQ5Tq5PWJVoeeeG" ], "script": "base64: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", "height": 1671557, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: FwNhKqUi76beVEZHVSPZKzBT7QSGDorU4Kctj2KpN6oR Next: HiBUgHxmrccbp22a7DeDKWWp7RNHA5K6TqtghP9pzptM Diff:
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 5 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | - | let config = | |
4 | + | let config = getStringValue(this, "config") | |
5 | 5 | ||
6 | - | let admin = | |
6 | + | let admin = valueOrElse(getStringValue(addressFromStringValue(config), "admin"), "") | |
7 | 7 | ||
8 | 8 | let pools = valueOrErrorMessage(getString(this, "pools"), "No key admin was found") | |
9 | 9 | ||
10 | - | func isAdmin (callerAddress) = if ((callerAddress == | |
10 | + | func isAdmin (callerAddress) = if ((callerAddress == addressFromStringValue(admin))) | |
11 | 11 | then true | |
12 | 12 | else false | |
13 | 13 | ||
24 | 24 | ||
25 | 25 | ||
26 | 26 | @Callable(i) | |
27 | - | func setup (configAddress,pools) = if (if (isAdmin(i.caller | |
27 | + | func setup (configAddress,pools) = if (if (isAdmin(i.caller)) | |
28 | 28 | then true | |
29 | 29 | else (0 >= size(admin))) | |
30 | 30 | then [writeString("config", configAddress), writeString("poolsStrg", makeString(pools, ";"))] | |
33 | 33 | ||
34 | 34 | ||
35 | 35 | @Callable(i) | |
36 | - | func addPool (poolAddress) = if (isAdmin(i.caller | |
36 | + | func addPool (poolAddress) = if (isAdmin(i.caller)) | |
37 | 37 | then { | |
38 | 38 | let poolList = split(pools, ";") | |
39 | 39 | if ((containsElement(poolList, poolAddress) == false)) | |
48 | 48 | ||
49 | 49 | ||
50 | 50 | @Callable(i) | |
51 | - | func updateConfig (configAddress) = if (isAdmin(i.caller | |
51 | + | func updateConfig (configAddress) = if (isAdmin(i.caller)) | |
52 | 52 | then [writeString("config", configAddress)] | |
53 | 53 | else throw("Address does not match with admin address!") | |
54 | 54 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 5 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | - | let config = | |
4 | + | let config = getStringValue(this, "config") | |
5 | 5 | ||
6 | - | let admin = | |
6 | + | let admin = valueOrElse(getStringValue(addressFromStringValue(config), "admin"), "") | |
7 | 7 | ||
8 | 8 | let pools = valueOrErrorMessage(getString(this, "pools"), "No key admin was found") | |
9 | 9 | ||
10 | - | func isAdmin (callerAddress) = if ((callerAddress == | |
10 | + | func isAdmin (callerAddress) = if ((callerAddress == addressFromStringValue(admin))) | |
11 | 11 | then true | |
12 | 12 | else false | |
13 | 13 | ||
14 | 14 | ||
15 | 15 | func checkPool (poolAdd) = if (contains(pools, poolAdd)) | |
16 | 16 | then true | |
17 | 17 | else false | |
18 | 18 | ||
19 | 19 | ||
20 | 20 | func writeString (key,stringValue) = StringEntry(key, stringValue) | |
21 | 21 | ||
22 | 22 | ||
23 | 23 | func writeInteger (key,integerValue) = IntegerEntry(key, integerValue) | |
24 | 24 | ||
25 | 25 | ||
26 | 26 | @Callable(i) | |
27 | - | func setup (configAddress,pools) = if (if (isAdmin(i.caller | |
27 | + | func setup (configAddress,pools) = if (if (isAdmin(i.caller)) | |
28 | 28 | then true | |
29 | 29 | else (0 >= size(admin))) | |
30 | 30 | then [writeString("config", configAddress), writeString("poolsStrg", makeString(pools, ";"))] | |
31 | 31 | else throw("Address does not match with admin address!") | |
32 | 32 | ||
33 | 33 | ||
34 | 34 | ||
35 | 35 | @Callable(i) | |
36 | - | func addPool (poolAddress) = if (isAdmin(i.caller | |
36 | + | func addPool (poolAddress) = if (isAdmin(i.caller)) | |
37 | 37 | then { | |
38 | 38 | let poolList = split(pools, ";") | |
39 | 39 | if ((containsElement(poolList, poolAddress) == false)) | |
40 | 40 | then { | |
41 | 41 | let newPools = (poolList :+ poolAddress) | |
42 | 42 | [writeString("pools", makeString(newPools, ";"))] | |
43 | 43 | } | |
44 | 44 | else throw("Pool already exists!") | |
45 | 45 | } | |
46 | 46 | else throw("Address does not match with admin address!") | |
47 | 47 | ||
48 | 48 | ||
49 | 49 | ||
50 | 50 | @Callable(i) | |
51 | - | func updateConfig (configAddress) = if (isAdmin(i.caller | |
51 | + | func updateConfig (configAddress) = if (isAdmin(i.caller)) | |
52 | 52 | then [writeString("config", configAddress)] | |
53 | 53 | else throw("Address does not match with admin address!") | |
54 | 54 | ||
55 | 55 | ||
56 | 56 | ||
57 | 57 | @Callable(i) | |
58 | 58 | func depositAt (poolAddress,isCollateral) = if (checkPool(poolAddress)) | |
59 | 59 | then if ((size(i.payments) > 0)) | |
60 | 60 | then { | |
61 | 61 | let user = toBase58String(i.caller.bytes) | |
62 | 62 | let tokenAmount = invoke(addressFromStringValue(poolAddress), "deposit", [user, isCollateral], i.payments) | |
63 | 63 | let tokenId = getStringValue(addressFromStringValue(poolAddress), "dTokenId") | |
64 | 64 | match tokenAmount { | |
65 | 65 | case t: Int => | |
66 | 66 | [ScriptTransfer(i.caller, t, fromBase58String(tokenId))] | |
67 | 67 | case _ => | |
68 | 68 | throw("Incorrect invoke result!") | |
69 | 69 | } | |
70 | 70 | } | |
71 | 71 | else throw("No payment attached!") | |
72 | 72 | else throw("Pool address not found!") | |
73 | 73 | ||
74 | 74 | ||
75 | 75 | @Verifier(tx) | |
76 | 76 | func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
77 | 77 |
github/deemru/w8io/169f3d6 26.05 ms ◑