tx · DXAiAiu3Qx4Zf8UjFpj1YxazV88AkRKTBN9zKAC68ZKf

3PJFu8MmVa2rSVGM48wdLm4jhLznEgu6XSe:  -0.00900000 Waves

2024.01.14 12:18 [3996783] smart account 3PJFu8MmVa2rSVGM48wdLm4jhLznEgu6XSe > SELF 0.00000000 Waves

{ "type": 13, "id": "DXAiAiu3Qx4Zf8UjFpj1YxazV88AkRKTBN9zKAC68ZKf", "fee": 900000, "feeAssetId": null, "timestamp": 1705223947772, "version": 1, "sender": "3PJFu8MmVa2rSVGM48wdLm4jhLznEgu6XSe", "senderPublicKey": "5k59JsDv4Nh9KgnBQFfggScT4ce5vtoDmzQwivD8hgpc", "proofs": [ "2fzy84cZwMNzM3uV4B9hxRLWN12ZHYMHhoHsXHe5VzYXPZaR3RUHqzSyhfyD1vuDRLqJG9proMdt4pty6cirE78d" ], "script": "base64:BgIPCAISBAoCCAgSAwoBCBIACgEQd3JpdGVDb25zdFN0cmluZwIDa2V5BXZhbHVlAwkBASEBCQEJaXNEZWZpbmVkAQkAnQgCBQR0aGlzBQNrZXkJAQtTdHJpbmdFbnRyeQIFA2tleQUFdmFsdWUJAAIBCQCsAgICFWFscmVhZHkgaW5pdGlhbGl6ZWQ6IAUDa2V5ABB1c2RuQXNzZXRJZFN0b3JlAgt1c2RuQXNzZXRJZAASdXNkbkxQQXNzZXRJZFN0b3JlAg11c2RuTFBBc3NldElkAAtjb25maWdTdG9yZQIGY29uZmlnAAt1c2RuQXNzZXRJZAkA2QQBCQERQGV4dHJOYXRpdmUoMTA1OCkBBRB1c2RuQXNzZXRJZFN0b3JlAA11c2RuTFBBc3NldElkCQDZBAEJARFAZXh0ck5hdGl2ZSgxMDU4KQEFEnVzZG5MUEFzc2V0SWRTdG9yZQANY29uZmlnQWRkcmVzcwkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwULY29uZmlnU3RvcmUBB3Rocm93SWYCCWNvbmRpdGlvbgVlcnJvcgMFCWNvbmRpdGlvbgkAAgEFBWVycm9yBgEIbWFpbk9ubHkBAWkDCQEIY29udGFpbnMCCQERQGV4dHJOYXRpdmUoMTA1MykCBQ1jb25maWdBZGRyZXNzAgRtYWluCQClCAEIBQFpBmNhbGxlcgYJAAIBAhBvbmx5IG1haW4gY2FuIGRvAQlvcEFsbG93ZWQBAm9wBAckbWF0Y2gwCQD8BwQFDWNvbmZpZ0FkZHJlc3MCCW9wQWxsb3dlZAkAzAgCAgR1c2RuCQDMCAIFAm9wBQNuaWwFA25pbAMJAAECBQckbWF0Y2gwAgdCb29sZWFuBAFiBQckbWF0Y2gwAwUBYgYJAAIBAgtub3QgYWxsb3dlZAkAAgECIW9wQWxsb3dlZDogdW5leHBlY3RlZCByZXN1bHQgdHlwZQMBaQEEaW5pdAIEdXNkbgNjZmcDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAhJvbmx5IHNlbGYgY2FuIGluaXQECWxwVG9rZW5JZAkAwggFAghWVlVTRE5MUAIUVmlyZXMgVmVzdGVkIFVTRE4gTFAAAAAGBgkAzAgCBQlscFRva2VuSWQJAMwIAgkBEHdyaXRlQ29uc3RTdHJpbmcCBRB1c2RuQXNzZXRJZFN0b3JlBQR1c2RuCQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgUSdXNkbkxQQXNzZXRJZFN0b3JlCQDYBAEJALgIAQUJbHBUb2tlbklkCQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgULY29uZmlnU3RvcmUFA2NmZwUDbmlsAWkBBm1pbnRUbwEHYWRkcmVzcwQGY2hlY2tzCQEHdGhyb3dJZgIJAQIhPQIJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAggJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkAgl1c2RuIG9ubHkFC3VzZG5Bc3NldElkAhJ1c2RuIG9ubHkgYWNjZXB0ZWQDCQAAAgUGY2hlY2tzBQZjaGVja3MEBmFtb3VudAgJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQJAMwIAgkBB1JlaXNzdWUDBQ11c2RuTFBBc3NldElkBQZhbW91bnQGCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMJARFAZXh0ck5hdGl2ZSgxMDYyKQEFB2FkZHJlc3MFBmFtb3VudAUNdXNkbkxQQXNzZXRJZAUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBBmltcG9ydAAEBmNoZWNrcwMDAwkBCG1haW5Pbmx5AQUBaQkBCW9wQWxsb3dlZAECEWltcG9ydF92ZXN0ZWRfeHRuBwkBB3Rocm93SWYCCQECIT0CCQETdmFsdWVPckVycm9yTWVzc2FnZQIICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAIMdXNkbiBscCBvbmx5BQ11c2RuTFBBc3NldElkAhZ2dnVzZG5scCBvbmx5IGFjY2VwdGVkBwkBB3Rocm93SWYCCQBmAgkBC3ZhbHVlT3JFbHNlAgkAmggCBQ1jb25maWdBZGRyZXNzAhNtaW5faW1wb3J0X3Z2dXNkbmxwCQBoAgkAaAIJAGgCCQBoAgBkAOgHAOgHAOgHAOgHCAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAIUbGVzcyB0aGFuIG1pbiBhbW91bnQHAwkAAAIFBmNoZWNrcwUGY2hlY2tzBAxpbXBvcnRBbW91bnQICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50CQCUCgIJAMwIAgkBBEJ1cm4CBQ11c2RuTFBBc3NldElkBQxpbXBvcnRBbW91bnQJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyBQxpbXBvcnRBbW91bnQFC3VzZG5Bc3NldElkBQNuaWwFDGltcG9ydEFtb3VudAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgECdHgBBnZlcmlmeQAEEm1heWJlT3JhY2xlQWRkcmVzcwQHJG1hdGNoMAkAnQgCBQ1jb25maWdBZGRyZXNzAg5vcmFjbGVfYWRkcmVzcwMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAXMFByRtYXRjaDAJAKYIAQUBcwUEdW5pdAQGSEVJR0hUBQZoZWlnaHQEBEJBU0UA6AcEC3F1b3J1bVJhdGlvCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUNY29uZmlnQWRkcmVzcwIVcHJvcG9zYWxfcXVvcnVtX3JhdGlvAiJwcm9wb3NhbFF1b3J1bVJhdGlvIGlzIG5vdCBkZWZpbmVkBAtwYXNzZWRSYXRpbwkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFDWNvbmZpZ0FkZHJlc3MCFXByb3Bvc2FsX3Bhc3NlZF9yYXRpbwIlcHJvcG9zYWxUaHJlc2hvbGRSYXRpbyBpcyBub3QgZGVmaW5lZAQOZ1ZpcmVzQ29udHJhY3QJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUNY29uZmlnQWRkcmVzcwISZGl2aWRlbmRzX2NvbnRyYWN0AhVubyBkaXZpZGVuZHNfY29udHJhY3QCGmludmFsaWQgZGl2aWRlbmRzX2NvbnRyYWN0BA52b3RpbmdDb250cmFjdAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQ1jb25maWdBZGRyZXNzAg92b3RpbmdfY29udHJhY3QCEm5vIHZvdGluZ19jb250cmFjdAIXaW52YWxpZCB2b3RpbmdfY29udHJhY3QEAmlkCQDYBAEIBQJ0eAJpZAQIdm90ZXNZZXMJAQt2YWx1ZU9yRWxzZQIJAJoIAgUOdm90aW5nQ29udHJhY3QJAKwCAgINcHJvcG9zYWxfeWVzXwUCaWQAAAQHdm90ZXNObwkBC3ZhbHVlT3JFbHNlAgkAmggCBQ52b3RpbmdDb250cmFjdAkArAICAgxwcm9wb3NhbF9ub18FAmlkAAAEDnByb3Bvc2FsSGVpZ2h0CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUOdm90aW5nQ29udHJhY3QJAKwCAgIQcHJvcG9zYWxfaGVpZ2h0XwUCaWQCF3Byb3Bvc2FsIG5vdCByZWdpc3RlcmVkBAphcHBseVN0YXJ0CQELdmFsdWVPckVsc2UCCQCaCAIFDnZvdGluZ0NvbnRyYWN0CQCsAgICFHByb3Bvc2FsX2FwcGx5c3RhcnRfBQJpZAAABAhhcHBseUVuZAkBC3ZhbHVlT3JFbHNlAgkAmggCBQ52b3RpbmdDb250cmFjdAkArAICAhJwcm9wb3NhbF9hcHBseWVuZF8FAmlkAAAEC3RvdGFsR1ZpcmVzCQELdmFsdWVPckVsc2UCCQCaCAIFDnZvdGluZ0NvbnRyYWN0CQCsAgICEHByb3Bvc2FsX2d2aXJlc18FAmlkAAAEB2VuYWJsZWQJAQt2YWx1ZU9yRWxzZQIJAJsIAgUNY29uZmlnQWRkcmVzcwIdb3BfZ292ZXJuYW5jZV9hcHBseV90eF9wYXVzZWQHBAd2b3RlWWVzBQh2b3Rlc1llcwQGdm90ZU5vBQd2b3Rlc05vBAp0b3RhbFZvdGVzCQBkAgUHdm90ZVllcwUGdm90ZU5vBAloYXNRdW9ydW0JAGcCCQBpAgkAaAIFCnRvdGFsVm90ZXMFBEJBU0UFC3RvdGFsR1ZpcmVzBQtxdW9ydW1SYXRpbwQJaGFzUGFzc2VkCQBnAgkAaQIJAGgCBQd2b3RlWWVzBQRCQVNFBQp0b3RhbFZvdGVzBQtwYXNzZWRSYXRpbwQIdG9vRWFybHkJAGcCBQphcHBseVN0YXJ0BQZIRUlHSFQEB3Rvb0xhdGUJAGcCBQZIRUlHSFQFCGFwcGx5RW5kBAl0aW1lRGVidWcJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgIRcHJvcG9zYWxIZWlnaHQgPSAJAKQDAQUOcHJvcG9zYWxIZWlnaHQCDywgYXBwbHlTdGFydCA9IAkApAMBBQphcHBseVN0YXJ0Ag0sIGFwcGx5RW5kID0gCQCkAwEFCGFwcGx5RW5kAgssIEhFSUdIVCA9IAkApAMBBQZIRUlHSFQECGJ5Vm90aW5nAwkBASEBBQdlbmFibGVkCQACAQIrdHggYXBwbGljYXRpb24gdGhyb3cgZ292ZXJuYW5jZSBub3QgZW5hYmxlZAMFCHRvb0Vhcmx5CQACAQkArAICAi5wcm9wb3NhbCBjYW4ndCBiZSBleGVjdXRlZCBhcyBpdCdzIHRvbyBlYXJseTogBQl0aW1lRGVidWcDBQd0b29MYXRlCQACAQkArAICAixwcm9wb3NhbCBjYW4ndCBiZSBleGVjdXRlZCBhcyBpdCdzIHRvbyBsYXRlOgUJdGltZURlYnVnAwkBASEBBQloYXNRdW9ydW0JAAIBCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAgtubyBxdW9ydW06IAIMdG90YWxWb3RlczogCQCkAwEFCnRvdGFsVm90ZXMCDywgdG90YWxHVmlyZXM6IAkApAMBBQt0b3RhbEdWaXJlcwIPLCBxdW9ydW1SYXRpbzogCQCkAwEFC3F1b3J1bVJhdGlvAwkBASEBBQloYXNQYXNzZWQJAAIBCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAhdubyB0aHJlc2hvbGQgYWNoaWV2ZWQ6IAIJdm90ZVllczogCQCkAwEFB3ZvdGVZZXMCCiwgdm90ZU5vOiAJAKQDAQUGdm90ZU5vAg8sIHBhc3NlZFJhdGlvOiAJAKQDAQULcGFzc2VkUmF0aW8GAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAgFAnR4D3NlbmRlclB1YmxpY0tleQYFCGJ5Vm90aW5nZF2CSQ==", "chainId": 87, "height": 3996783, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: DhUYBwMh5PgmeZd7Qig3HrYeg9QTtqACj5qnbqmQWNPH Next: ALCMKeL27skgMQUWmVGkjGDRkFF6ZQLnm1RPV2G7S6K2 Diff:
OldNewDifferences
5050
5151 @Callable(i)
5252 func mintTo (address) = {
53- let d = throw("paused")
54- if ((d == d))
53+ let checks = throwIf((valueOrErrorMessage(i.payments[0].assetId, "usdn only") != usdnAssetId), "usdn only accepted")
54+ if ((checks == checks))
5555 then {
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
56+ let amount = i.payments[0].amount
6057 [Reissue(usdnLPAssetId, amount, true), ScriptTransfer(addressFromStringValue(address), amount, usdnLPAssetId)]
61- }
62- else throw("Strict value is not equal to itself.")
6358 }
6459 else throw("Strict value is not equal to itself.")
6560 }
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 d = throw("paused")
54- if ((d == d))
53+ let checks = throwIf((valueOrErrorMessage(i.payments[0].assetId, "usdn only") != usdnAssetId), "usdn only accepted")
54+ if ((checks == checks))
5555 then {
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
56+ let amount = i.payments[0].amount
6057 [Reissue(usdnLPAssetId, amount, true), ScriptTransfer(addressFromStringValue(address), amount, usdnLPAssetId)]
61- }
62- else throw("Strict value is not equal to itself.")
6358 }
6459 else throw("Strict value is not equal to itself.")
6560 }
6661
6762
6863
6964 @Callable(i)
7065 func import () = {
7166 let checks = if (if (if (mainOnly(i))
7267 then opAllowed("import_vested_xtn")
7368 else false)
7469 then throwIf((valueOrErrorMessage(i.payments[0].assetId, "usdn lp only") != usdnLPAssetId), "vvusdnlp only accepted")
7570 else false)
7671 then throwIf((valueOrElse(getInteger(configAddress, "min_import_vvusdnlp"), ((((100 * 1000) * 1000) * 1000) * 1000)) > i.payments[0].amount), "less than min amount")
7772 else false
7873 if ((checks == checks))
7974 then {
8075 let importAmount = i.payments[0].amount
8176 $Tuple2([Burn(usdnLPAssetId, importAmount), ScriptTransfer(i.caller, importAmount, usdnAssetId)], importAmount)
8277 }
8378 else throw("Strict value is not equal to itself.")
8479 }
8580
8681
8782 @Verifier(tx)
8883 func verify () = {
8984 let maybeOracleAddress = match getString(configAddress, "oracle_address") {
9085 case s: String =>
9186 addressFromString(s)
9287 case _ =>
9388 unit
9489 }
9590 let HEIGHT = height
9691 let BASE = 1000
9792 let quorumRatio = valueOrErrorMessage(getInteger(configAddress, "proposal_quorum_ratio"), "proposalQuorumRatio is not defined")
9893 let passedRatio = valueOrErrorMessage(getInteger(configAddress, "proposal_passed_ratio"), "proposalThresholdRatio is not defined")
9994 let gViresContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "dividends_contract"), "no dividends_contract")), "invalid dividends_contract")
10095 let votingContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "voting_contract"), "no voting_contract")), "invalid voting_contract")
10196 let id = toBase58String(tx.id)
10297 let votesYes = valueOrElse(getInteger(votingContract, ("proposal_yes_" + id)), 0)
10398 let votesNo = valueOrElse(getInteger(votingContract, ("proposal_no_" + id)), 0)
10499 let proposalHeight = valueOrErrorMessage(getInteger(votingContract, ("proposal_height_" + id)), "proposal not registered")
105100 let applyStart = valueOrElse(getInteger(votingContract, ("proposal_applystart_" + id)), 0)
106101 let applyEnd = valueOrElse(getInteger(votingContract, ("proposal_applyend_" + id)), 0)
107102 let totalGVires = valueOrElse(getInteger(votingContract, ("proposal_gvires_" + id)), 0)
108103 let enabled = valueOrElse(getBoolean(configAddress, "op_governance_apply_tx_paused"), false)
109104 let voteYes = votesYes
110105 let voteNo = votesNo
111106 let totalVotes = (voteYes + voteNo)
112107 let hasQuorum = (((totalVotes * BASE) / totalGVires) >= quorumRatio)
113108 let hasPassed = (((voteYes * BASE) / totalVotes) >= passedRatio)
114109 let tooEarly = (applyStart >= HEIGHT)
115110 let tooLate = (HEIGHT >= applyEnd)
116111 let timeDebug = ((((((("proposalHeight = " + toString(proposalHeight)) + ", applyStart = ") + toString(applyStart)) + ", applyEnd = ") + toString(applyEnd)) + ", HEIGHT = ") + toString(HEIGHT))
117112 let byVoting = if (!(enabled))
118113 then throw("tx application throw governance not enabled")
119114 else if (tooEarly)
120115 then throw(("proposal can't be executed as it's too early: " + timeDebug))
121116 else if (tooLate)
122117 then throw(("proposal can't be executed as it's too late:" + timeDebug))
123118 else if (!(hasQuorum))
124119 then throw((((((("no quorum: " + "totalVotes: ") + toString(totalVotes)) + ", totalGVires: ") + toString(totalGVires)) + ", quorumRatio: ") + toString(quorumRatio)))
125120 else if (!(hasPassed))
126121 then throw((((((("no threshold achieved: " + "voteYes: ") + toString(voteYes)) + ", voteNo: ") + toString(voteNo)) + ", passedRatio: ") + toString(passedRatio)))
127122 else true
128123 if (sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey))
129124 then true
130125 else byVoting
131126 }
132127

github/deemru/w8io/3ef1775 
34.32 ms