tx · 2MGWf8kASDBFKUQTMB7KUktLecyYePGwJ8nffCZj8Qin 3N3v2zVJyynhzc39qG5wrE244prmxQ4bgV4: -0.14000000 Waves 2023.03.22 17:10 [2501322] smart account 3N3v2zVJyynhzc39qG5wrE244prmxQ4bgV4 > SELF 0.00000000 Waves
{ "type": 13, "id": "2MGWf8kASDBFKUQTMB7KUktLecyYePGwJ8nffCZj8Qin", "fee": 14000000, "feeAssetId": null, "timestamp": 1679494210713, "version": 2, "chainId": 84, "sender": "3N3v2zVJyynhzc39qG5wrE244prmxQ4bgV4", "senderPublicKey": "B9tjfxvdWuoHAvWusCmsxYMGHa4o2uzQmod3uHjLmF5G", "proofs": [ "2u7KVZVXRpudCZVW5keaZSX2e2EJgYMTgxv2YyxWqg6goqh98a7NUMQYfdvP9ZTkiy3rhawu2iMtHRE6d1DutAof", "2oTk3CqLQ8oXhsavjgTMSkjx11o3mRULghJuZFqHKeCVeLYEpGXm221LkpDbR2EKmcxuuXhfg1sBNe16m91D4qgu" ], "script": "base64:BgICCAINAAZvcmFjbGUJAQdBZGRyZXNzAQEaAVRIE5cMwNMzzCUygLYp96dkaICr48x7S5kBE2dldEJhc2U1OEZyb21PcmFjbGUBA2tleQQHJG1hdGNoMAkAnQgCBQZvcmFjbGUFA2tleQMJAAECBQckbWF0Y2gwAgZTdHJpbmcEBnN0cmluZwUHJG1hdGNoMAkA2QQBBQZzdHJpbmcEB25vdGhpbmcFByRtYXRjaDAJAAIBCQCsAgIFA2tleQIIaXMgZW1wdHkADWtBZG1pblB1YktleTECC2FkbWluX3B1Yl8xAA1rQWRtaW5QdWJLZXkyAgthZG1pbl9wdWJfMgANa0FkbWluUHViS2V5MwILYWRtaW5fcHViXzMAEmtBZG1pbkludm9rZVB1YktleQIQYWRtaW5faW52b2tlX3B1YgAMa1JvdXRpbmdBZGRyAg9yb3V0aW5nX2FkZHJlc3MADGFkbWluUHViS2V5MQkBE2dldEJhc2U1OEZyb21PcmFjbGUBBQ1rQWRtaW5QdWJLZXkxAAxhZG1pblB1YktleTIJARNnZXRCYXNlNThGcm9tT3JhY2xlAQUNa0FkbWluUHViS2V5MgAMYWRtaW5QdWJLZXkzCQETZ2V0QmFzZTU4RnJvbU9yYWNsZQEFDWtBZG1pblB1YktleTMAC2FkbWluSW52b2tlCQETZ2V0QmFzZTU4RnJvbU9yYWNsZQEFEmtBZG1pbkludm9rZVB1YktleQAOcm91dGluZ0FkZHJlc3MJAQdBZGRyZXNzAQkBE2dldEJhc2U1OEZyb21PcmFjbGUBBQxrUm91dGluZ0FkZHIAEWtleVByZWZpeFBvb2xOYW1lAgVwb29sXwABAnR4AQZ2ZXJpZnkABAckbWF0Y2gwBQJ0eAMJAAECBQckbWF0Y2gwAhdJbnZva2VTY3JpcHRUcmFuc2FjdGlvbgQDaW52BQckbWF0Y2gwBAppc1JpZ2h0RmVlAwkAAAIIBQNpbnYDZmVlAKD3NgkAAAIIBQNpbnYKZmVlQXNzZXRJZAUEdW5pdAcEDWlzUm91dGluZ0NhbGwDCQAAAggFA2ludgRkQXBwBQ5yb3V0aW5nQWRkcmVzcwkAAAIIBQNpbnYIZnVuY3Rpb24CDHJvdXRpbmdUcmFkZQcEEmlzRXhjaGFuZ2VDYWxsQ1BNTQMDCQEJaXNEZWZpbmVkAQkAnQgCBQZvcmFjbGUJAKwCAgURa2V5UHJlZml4UG9vbE5hbWUJAKUIAQkApAgBCAUDaW52BGRBcHAJAAACCAUDaW52CGZ1bmN0aW9uAgxjYWxsRnVuY3Rpb24HCQAAAgkAkQMCCAUDaW52BGFyZ3MAAAIIZXhjaGFuZ2UHBA5pc0V4Y2hhbmdlQ2FsbAMJAQlpc0RlZmluZWQBCQCdCAIFBm9yYWNsZQkArAICBRFrZXlQcmVmaXhQb29sTmFtZQkApQgBCQCkCAEIBQNpbnYEZEFwcAkAAAIIBQNpbnYIZnVuY3Rpb24CCGV4Y2hhbmdlBwQSYWRtaW5QdWJLZXkxU2lnbmVkAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAUMYWRtaW5QdWJLZXkxAAEAAAQSYWRtaW5QdWJLZXkyU2lnbmVkAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAUMYWRtaW5QdWJLZXkyAAEAAAQSYWRtaW5QdWJLZXkzU2lnbmVkAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAUMYWRtaW5QdWJLZXkzAAEAAAQXYWRtaW5QdWJLZXlJbnZva2VTaWduZWQDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAABQthZG1pbkludm9rZQABAAAEEHNpZ25lZEJ5T25lQWRtaW4JAGcCCQBkAgkAZAIJAGQCBRJhZG1pblB1YktleTFTaWduZWQFEmFkbWluUHViS2V5MlNpZ25lZAUSYWRtaW5QdWJLZXkzU2lnbmVkBRdhZG1pblB1YktleUludm9rZVNpZ25lZAABAwMDAwMFDmlzRXhjaGFuZ2VDYWxsBgUSaXNFeGNoYW5nZUNhbGxDUE1NBgUNaXNSb3V0aW5nQ2FsbAkAAAIJAJADAQgFA2ludghwYXltZW50cwABBwUKaXNSaWdodEZlZQcFEHNpZ25lZEJ5T25lQWRtaW4HBBJhZG1pblB1YktleTFTaWduZWQDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAABQxhZG1pblB1YktleTEAAQAABBJhZG1pblB1YktleTJTaWduZWQDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwABBQxhZG1pblB1YktleTIAAQAABBJhZG1pblB1YktleTNTaWduZWQDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwACBQxhZG1pblB1YktleTMAAQAACQBnAgkAZAIJAGQCBRJhZG1pblB1YktleTFTaWduZWQFEmFkbWluUHViS2V5MlNpZ25lZAUSYWRtaW5QdWJLZXkzU2lnbmVkAAKwpyKg", "height": 2501322, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 6dTMKXHrBZVXcD91DkV44XSr7zN8HHZtTsgbv1G5tG5Y Next: none Diff:
Old | New | Differences | |
---|---|---|---|
64 | 64 | then 1 | |
65 | 65 | else 0 | |
66 | 66 | let signedByOneAdmin = ((((adminPubKey1Signed + adminPubKey2Signed) + adminPubKey3Signed) + adminPubKeyInvokeSigned) >= 1) | |
67 | - | if (if (if (if (if ( | |
67 | + | if (if (if (if (if (isExchangeCall) | |
68 | 68 | then true | |
69 | 69 | else isExchangeCallCPMM) | |
70 | 70 | then true | |
71 | 71 | else isRoutingCall) | |
72 | 72 | then (size(inv.payments) == 1) | |
73 | - | else false) | |
74 | - | then sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
75 | 73 | else false) | |
76 | 74 | then isRightFee | |
77 | 75 | else false) |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let oracle = Address(base58'3MvVBtsXroQpy1tsPw21TU2ET9A8WfmrNjz') | |
5 | 5 | ||
6 | 6 | func getBase58FromOracle (key) = match getString(oracle, key) { | |
7 | 7 | case string: String => | |
8 | 8 | fromBase58String(string) | |
9 | 9 | case nothing => | |
10 | 10 | throw((key + "is empty")) | |
11 | 11 | } | |
12 | 12 | ||
13 | 13 | ||
14 | 14 | let kAdminPubKey1 = "admin_pub_1" | |
15 | 15 | ||
16 | 16 | let kAdminPubKey2 = "admin_pub_2" | |
17 | 17 | ||
18 | 18 | let kAdminPubKey3 = "admin_pub_3" | |
19 | 19 | ||
20 | 20 | let kAdminInvokePubKey = "admin_invoke_pub" | |
21 | 21 | ||
22 | 22 | let kRoutingAddr = "routing_address" | |
23 | 23 | ||
24 | 24 | let adminPubKey1 = getBase58FromOracle(kAdminPubKey1) | |
25 | 25 | ||
26 | 26 | let adminPubKey2 = getBase58FromOracle(kAdminPubKey2) | |
27 | 27 | ||
28 | 28 | let adminPubKey3 = getBase58FromOracle(kAdminPubKey3) | |
29 | 29 | ||
30 | 30 | let adminInvoke = getBase58FromOracle(kAdminInvokePubKey) | |
31 | 31 | ||
32 | 32 | let routingAddress = Address(getBase58FromOracle(kRoutingAddr)) | |
33 | 33 | ||
34 | 34 | let keyPrefixPoolName = "pool_" | |
35 | 35 | ||
36 | 36 | ||
37 | 37 | @Verifier(tx) | |
38 | 38 | func verify () = match tx { | |
39 | 39 | case inv: InvokeScriptTransaction => | |
40 | 40 | let isRightFee = if ((inv.fee == 900000)) | |
41 | 41 | then (inv.feeAssetId == unit) | |
42 | 42 | else false | |
43 | 43 | let isRoutingCall = if ((inv.dApp == routingAddress)) | |
44 | 44 | then (inv.function == "routingTrade") | |
45 | 45 | else false | |
46 | 46 | let isExchangeCallCPMM = if (if (isDefined(getString(oracle, (keyPrefixPoolName + toString(addressFromRecipient(inv.dApp)))))) | |
47 | 47 | then (inv.function == "callFunction") | |
48 | 48 | else false) | |
49 | 49 | then (inv.args[0] == "exchange") | |
50 | 50 | else false | |
51 | 51 | let isExchangeCall = if (isDefined(getString(oracle, (keyPrefixPoolName + toString(addressFromRecipient(inv.dApp)))))) | |
52 | 52 | then (inv.function == "exchange") | |
53 | 53 | else false | |
54 | 54 | let adminPubKey1Signed = if (sigVerify(tx.bodyBytes, tx.proofs[0], adminPubKey1)) | |
55 | 55 | then 1 | |
56 | 56 | else 0 | |
57 | 57 | let adminPubKey2Signed = if (sigVerify(tx.bodyBytes, tx.proofs[0], adminPubKey2)) | |
58 | 58 | then 1 | |
59 | 59 | else 0 | |
60 | 60 | let adminPubKey3Signed = if (sigVerify(tx.bodyBytes, tx.proofs[0], adminPubKey3)) | |
61 | 61 | then 1 | |
62 | 62 | else 0 | |
63 | 63 | let adminPubKeyInvokeSigned = if (sigVerify(tx.bodyBytes, tx.proofs[0], adminInvoke)) | |
64 | 64 | then 1 | |
65 | 65 | else 0 | |
66 | 66 | let signedByOneAdmin = ((((adminPubKey1Signed + adminPubKey2Signed) + adminPubKey3Signed) + adminPubKeyInvokeSigned) >= 1) | |
67 | - | if (if (if (if (if ( | |
67 | + | if (if (if (if (if (isExchangeCall) | |
68 | 68 | then true | |
69 | 69 | else isExchangeCallCPMM) | |
70 | 70 | then true | |
71 | 71 | else isRoutingCall) | |
72 | 72 | then (size(inv.payments) == 1) | |
73 | - | else false) | |
74 | - | then sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey) | |
75 | 73 | else false) | |
76 | 74 | then isRightFee | |
77 | 75 | else false) | |
78 | 76 | then signedByOneAdmin | |
79 | 77 | else false | |
80 | 78 | case _ => | |
81 | 79 | let adminPubKey1Signed = if (sigVerify(tx.bodyBytes, tx.proofs[0], adminPubKey1)) | |
82 | 80 | then 1 | |
83 | 81 | else 0 | |
84 | 82 | let adminPubKey2Signed = if (sigVerify(tx.bodyBytes, tx.proofs[1], adminPubKey2)) | |
85 | 83 | then 1 | |
86 | 84 | else 0 | |
87 | 85 | let adminPubKey3Signed = if (sigVerify(tx.bodyBytes, tx.proofs[2], adminPubKey3)) | |
88 | 86 | then 1 | |
89 | 87 | else 0 | |
90 | 88 | (((adminPubKey1Signed + adminPubKey2Signed) + adminPubKey3Signed) >= 2) | |
91 | 89 | } | |
92 | 90 |
github/deemru/w8io/026f985 23.70 ms ◑