tx · ALCMKeL27skgMQUWmVGkjGDRkFF6ZQLnm1RPV2G7S6K2

3PJFu8MmVa2rSVGM48wdLm4jhLznEgu6XSe:  -0.00900000 Waves

2024.01.14 23:22 [3997452] smart account 3PJFu8MmVa2rSVGM48wdLm4jhLznEgu6XSe > SELF 0.00000000 Waves

{ "type": 13, "id": "ALCMKeL27skgMQUWmVGkjGDRkFF6ZQLnm1RPV2G7S6K2", "fee": 900000, "feeAssetId": null, "timestamp": 1705263734661, "version": 1, "sender": "3PJFu8MmVa2rSVGM48wdLm4jhLznEgu6XSe", "senderPublicKey": "5k59JsDv4Nh9KgnBQFfggScT4ce5vtoDmzQwivD8hgpc", "proofs": [ "S6BnYWDEpJbedToh1JS5ktexfEvDkXdgcTMVKDAjYwgH1uQeD7XzB1tmdVwgygvMk7fUoLsxeJMn87dBpg9kxo8" ], "script": "base64:BgIPCAISBAoCCAgSAwoBCBIACgEQd3JpdGVDb25zdFN0cmluZwIDa2V5BXZhbHVlAwkBASEBCQEJaXNEZWZpbmVkAQkAnQgCBQR0aGlzBQNrZXkJAQtTdHJpbmdFbnRyeQIFA2tleQUFdmFsdWUJAAIBCQCsAgICFWFscmVhZHkgaW5pdGlhbGl6ZWQ6IAUDa2V5ABB1c2RuQXNzZXRJZFN0b3JlAgt1c2RuQXNzZXRJZAASdXNkbkxQQXNzZXRJZFN0b3JlAg11c2RuTFBBc3NldElkAAtjb25maWdTdG9yZQIGY29uZmlnAAt1c2RuQXNzZXRJZAkA2QQBCQERQGV4dHJOYXRpdmUoMTA1OCkBBRB1c2RuQXNzZXRJZFN0b3JlAA11c2RuTFBBc3NldElkCQDZBAEJARFAZXh0ck5hdGl2ZSgxMDU4KQEFEnVzZG5MUEFzc2V0SWRTdG9yZQANY29uZmlnQWRkcmVzcwkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwULY29uZmlnU3RvcmUBB3Rocm93SWYCCWNvbmRpdGlvbgVlcnJvcgMFCWNvbmRpdGlvbgkAAgEFBWVycm9yBgEIbWFpbk9ubHkBAWkDCQEIY29udGFpbnMCCQERQGV4dHJOYXRpdmUoMTA1MykCBQ1jb25maWdBZGRyZXNzAgRtYWluCQClCAEIBQFpBmNhbGxlcgYJAAIBAhBvbmx5IG1haW4gY2FuIGRvAQlvcEFsbG93ZWQBAm9wBAckbWF0Y2gwCQD8BwQFDWNvbmZpZ0FkZHJlc3MCCW9wQWxsb3dlZAkAzAgCAgR1c2RuCQDMCAIFAm9wBQNuaWwFA25pbAMJAAECBQckbWF0Y2gwAgdCb29sZWFuBAFiBQckbWF0Y2gwAwUBYgYJAAIBAgtub3QgYWxsb3dlZAkAAgECIW9wQWxsb3dlZDogdW5leHBlY3RlZCByZXN1bHQgdHlwZQMBaQEEaW5pdAIEdXNkbgNjZmcDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAhJvbmx5IHNlbGYgY2FuIGluaXQECWxwVG9rZW5JZAkAwggFAghWVlVTRE5MUAIUVmlyZXMgVmVzdGVkIFVTRE4gTFAAAAAGBgkAzAgCBQlscFRva2VuSWQJAMwIAgkBEHdyaXRlQ29uc3RTdHJpbmcCBRB1c2RuQXNzZXRJZFN0b3JlBQR1c2RuCQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgUSdXNkbkxQQXNzZXRJZFN0b3JlCQDYBAEJALgIAQUJbHBUb2tlbklkCQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgULY29uZmlnU3RvcmUFA2NmZwUDbmlsAWkBBm1pbnRUbwEHYWRkcmVzcwQGZGVuaWVkCQACAQIGZGVuaWVkAwkAAAIFBmRlbmllZAUGZGVuaWVkBAZjaGVja3MJAQd0aHJvd0lmAgkBAiE9AgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQCCXVzZG4gb25seQULdXNkbkFzc2V0SWQCEnVzZG4gb25seSBhY2NlcHRlZAMJAAACBQZjaGVja3MFBmNoZWNrcwQGYW1vdW50CAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAkAzAgCCQEHUmVpc3N1ZQMFDXVzZG5MUEFzc2V0SWQFBmFtb3VudAYJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwkBEUBleHRyTmF0aXZlKDEwNjIpAQUHYWRkcmVzcwUGYW1vdW50BQ11c2RuTFBBc3NldElkBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEGaW1wb3J0AAQGY2hlY2tzAwMDCQEIbWFpbk9ubHkBBQFpCQEJb3BBbGxvd2VkAQIRaW1wb3J0X3Zlc3RlZF94dG4HCQEHdGhyb3dJZgIJAQIhPQIJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAggJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkAgx1c2RuIGxwIG9ubHkFDXVzZG5MUEFzc2V0SWQCFnZ2dXNkbmxwIG9ubHkgYWNjZXB0ZWQHCQEHdGhyb3dJZgIJAGYCCQELdmFsdWVPckVsc2UCCQCaCAIFDWNvbmZpZ0FkZHJlc3MCE21pbl9pbXBvcnRfdnZ1c2RubHAJAGgCCQBoAgkAaAIJAGgCAGQA6AcA6AcA6AcA6AcICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50AhRsZXNzIHRoYW4gbWluIGFtb3VudAcDCQAAAgUGY2hlY2tzBQZjaGVja3MEDGltcG9ydEFtb3VudAgJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQJAJQKAgkAzAgCCQEEQnVybgIFDXVzZG5MUEFzc2V0SWQFDGltcG9ydEFtb3VudAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFDGltcG9ydEFtb3VudAULdXNkbkFzc2V0SWQFA25pbAUMaW1wb3J0QW1vdW50CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJ0eAEGdmVyaWZ5AAQSbWF5YmVPcmFjbGVBZGRyZXNzBAckbWF0Y2gwCQCdCAIFDWNvbmZpZ0FkZHJlc3MCDm9yYWNsZV9hZGRyZXNzAwkAAQIFByRtYXRjaDACBlN0cmluZwQBcwUHJG1hdGNoMAkApggBBQFzBQR1bml0BAZIRUlHSFQFBmhlaWdodAQEQkFTRQDoBwQLcXVvcnVtUmF0aW8JARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQ1jb25maWdBZGRyZXNzAhVwcm9wb3NhbF9xdW9ydW1fcmF0aW8CInByb3Bvc2FsUXVvcnVtUmF0aW8gaXMgbm90IGRlZmluZWQEC3Bhc3NlZFJhdGlvCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUNY29uZmlnQWRkcmVzcwIVcHJvcG9zYWxfcGFzc2VkX3JhdGlvAiVwcm9wb3NhbFRocmVzaG9sZFJhdGlvIGlzIG5vdCBkZWZpbmVkBA5nVmlyZXNDb250cmFjdAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQ1jb25maWdBZGRyZXNzAhJkaXZpZGVuZHNfY29udHJhY3QCFW5vIGRpdmlkZW5kc19jb250cmFjdAIaaW52YWxpZCBkaXZpZGVuZHNfY29udHJhY3QEDnZvdGluZ0NvbnRyYWN0CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFDWNvbmZpZ0FkZHJlc3MCD3ZvdGluZ19jb250cmFjdAISbm8gdm90aW5nX2NvbnRyYWN0AhdpbnZhbGlkIHZvdGluZ19jb250cmFjdAQCaWQJANgEAQgFAnR4AmlkBAh2b3Rlc1llcwkBC3ZhbHVlT3JFbHNlAgkAmggCBQ52b3RpbmdDb250cmFjdAkArAICAg1wcm9wb3NhbF95ZXNfBQJpZAAABAd2b3Rlc05vCQELdmFsdWVPckVsc2UCCQCaCAIFDnZvdGluZ0NvbnRyYWN0CQCsAgICDHByb3Bvc2FsX25vXwUCaWQAAAQOcHJvcG9zYWxIZWlnaHQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQ52b3RpbmdDb250cmFjdAkArAICAhBwcm9wb3NhbF9oZWlnaHRfBQJpZAIXcHJvcG9zYWwgbm90IHJlZ2lzdGVyZWQECmFwcGx5U3RhcnQJAQt2YWx1ZU9yRWxzZQIJAJoIAgUOdm90aW5nQ29udHJhY3QJAKwCAgIUcHJvcG9zYWxfYXBwbHlzdGFydF8FAmlkAAAECGFwcGx5RW5kCQELdmFsdWVPckVsc2UCCQCaCAIFDnZvdGluZ0NvbnRyYWN0CQCsAgICEnByb3Bvc2FsX2FwcGx5ZW5kXwUCaWQAAAQLdG90YWxHVmlyZXMJAQt2YWx1ZU9yRWxzZQIJAJoIAgUOdm90aW5nQ29udHJhY3QJAKwCAgIQcHJvcG9zYWxfZ3ZpcmVzXwUCaWQAAAQHZW5hYmxlZAkBC3ZhbHVlT3JFbHNlAgkAmwgCBQ1jb25maWdBZGRyZXNzAh1vcF9nb3Zlcm5hbmNlX2FwcGx5X3R4X3BhdXNlZAcEB3ZvdGVZZXMFCHZvdGVzWWVzBAZ2b3RlTm8FB3ZvdGVzTm8ECnRvdGFsVm90ZXMJAGQCBQd2b3RlWWVzBQZ2b3RlTm8ECWhhc1F1b3J1bQkAZwIJAGkCCQBoAgUKdG90YWxWb3RlcwUEQkFTRQULdG90YWxHVmlyZXMFC3F1b3J1bVJhdGlvBAloYXNQYXNzZWQJAGcCCQBpAgkAaAIFB3ZvdGVZZXMFBEJBU0UFCnRvdGFsVm90ZXMFC3Bhc3NlZFJhdGlvBAh0b29FYXJseQkAZwIFCmFwcGx5U3RhcnQFBkhFSUdIVAQHdG9vTGF0ZQkAZwIFBkhFSUdIVAUIYXBwbHlFbmQECXRpbWVEZWJ1ZwkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAhFwcm9wb3NhbEhlaWdodCA9IAkApAMBBQ5wcm9wb3NhbEhlaWdodAIPLCBhcHBseVN0YXJ0ID0gCQCkAwEFCmFwcGx5U3RhcnQCDSwgYXBwbHlFbmQgPSAJAKQDAQUIYXBwbHlFbmQCCywgSEVJR0hUID0gCQCkAwEFBkhFSUdIVAQIYnlWb3RpbmcDCQEBIQEFB2VuYWJsZWQJAAIBAit0eCBhcHBsaWNhdGlvbiB0aHJvdyBnb3Zlcm5hbmNlIG5vdCBlbmFibGVkAwUIdG9vRWFybHkJAAIBCQCsAgICLnByb3Bvc2FsIGNhbid0IGJlIGV4ZWN1dGVkIGFzIGl0J3MgdG9vIGVhcmx5OiAFCXRpbWVEZWJ1ZwMFB3Rvb0xhdGUJAAIBCQCsAgICLHByb3Bvc2FsIGNhbid0IGJlIGV4ZWN1dGVkIGFzIGl0J3MgdG9vIGxhdGU6BQl0aW1lRGVidWcDCQEBIQEFCWhhc1F1b3J1bQkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICC25vIHF1b3J1bTogAgx0b3RhbFZvdGVzOiAJAKQDAQUKdG90YWxWb3RlcwIPLCB0b3RhbEdWaXJlczogCQCkAwEFC3RvdGFsR1ZpcmVzAg8sIHF1b3J1bVJhdGlvOiAJAKQDAQULcXVvcnVtUmF0aW8DCQEBIQEFCWhhc1Bhc3NlZAkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICF25vIHRocmVzaG9sZCBhY2hpZXZlZDogAgl2b3RlWWVzOiAJAKQDAQUHdm90ZVllcwIKLCB2b3RlTm86IAkApAMBBQZ2b3RlTm8CDywgcGFzc2VkUmF0aW86IAkApAMBBQtwYXNzZWRSYXRpbwYDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAACAUCdHgPc2VuZGVyUHVibGljS2V5BgUIYnlWb3RpbmcLclYa", "chainId": 87, "height": 3997452, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: DXAiAiu3Qx4Zf8UjFpj1YxazV88AkRKTBN9zKAC68ZKf Next: 9LddbbZqFDQt874tNVvTaoACYqCxfKWrt61Wdes2Kxfm Diff:
OldNewDifferences
5050
5151 @Callable(i)
5252 func mintTo (address) = {
53- let checks = throwIf((valueOrErrorMessage(i.payments[0].assetId, "usdn only") != usdnAssetId), "usdn only accepted")
54- if ((checks == checks))
53+ let denied = throw("denied")
54+ if ((denied == denied))
5555 then {
56- let amount = i.payments[0].amount
56+ let checks = throwIf((valueOrErrorMessage(i.payments[0].assetId, "usdn only") != usdnAssetId), "usdn only accepted")
57+ if ((checks == checks))
58+ then {
59+ let amount = i.payments[0].amount
5760 [Reissue(usdnLPAssetId, amount, true), ScriptTransfer(addressFromStringValue(address), amount, usdnLPAssetId)]
61+ }
62+ else throw("Strict value is not equal to itself.")
5863 }
5964 else throw("Strict value is not equal to itself.")
6065 }
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 func writeConstString (key,value) = if (!(isDefined(getString(this, key))))
55 then StringEntry(key, value)
66 else throw(("already initialized: " + key))
77
88
99 let usdnAssetIdStore = "usdnAssetId"
1010
1111 let usdnLPAssetIdStore = "usdnLPAssetId"
1212
1313 let configStore = "config"
1414
1515 let usdnAssetId = fromBase58String(getStringValue(usdnAssetIdStore))
1616
1717 let usdnLPAssetId = fromBase58String(getStringValue(usdnLPAssetIdStore))
1818
1919 let configAddress = addressFromStringValue(getStringValue(this, configStore))
2020
2121 func throwIf (condition,error) = if (condition)
2222 then throw(error)
2323 else true
2424
2525
2626 func mainOnly (i) = if (contains(getStringValue(configAddress, "main"), toString(i.caller)))
2727 then true
2828 else throw("only main can do")
2929
3030
3131 func opAllowed (op) = match invoke(configAddress, "opAllowed", ["usdn", op], nil) {
3232 case b: Boolean =>
3333 if (b)
3434 then true
3535 else throw("not allowed")
3636 case _ =>
3737 throw("opAllowed: unexpected result type")
3838 }
3939
4040
4141 @Callable(i)
4242 func init (usdn,cfg) = if ((i.caller != this))
4343 then throw("only self can init")
4444 else {
4545 let lpTokenId = Issue("VVUSDNLP", "Vires Vested USDN LP", 0, 6, true)
4646 [lpTokenId, writeConstString(usdnAssetIdStore, usdn), writeConstString(usdnLPAssetIdStore, toBase58String(calculateAssetId(lpTokenId))), writeConstString(configStore, cfg)]
4747 }
4848
4949
5050
5151 @Callable(i)
5252 func mintTo (address) = {
53- let checks = throwIf((valueOrErrorMessage(i.payments[0].assetId, "usdn only") != usdnAssetId), "usdn only accepted")
54- if ((checks == checks))
53+ let denied = throw("denied")
54+ if ((denied == denied))
5555 then {
56- let amount = i.payments[0].amount
56+ let checks = throwIf((valueOrErrorMessage(i.payments[0].assetId, "usdn only") != usdnAssetId), "usdn only accepted")
57+ if ((checks == checks))
58+ then {
59+ let amount = i.payments[0].amount
5760 [Reissue(usdnLPAssetId, amount, true), ScriptTransfer(addressFromStringValue(address), amount, usdnLPAssetId)]
61+ }
62+ else throw("Strict value is not equal to itself.")
5863 }
5964 else throw("Strict value is not equal to itself.")
6065 }
6166
6267
6368
6469 @Callable(i)
6570 func import () = {
6671 let checks = if (if (if (mainOnly(i))
6772 then opAllowed("import_vested_xtn")
6873 else false)
6974 then throwIf((valueOrErrorMessage(i.payments[0].assetId, "usdn lp only") != usdnLPAssetId), "vvusdnlp only accepted")
7075 else false)
7176 then throwIf((valueOrElse(getInteger(configAddress, "min_import_vvusdnlp"), ((((100 * 1000) * 1000) * 1000) * 1000)) > i.payments[0].amount), "less than min amount")
7277 else false
7378 if ((checks == checks))
7479 then {
7580 let importAmount = i.payments[0].amount
7681 $Tuple2([Burn(usdnLPAssetId, importAmount), ScriptTransfer(i.caller, importAmount, usdnAssetId)], importAmount)
7782 }
7883 else throw("Strict value is not equal to itself.")
7984 }
8085
8186
8287 @Verifier(tx)
8388 func verify () = {
8489 let maybeOracleAddress = match getString(configAddress, "oracle_address") {
8590 case s: String =>
8691 addressFromString(s)
8792 case _ =>
8893 unit
8994 }
9095 let HEIGHT = height
9196 let BASE = 1000
9297 let quorumRatio = valueOrErrorMessage(getInteger(configAddress, "proposal_quorum_ratio"), "proposalQuorumRatio is not defined")
9398 let passedRatio = valueOrErrorMessage(getInteger(configAddress, "proposal_passed_ratio"), "proposalThresholdRatio is not defined")
9499 let gViresContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "dividends_contract"), "no dividends_contract")), "invalid dividends_contract")
95100 let votingContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "voting_contract"), "no voting_contract")), "invalid voting_contract")
96101 let id = toBase58String(tx.id)
97102 let votesYes = valueOrElse(getInteger(votingContract, ("proposal_yes_" + id)), 0)
98103 let votesNo = valueOrElse(getInteger(votingContract, ("proposal_no_" + id)), 0)
99104 let proposalHeight = valueOrErrorMessage(getInteger(votingContract, ("proposal_height_" + id)), "proposal not registered")
100105 let applyStart = valueOrElse(getInteger(votingContract, ("proposal_applystart_" + id)), 0)
101106 let applyEnd = valueOrElse(getInteger(votingContract, ("proposal_applyend_" + id)), 0)
102107 let totalGVires = valueOrElse(getInteger(votingContract, ("proposal_gvires_" + id)), 0)
103108 let enabled = valueOrElse(getBoolean(configAddress, "op_governance_apply_tx_paused"), false)
104109 let voteYes = votesYes
105110 let voteNo = votesNo
106111 let totalVotes = (voteYes + voteNo)
107112 let hasQuorum = (((totalVotes * BASE) / totalGVires) >= quorumRatio)
108113 let hasPassed = (((voteYes * BASE) / totalVotes) >= passedRatio)
109114 let tooEarly = (applyStart >= HEIGHT)
110115 let tooLate = (HEIGHT >= applyEnd)
111116 let timeDebug = ((((((("proposalHeight = " + toString(proposalHeight)) + ", applyStart = ") + toString(applyStart)) + ", applyEnd = ") + toString(applyEnd)) + ", HEIGHT = ") + toString(HEIGHT))
112117 let byVoting = if (!(enabled))
113118 then throw("tx application throw governance not enabled")
114119 else if (tooEarly)
115120 then throw(("proposal can't be executed as it's too early: " + timeDebug))
116121 else if (tooLate)
117122 then throw(("proposal can't be executed as it's too late:" + timeDebug))
118123 else if (!(hasQuorum))
119124 then throw((((((("no quorum: " + "totalVotes: ") + toString(totalVotes)) + ", totalGVires: ") + toString(totalGVires)) + ", quorumRatio: ") + toString(quorumRatio)))
120125 else if (!(hasPassed))
121126 then throw((((((("no threshold achieved: " + "voteYes: ") + toString(voteYes)) + ", voteNo: ") + toString(voteNo)) + ", passedRatio: ") + toString(passedRatio)))
122127 else true
123128 if (sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey))
124129 then true
125130 else byVoting
126131 }
127132

github/deemru/w8io/6500d08 
31.80 ms