tx · EuWFzAFhpCfG1ngNofmRejKiAZAkUNFomRGXxg5vKay7

3MxiR4vDPzVeaEPgznfS4zi4uLd2nnQuGy9:  -0.01000000 Waves

2023.09.26 00:33 [2771487] smart account 3MxiR4vDPzVeaEPgznfS4zi4uLd2nnQuGy9 > SELF 0.00000000 Waves

{ "type": 13, "id": "EuWFzAFhpCfG1ngNofmRejKiAZAkUNFomRGXxg5vKay7", "fee": 1000000, "feeAssetId": null, "timestamp": 1695677611192, "version": 2, "chainId": 84, "sender": "3MxiR4vDPzVeaEPgznfS4zi4uLd2nnQuGy9", "senderPublicKey": "4AVkL2DQJ8sngCNyArYueNuPS7cvygnakPJhU65LfPfu", "proofs": [ "3vh6sWpCHfKuQevYGgF3Zg6SVruF6kVRQ2keX2APMEnhMVg4Adiox1EVZAg1jUPCJKQT3RJYwasT5TEmYw8HQtVK", "3XFoggokQnKfMJfc1MivAbRaWq65pf5BihFSerYCztSyFwRwKz5Bg4mS1YKHyJDyc38D5s7b3ctbZmM9ryZDs1a2" ], "script": "base64:BgIMCAISAwoBGBIDCgEYDgAOQVhMWV9NQUlOX0FERFIJAQdBZGRyZXNzAQEaAVRHYdFKTc5/+9vupfS91sItmkjqQtK5YZsAB1NGX1BPT0wCAlNGAAdXWF9QT09MAgJXWAAKa1NoYXJlUG9vbAIMX3Bvb2xTaGFyZUlkAAVrUG9vbAIFcG9vbF8ACWtBZG1pbjFQSwIVZ3JvdXAxX2FkbWluMV9wdWJfa2V5AAlrQWRtaW4yUEsCFWdyb3VwMV9hZG1pbjJfcHViX2tleQAJa0FkbWluM1BLAhVncm91cDFfYWRtaW4zX3B1Yl9rZXkAD2tPcGVyYXRvckNhbGxQSwISYWRtaW5fY2FsbF9wdWJfa2V5AAhhZG1pbjFQSwkA2QQBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUOQVhMWV9NQUlOX0FERFIFCWtBZG1pbjFQSwISQ2FuJ3QgZ2V0IGFkbWluMVBLAAhhZG1pbjJQSwkA2QQBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUOQVhMWV9NQUlOX0FERFIFCWtBZG1pbjJQSwISQ2FuJ3QgZ2V0IGFkbWluMlBLAAhhZG1pbjNQSwkA2QQBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUOQVhMWV9NQUlOX0FERFIFCWtBZG1pbjNQSwISQ2FuJ3QgZ2V0IGFkbWluM1BLAApvcGVyYXRvclBLCQDZBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQ5BWExZX01BSU5fQUREUgUPa09wZXJhdG9yQ2FsbFBLAhRDYW4ndCBnZXQgb3BlcmF0b3JQSwEPdW5rbm93blBvb2xUeXBlAAkAAgECD1dyb25nIHBvb2wgdHlwZQIBaQELZXhjaGFuZ2VMcHMBA2xwcwoBBGV4TFACAWECbHAEA2xwQgkA2QQBBQJscAQHYmFsYW5jZQkA8AcCBQR0aGlzBQNscEIEBHBvb2wJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQ5BWExZX01BSU5fQUREUgkArAICBQJscAUKa1NoYXJlUG9vbAkArAICAhVDYW4ndCBnZXQgcG9vbCBvZiBscDoFAmxwBAVwVHlwZQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMJAKwCAgUFa1Bvb2wFBHBvb2wCElBvb2wgaXMgbm90IGluaXRlZAQIcG9vbEFkZHIJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBBQRwb29sAgx1bmtub3duIGFkZHIDCQBmAgUHYmFsYW5jZQAABANpbnYDCQAAAgUFcFR5cGUFB1NGX1BPT0wJAPwHBAUIcG9vbEFkZHICDGNhbGxGdW5jdGlvbgkAzAgCAgh3aXRoZHJhdwkAzAgCCQDMCAICATAFA25pbAUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQNscEIFB2JhbGFuY2UFA25pbAMJAAACBQVwVHlwZQUHV1hfUE9PTAkA/AcEBQhwb29sQWRkcgIDZ2V0BQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFA2xwQgUHYmFsYW5jZQUDbmlsCQEPdW5rbm93blBvb2xUeXBlAAMJAAACBQNpbnYFA2ludgkAzQgCBQFhBgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAzQgCBQFhBwUDbmlsAWkBDmV4Y2hhbmdlVG9rZW5zAQVyb3V0ZQUDbmlsAQJ0eAEGdmVyaWZ5AAQHJG1hdGNoMAUCdHgDCQABAgUHJG1hdGNoMAIXSW52b2tlU2NyaXB0VHJhbnNhY3Rpb24EA2ludgUHJG1hdGNoMAQKaXNSaWdodEZlZQMJAAACCAUDaW52A2ZlZQCg9zYJAAACCAUDaW52CmZlZUFzc2V0SWQFBHVuaXQHBAppc0V4THBDYWxsCQAAAggFA2ludghmdW5jdGlvbgILZXhjaGFuZ2VMcHMEEmFkbWluUHViS2V5MVNpZ25lZAMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAFCGFkbWluMVBLAAEAAAQSYWRtaW5QdWJLZXkyU2lnbmVkAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAUIYWRtaW4yUEsAAQAABBJhZG1pblB1YktleTNTaWduZWQDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAABQhhZG1pbjNQSwABAAAEFWFkbWluUHViS2V5Q2FsbFNpZ25lZAMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAFCm9wZXJhdG9yUEsAAQAABBBzaWduZWRCeU9uZUFkbWluCQBnAgkAZAIJAGQCCQBkAgUSYWRtaW5QdWJLZXkxU2lnbmVkBRJhZG1pblB1YktleTJTaWduZWQFEmFkbWluUHViS2V5M1NpZ25lZAUVYWRtaW5QdWJLZXlDYWxsU2lnbmVkAAEDAwUKaXNSaWdodEZlZQUKaXNFeExwQ2FsbAcFEHNpZ25lZEJ5T25lQWRtaW4HBBJhZG1pblB1YktleTFTaWduZWQDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAABQhhZG1pbjFQSwABAAAEEmFkbWluUHViS2V5MlNpZ25lZAMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAEFCGFkbWluMlBLAAEAAAQSYWRtaW5QdWJLZXkzU2lnbmVkAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAgUIYWRtaW4zUEsAAQAACQBnAgkAZAIJAGQCBRJhZG1pblB1YktleTFTaWduZWQFEmFkbWluUHViS2V5MlNpZ25lZAUSYWRtaW5QdWJLZXkzU2lnbmVkAAJoU4bS", "height": 2771487, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: CTK9XPWCeFmosRJXTrGMRH3VGzdDSAKhjaUugGYzMc7j Next: 6E7SeS9KNuHLoQvLSfiCPqtUD2EAVToZBcUiQVMGL2eJ Diff:
OldNewDifferences
6363
6464 @Verifier(tx)
6565 func verify () = match tx {
66+ case inv: InvokeScriptTransaction =>
67+ let isRightFee = if ((inv.fee == 900000))
68+ then (inv.feeAssetId == unit)
69+ else false
70+ let isExLpCall = (inv.function == "exchangeLps")
71+ let adminPubKey1Signed = if (sigVerify(tx.bodyBytes, tx.proofs[0], admin1PK))
72+ then 1
73+ else 0
74+ let adminPubKey2Signed = if (sigVerify(tx.bodyBytes, tx.proofs[0], admin2PK))
75+ then 1
76+ else 0
77+ let adminPubKey3Signed = if (sigVerify(tx.bodyBytes, tx.proofs[0], admin3PK))
78+ then 1
79+ else 0
80+ let adminPubKeyCallSigned = if (sigVerify(tx.bodyBytes, tx.proofs[0], operatorPK))
81+ then 1
82+ else 0
83+ let signedByOneAdmin = ((((adminPubKey1Signed + adminPubKey2Signed) + adminPubKey3Signed) + adminPubKeyCallSigned) >= 1)
84+ if (if (isRightFee)
85+ then isExLpCall
86+ else false)
87+ then signedByOneAdmin
88+ else false
6689 case _ =>
6790 let adminPubKey1Signed = if (sigVerify(tx.bodyBytes, tx.proofs[0], admin1PK))
6891 then 1
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let AXLY_MAIN_ADDR = Address(base58'3MvRWw2FPEimFCTGtK7qY9uAJbM7XJ4ZfJS')
55
66 let SF_POOL = "SF"
77
88 let WX_POOL = "WX"
99
1010 let kSharePool = "_poolShareId"
1111
1212 let kPool = "pool_"
1313
1414 let kAdmin1PK = "group1_admin1_pub_key"
1515
1616 let kAdmin2PK = "group1_admin2_pub_key"
1717
1818 let kAdmin3PK = "group1_admin3_pub_key"
1919
2020 let kOperatorCallPK = "admin_call_pub_key"
2121
2222 let admin1PK = fromBase58String(valueOrErrorMessage(getString(AXLY_MAIN_ADDR, kAdmin1PK), "Can't get admin1PK"))
2323
2424 let admin2PK = fromBase58String(valueOrErrorMessage(getString(AXLY_MAIN_ADDR, kAdmin2PK), "Can't get admin2PK"))
2525
2626 let admin3PK = fromBase58String(valueOrErrorMessage(getString(AXLY_MAIN_ADDR, kAdmin3PK), "Can't get admin3PK"))
2727
2828 let operatorPK = fromBase58String(valueOrErrorMessage(getString(AXLY_MAIN_ADDR, kOperatorCallPK), "Can't get operatorPK"))
2929
3030 func unknownPoolType () = throw("Wrong pool type")
3131
3232
3333 @Callable(i)
3434 func exchangeLps (lps) = {
3535 func exLP (a,lp) = {
3636 let lpB = fromBase58String(lp)
3737 let balance = assetBalance(this, lpB)
3838 let pool = valueOrErrorMessage(getString(AXLY_MAIN_ADDR, (lp + kSharePool)), ("Can't get pool of lp:" + lp))
3939 let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited")
4040 let poolAddr = valueOrErrorMessage(addressFromString(pool), "unknown addr")
4141 if ((balance > 0))
4242 then {
4343 let inv = if ((pType == SF_POOL))
4444 then invoke(poolAddr, "callFunction", ["withdraw", ["0"]], [AttachedPayment(lpB, balance)])
4545 else if ((pType == WX_POOL))
4646 then invoke(poolAddr, "get", nil, [AttachedPayment(lpB, balance)])
4747 else unknownPoolType()
4848 if ((inv == inv))
4949 then (a :+ true)
5050 else throw("Strict value is not equal to itself.")
5151 }
5252 else (a :+ false)
5353 }
5454
5555 nil
5656 }
5757
5858
5959
6060 @Callable(i)
6161 func exchangeTokens (route) = nil
6262
6363
6464 @Verifier(tx)
6565 func verify () = match tx {
66+ case inv: InvokeScriptTransaction =>
67+ let isRightFee = if ((inv.fee == 900000))
68+ then (inv.feeAssetId == unit)
69+ else false
70+ let isExLpCall = (inv.function == "exchangeLps")
71+ let adminPubKey1Signed = if (sigVerify(tx.bodyBytes, tx.proofs[0], admin1PK))
72+ then 1
73+ else 0
74+ let adminPubKey2Signed = if (sigVerify(tx.bodyBytes, tx.proofs[0], admin2PK))
75+ then 1
76+ else 0
77+ let adminPubKey3Signed = if (sigVerify(tx.bodyBytes, tx.proofs[0], admin3PK))
78+ then 1
79+ else 0
80+ let adminPubKeyCallSigned = if (sigVerify(tx.bodyBytes, tx.proofs[0], operatorPK))
81+ then 1
82+ else 0
83+ let signedByOneAdmin = ((((adminPubKey1Signed + adminPubKey2Signed) + adminPubKey3Signed) + adminPubKeyCallSigned) >= 1)
84+ if (if (isRightFee)
85+ then isExLpCall
86+ else false)
87+ then signedByOneAdmin
88+ else false
6689 case _ =>
6790 let adminPubKey1Signed = if (sigVerify(tx.bodyBytes, tx.proofs[0], admin1PK))
6891 then 1
6992 else 0
7093 let adminPubKey2Signed = if (sigVerify(tx.bodyBytes, tx.proofs[1], admin2PK))
7194 then 1
7295 else 0
7396 let adminPubKey3Signed = if (sigVerify(tx.bodyBytes, tx.proofs[2], admin3PK))
7497 then 1
7598 else 0
7699 (((adminPubKey1Signed + adminPubKey2Signed) + adminPubKey3Signed) >= 2)
77100 }
78101

github/deemru/w8io/169f3d6 
29.10 ms