tx · 4tAa5vcTppjzsLaGqrHWCzyo39w1C17tEwK5N6LtBMvq

3PGWhtvCSz1TRJhe3BJSrvQigrtKuyXsgma:  -0.01000000 Waves

2023.04.03 12:05 [3583819] smart account 3PGWhtvCSz1TRJhe3BJSrvQigrtKuyXsgma > SELF 0.00000000 Waves

{ "type": 13, "id": "4tAa5vcTppjzsLaGqrHWCzyo39w1C17tEwK5N6LtBMvq", "fee": 1000000, "feeAssetId": null, "timestamp": 1680512716246, "version": 1, "sender": "3PGWhtvCSz1TRJhe3BJSrvQigrtKuyXsgma", "senderPublicKey": "4MpZMd8gCopeSW5sZNQx6DnKTcckE7ckhX1QArMdUiyT", "proofs": [ "37ADtX5u8UM38u3xkzdBzK49CT8KuPBw3ADWrAceKZptLMNH86VwDX7qSEN3iAeiDuHAq8Sxm3CPqeeuKYqChNDh" ], "script": "base64:BgIWCAISAwoBCBIDCgEIEgMKAQgSAwoBCA4BC3dyaXRlU3RyaW5nAgNrZXkFdmFsdWUJAQtTdHJpbmdFbnRyeQIFA2tleQUFdmFsdWUBEHdyaXRlQ29uc3RTdHJpbmcCA2tleQV2YWx1ZQMJAQEhAQkBCWlzRGVmaW5lZAEJAJ0IAgUEdGhpcwUDa2V5CQELU3RyaW5nRW50cnkCBQNrZXkFBXZhbHVlCQACAQkArAICAhVhbHJlYWR5IGluaXRpYWxpemVkOiAFA2tleQANY29uZmlnQWRkcmVzcwUEdGhpcwAGSEVJR0hUBQZoZWlnaHQBBmFkdmlzZQAJAKwCAgIIaGVpZ2h0OiAJAKQDAQUGSEVJR0hUAANvcHMJAMwIAgITZ292ZXJuYW5jZV9hcHBseV90eAkAzAgCAgRtaW50CQDMCAICBXN0YWtlCQDMCAICCHN0YWtlRm9yCQDMCAICB3Vuc3Rha2UJAMwIAgILdW5zdGFrZUZyb20JAMwIAgINY2xhaW1BbmRTdGFrZQkAzAgCAhVnb3Zlcm5hbmNlX3Byb3Bvc2VfdHgJAMwIAgISZ292ZXJuYW5jZV92b3RlX3R4CQDMCAICF2dvdmVybmFuY2VfcmV0cmFjdF92b3RlCQDMCAICHmdvdmVybmFuY2VfcmV0cmFjdF9wcm9wb3NhbF90eAkAzAgCAgdwcm9qZWN0CQDMCAICBmNvbW1pdAkAzAgCAgp1bmRvQ29tbWl0CQDMCAICCnByb2plY3RGb3IJAMwIAgINaW5jcmVyYXNlU2tpbgkAzAgCAgljb21taXRGb3IJAMwIAgIGaW52ZXN0CQDMCAICBXN0YXJ0CQDMCAICBXNsYXNoCQDMCAICCGNvbXBsZXRlCQDMCAICBmNhbmNlbAkAzAgCAgp1bmRvSW52ZXN0CQDMCAICDXVuZG9Db21taXRGb3IJAMwIAgIFc3RhcnQJAMwIAgIFc2xhc2gFA25pbAASc3lzdGVtQ29udHJvbFN0b3JlAg5zeXN0ZW1fYWxsb3dlZAEOb3BBbGxvd2VkU3RvcmUBAm9wAwkBCWlzRGVmaW5lZAEJAM8IAgUDb3BzBQJvcAkArAICCQCsAgICA29wXwUCb3ACCF9hbGxvd2VkCQACAQkArAICCQCsAgICFkludmFsaWQgYXJndW1lbnQ6IG9wLiAFAm9wAhwgb3BlcmF0aW9uIGlzIG5vdCByZWdpc3RlcmVkAQ5vcFVucGF1c2VTdG9yZQECb3AJAKwCAgkArAICAgNvcF8FAm9wAgxfdW5wYXVzZWRfYnkADnNlbnRpbmVsc1N0b3JlAglzZW50aW5lbHMADHNlbnRpbmVsc1N0cgkAnQgCBQR0aGlzBQ5zZW50aW5lbHNTdG9yZQAJc2VudGluZWxzAwkBCWlzRGVmaW5lZAEFDHNlbnRpbmVsc1N0cgkAtQkCCQEFdmFsdWUBBQxzZW50aW5lbHNTdHICASwFA25pbAEOYXNzZXJ0U2VudGluZWwBAXMJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAzwgCBQlzZW50aW5lbHMJAKUIAQUBcwIOcGF1c2VPcCBkZW5pZWQBBnF1b3J1bQAEA2FsbAkAkAMBBQlzZW50aW5lbHMDCQBmAgADBQNhbGwAAQkAZAIJAGkCBQNhbGwAAgABBAFpAQlvcEFsbG93ZWQBAm9wBAVzdG9yZQkBDm9wQWxsb3dlZFN0b3JlAQUCb3ADCQEIY29udGFpbnMCCQELdmFsdWVPckVsc2UCCQCdCAIFBHRoaXMCCHN0b3BsaXN0AgAJAKUIAQgFAWkMb3JpZ2luQ2FsbGVyCQACAQIcb3BlcmF0aW9uIHBhdXNlZCBieSBzdG9wbGlzdAMJAQhjb250YWlucwIJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUEdGhpcwIDZXhjAgAJAKUIAQgFAWkMb3JpZ2luQ2FsbGVyCQCUCgIFA25pbAYECGVuYWJsZWQwCQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMFEnN5c3RlbUNvbnRyb2xTdG9yZQYECGVuYWJsZWQxCQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMFBXN0b3JlBgMJAQEhAQUIZW5hYmxlZDAJAAIBCQCsAgIJAKwCAgIUb3BlcmF0aW9uIHBhdXNlZCBieSAFEnN5c3RlbUNvbnRyb2xTdG9yZQIGPWZhbHNlAwkBASEBBQhlbmFibGVkMQkAAgEJAKwCAgkArAICAhRvcGVyYXRpb24gcGF1c2VkIGJ5IAUFc3RvcmUCBj1mYWxzZQkAlAoCBQNuaWwGAWkBB3BhdXNlT3ABAm9wBAFzCQEOYXNzZXJ0U2VudGluZWwBCAUBaQZjYWxsZXIDCQAAAgUBcwUBcwkAzAgCCQEMQm9vbGVhbkVudHJ5AgkBDm9wQWxsb3dlZFN0b3JlAQUCb3AHBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEJdW5wYXVzZU9wAQJvcAQBcwkBDmFzc2VydFNlbnRpbmVsAQgFAWkGY2FsbGVyAwkAAAIFAXMFAXMEBXN0b3JlCQEOb3BBbGxvd2VkU3RvcmUBBQJvcAMJAQt2YWx1ZU9yRWxzZQIJAJsIAgUEdGhpcwUFc3RvcmUGCQACAQIcdW5wYXVzZU9wOiBpbnZhbGlkIG9wZXJhdGlvbgQIc2VudGluZWwJAKUIAQgFAWkGY2FsbGVyBA91bnBhdXNlZEJ5U3RvcmUJAQ5vcFVucGF1c2VTdG9yZQEFAm9wBA11bnBhdXNlZEJ5U3RyCQCdCAIFBHRoaXMFD3VucGF1c2VkQnlTdG9yZQQBcQkBBnF1b3J1bQADCQEJaXNEZWZpbmVkAQUNdW5wYXVzZWRCeVN0cgQPdW5wYXVzZWRCeVZhbHVlCQEFdmFsdWUBBQ11bnBhdXNlZEJ5U3RyBAp1bnBhdXNlZEJ5CQC1CQIFD3VucGF1c2VkQnlWYWx1ZQIBLAMJAQlpc0RlZmluZWQBCQDPCAIFCnVucGF1c2VkQnkFCHNlbnRpbmVsCQACAQIRZHVwbGljYXRlIHVucGF1c2UDCQAAAgkAZAIJAJADAQUKdW5wYXVzZWRCeQABBQFxCQDMCAIJAQtEZWxldGVFbnRyeQEFBXN0b3JlCQDMCAIJAQtEZWxldGVFbnRyeQEFD3VucGF1c2VkQnlTdG9yZQUDbmlsCQDMCAIJAQtTdHJpbmdFbnRyeQIFD3VucGF1c2VkQnlTdG9yZQkArAICCQCsAgIFD3VucGF1c2VkQnlWYWx1ZQIBLAUIc2VudGluZWwFA25pbAMJAAACBQFxAAEJAMwIAgkBC0RlbGV0ZUVudHJ5AQUFc3RvcmUFA25pbAkAzAgCCQELU3RyaW5nRW50cnkCBQ91bnBhdXNlZEJ5U3RvcmUFCHNlbnRpbmVsBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQELYWRkU2VudGluZWwBCHNlbnRpbmVsAwkBAiE9AggFAWkGY2FsbGVyBQR0aGlzCQACAQIab25seSBzZWxmIGNhbiBhZGQgc2VudGluZWwDCQEBIQEJAQlpc0RlZmluZWQBBQxzZW50aW5lbHNTdHIJAMwIAgkBC1N0cmluZ0VudHJ5AgUOc2VudGluZWxzU3RvcmUFCHNlbnRpbmVsBQNuaWwDCQEJaXNEZWZpbmVkAQkAzwgCBQlzZW50aW5lbHMFCHNlbnRpbmVsBQNuaWwJAMwIAgkBC1N0cmluZ0VudHJ5AgUOc2VudGluZWxzU3RvcmUJAKwCAgkArAICCQEFdmFsdWUBBQxzZW50aW5lbHNTdHICASwFCHNlbnRpbmVsBQNuaWwBAnR4AQZ2ZXJpZnkABAt0aGlzQWRkcmVzcwkApQgBBQR0aGlzBARCQVNFAOgHBBB2b3RpbmdBZGRyZXNzU3RyCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUNY29uZmlnQWRkcmVzcwIPY29udHJhY3Rfdm90aW5nAhh2b3RpbmcgYWRkcmVzcyBub3QgZm91bmQEDnZvdGluZ0NvbnRyYWN0CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFDWNvbmZpZ0FkZHJlc3MCD2NvbnRyYWN0X3ZvdGluZwISbm8gY29udHJhY3Rfdm90aW5nAhdpbnZhbGlkIGNvbnRyYWN0X3ZvdGluZwQLcXVvcnVtUmF0aW8JARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQ1jb25maWdBZGRyZXNzCQCsAgIFEHZvdGluZ0FkZHJlc3NTdHICFl9wcm9wb3NhbF9xdW9ydW1fcmF0aW8CInByb3Bvc2FsUXVvcnVtUmF0aW8gaXMgbm90IGRlZmluZWQEC3Bhc3NlZFJhdGlvCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUNY29uZmlnQWRkcmVzcwkArAICBRB2b3RpbmdBZGRyZXNzU3RyAhZfcHJvcG9zYWxfcGFzc2VkX3JhdGlvAiVwcm9wb3NhbFRocmVzaG9sZFJhdGlvIGlzIG5vdCBkZWZpbmVkBAJpZAkA2AQBCAUCdHgCaWQECHZvdGVzWWVzCQELdmFsdWVPckVsc2UCCQCaCAIFDnZvdGluZ0NvbnRyYWN0CQCsAgICDXByb3Bvc2FsX3llc18FAmlkAAAEB3ZvdGVzTm8JAQt2YWx1ZU9yRWxzZQIJAJoIAgUOdm90aW5nQ29udHJhY3QJAKwCAgIMcHJvcG9zYWxfbm9fBQJpZAAABA5wcm9wb3NhbEhlaWdodAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFDnZvdGluZ0NvbnRyYWN0CQCsAgICEHByb3Bvc2FsX2hlaWdodF8FAmlkAhdwcm9wb3NhbCBub3QgcmVnaXN0ZXJlZAQKYXBwbHlTdGFydAkBC3ZhbHVlT3JFbHNlAgkAmggCBQ52b3RpbmdDb250cmFjdAkArAICAhRwcm9wb3NhbF9hcHBseXN0YXJ0XwUCaWQAAAQIYXBwbHlFbmQJAQt2YWx1ZU9yRWxzZQIJAJoIAgUOdm90aW5nQ29udHJhY3QJAKwCAgIScHJvcG9zYWxfYXBwbHllbmRfBQJpZAAABAp0b3RhbFBvd2VyCQELdmFsdWVPckVsc2UCCQCaCAIFDnZvdGluZ0NvbnRyYWN0CQCsAgICD3Byb3Bvc2FsX3Bvd2VyXwUCaWQAAAQHZW5hYmxlZAkBC3ZhbHVlT3JFbHNlAgkAmwgCBQ1jb25maWdBZGRyZXNzCQEOb3BBbGxvd2VkU3RvcmUBAhNnb3Zlcm5hbmNlX2FwcGx5X3R4BgQHdm90ZVllcwUIdm90ZXNZZXMEBnZvdGVObwUHdm90ZXNObwQKdG90YWxWb3RlcwkAZAIFB3ZvdGVZZXMFBnZvdGVObwQJaGFzUXVvcnVtCQBnAgkAaQIJAGgCBQp0b3RhbFZvdGVzBQRCQVNFBQp0b3RhbFBvd2VyBQtxdW9ydW1SYXRpbwQJaGFzUGFzc2VkCQBnAgkAaQIJAGgCBQd2b3RlWWVzBQRCQVNFBQp0b3RhbFZvdGVzBQtwYXNzZWRSYXRpbwQIdG9vRWFybHkJAGcCBQphcHBseVN0YXJ0BQZIRUlHSFQEB3Rvb0xhdGUJAGcCBQZIRUlHSFQFCGFwcGx5RW5kBAl0aW1lRGVidWcJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgIRcHJvcG9zYWxIZWlnaHQgPSAJAKQDAQUOcHJvcG9zYWxIZWlnaHQCDywgYXBwbHlTdGFydCA9IAkApAMBBQphcHBseVN0YXJ0Ag0sIGFwcGx5RW5kID0gCQCkAwEFCGFwcGx5RW5kAgssIEhFSUdIVCA9IAkApAMBBQZIRUlHSFQECGJ5Vm90aW5nAwkBASEBBQdlbmFibGVkCQACAQIrdHggYXBwbGljYXRpb24gdGhyb3cgZ292ZXJuYW5jZSBub3QgZW5hYmxlZAMFCHRvb0Vhcmx5CQACAQkArAICAi5wcm9wb3NhbCBjYW4ndCBiZSBleGVjdXRlZCBhcyBpdCdzIHRvbyBlYXJseTogBQl0aW1lRGVidWcDBQd0b29MYXRlCQACAQkArAICAixwcm9wb3NhbCBjYW4ndCBiZSBleGVjdXRlZCBhcyBpdCdzIHRvbyBsYXRlOgUJdGltZURlYnVnAwkBASEBBQloYXNRdW9ydW0JAAIBCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAgtubyBxdW9ydW06IAIMdG90YWxWb3RlczogCQCkAwEFCnRvdGFsVm90ZXMCDiwgdG90YWxQb3dlcjogCQCkAwEFCnRvdGFsUG93ZXICDywgcXVvcnVtUmF0aW86IAkApAMBBQtxdW9ydW1SYXRpbwMJAQEhAQUJaGFzUGFzc2VkCQACAQkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgIXbm8gdGhyZXNob2xkIGFjaGlldmVkOiACCXZvdGVZZXM6IAkApAMBBQd2b3RlWWVzAgosIHZvdGVObzogCQCkAwEFBnZvdGVObwIPLCBwYXNzZWRSYXRpbzogCQCkAwEFC3Bhc3NlZFJhdGlvBgMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAIBQJ0eA9zZW5kZXJQdWJsaWNLZXkGBQhieVZvdGluZ5cHKBc=", "chainId": 87, "height": 3583819, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: Czh1pFyoDSAcCkRqS1g6RJWqrmt7KHeRhAUA7SW6MBqg Next: 2Mmobcc3c3quE33dNi74ymMri657PpJcfnw5N5NCgFrM Diff:
OldNewDifferences
1616 func advise () = ("height: " + toString(HEIGHT))
1717
1818
19-let ops = ["governance_apply_tx", "mint", "stake", "stakeFor", "unstake", "unstakeFrom", "governance_propose_tx", "governance_vote_tx", "governance_retract_vote", "governance_retract_proposal_tx", "project", "commit", "undoCommit", "projectFor", "increraseSkin", "commitFor", "invest", "start", "slash", "complete", "cancel", "undoInvest", "undoCommitFor", "start", "slash"]
19+let ops = ["governance_apply_tx", "mint", "stake", "stakeFor", "unstake", "unstakeFrom", "claimAndStake", "governance_propose_tx", "governance_vote_tx", "governance_retract_vote", "governance_retract_proposal_tx", "project", "commit", "undoCommit", "projectFor", "increraseSkin", "commitFor", "invest", "start", "slash", "complete", "cancel", "undoInvest", "undoCommitFor", "start", "slash"]
2020
2121 let systemControlStore = "system_allowed"
2222
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 func writeString (key,value) = StringEntry(key, value)
55
66
77 func writeConstString (key,value) = if (!(isDefined(getString(this, key))))
88 then StringEntry(key, value)
99 else throw(("already initialized: " + key))
1010
1111
1212 let configAddress = this
1313
1414 let HEIGHT = height
1515
1616 func advise () = ("height: " + toString(HEIGHT))
1717
1818
19-let ops = ["governance_apply_tx", "mint", "stake", "stakeFor", "unstake", "unstakeFrom", "governance_propose_tx", "governance_vote_tx", "governance_retract_vote", "governance_retract_proposal_tx", "project", "commit", "undoCommit", "projectFor", "increraseSkin", "commitFor", "invest", "start", "slash", "complete", "cancel", "undoInvest", "undoCommitFor", "start", "slash"]
19+let ops = ["governance_apply_tx", "mint", "stake", "stakeFor", "unstake", "unstakeFrom", "claimAndStake", "governance_propose_tx", "governance_vote_tx", "governance_retract_vote", "governance_retract_proposal_tx", "project", "commit", "undoCommit", "projectFor", "increraseSkin", "commitFor", "invest", "start", "slash", "complete", "cancel", "undoInvest", "undoCommitFor", "start", "slash"]
2020
2121 let systemControlStore = "system_allowed"
2222
2323 func opAllowedStore (op) = if (isDefined(indexOf(ops, op)))
2424 then (("op_" + op) + "_allowed")
2525 else throw((("Invalid argument: op. " + op) + " operation is not registered"))
2626
2727
2828 func opUnpauseStore (op) = (("op_" + op) + "_unpaused_by")
2929
3030
3131 let sentinelsStore = "sentinels"
3232
3333 let sentinelsStr = getString(this, sentinelsStore)
3434
3535 let sentinels = if (isDefined(sentinelsStr))
3636 then split(value(sentinelsStr), ",")
3737 else nil
3838
3939 func assertSentinel (s) = valueOrErrorMessage(indexOf(sentinels, toString(s)), "pauseOp denied")
4040
4141
4242 func quorum () = {
4343 let all = size(sentinels)
4444 if ((3 > all))
4545 then 1
4646 else ((all / 2) + 1)
4747 }
4848
4949
5050 @Callable(i)
5151 func opAllowed (op) = {
5252 let store = opAllowedStore(op)
5353 if (contains(valueOrElse(getString(this, "stoplist"), ""), toString(i.originCaller)))
5454 then throw("operation paused by stoplist")
5555 else if (contains(valueOrElse(getString(this, "exc"), ""), toString(i.originCaller)))
5656 then $Tuple2(nil, true)
5757 else {
5858 let enabled0 = valueOrElse(getBoolean(this, systemControlStore), true)
5959 let enabled1 = valueOrElse(getBoolean(this, store), true)
6060 if (!(enabled0))
6161 then throw((("operation paused by " + systemControlStore) + "=false"))
6262 else if (!(enabled1))
6363 then throw((("operation paused by " + store) + "=false"))
6464 else $Tuple2(nil, true)
6565 }
6666 }
6767
6868
6969
7070 @Callable(i)
7171 func pauseOp (op) = {
7272 let s = assertSentinel(i.caller)
7373 if ((s == s))
7474 then [BooleanEntry(opAllowedStore(op), false)]
7575 else throw("Strict value is not equal to itself.")
7676 }
7777
7878
7979
8080 @Callable(i)
8181 func unpauseOp (op) = {
8282 let s = assertSentinel(i.caller)
8383 if ((s == s))
8484 then {
8585 let store = opAllowedStore(op)
8686 if (valueOrElse(getBoolean(this, store), true))
8787 then throw("unpauseOp: invalid operation")
8888 else {
8989 let sentinel = toString(i.caller)
9090 let unpausedByStore = opUnpauseStore(op)
9191 let unpausedByStr = getString(this, unpausedByStore)
9292 let q = quorum()
9393 if (isDefined(unpausedByStr))
9494 then {
9595 let unpausedByValue = value(unpausedByStr)
9696 let unpausedBy = split(unpausedByValue, ",")
9797 if (isDefined(indexOf(unpausedBy, sentinel)))
9898 then throw("duplicate unpause")
9999 else if (((size(unpausedBy) + 1) == q))
100100 then [DeleteEntry(store), DeleteEntry(unpausedByStore)]
101101 else [StringEntry(unpausedByStore, ((unpausedByValue + ",") + sentinel))]
102102 }
103103 else if ((q == 1))
104104 then [DeleteEntry(store)]
105105 else [StringEntry(unpausedByStore, sentinel)]
106106 }
107107 }
108108 else throw("Strict value is not equal to itself.")
109109 }
110110
111111
112112
113113 @Callable(i)
114114 func addSentinel (sentinel) = if ((i.caller != this))
115115 then throw("only self can add sentinel")
116116 else if (!(isDefined(sentinelsStr)))
117117 then [StringEntry(sentinelsStore, sentinel)]
118118 else if (isDefined(indexOf(sentinels, sentinel)))
119119 then nil
120120 else [StringEntry(sentinelsStore, ((value(sentinelsStr) + ",") + sentinel))]
121121
122122
123123 @Verifier(tx)
124124 func verify () = {
125125 let thisAddress = toString(this)
126126 let BASE = 1000
127127 let votingAddressStr = valueOrErrorMessage(getString(configAddress, "contract_voting"), "voting address not found")
128128 let votingContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "contract_voting"), "no contract_voting")), "invalid contract_voting")
129129 let quorumRatio = valueOrErrorMessage(getInteger(configAddress, (votingAddressStr + "_proposal_quorum_ratio")), "proposalQuorumRatio is not defined")
130130 let passedRatio = valueOrErrorMessage(getInteger(configAddress, (votingAddressStr + "_proposal_passed_ratio")), "proposalThresholdRatio is not defined")
131131 let id = toBase58String(tx.id)
132132 let votesYes = valueOrElse(getInteger(votingContract, ("proposal_yes_" + id)), 0)
133133 let votesNo = valueOrElse(getInteger(votingContract, ("proposal_no_" + id)), 0)
134134 let proposalHeight = valueOrErrorMessage(getInteger(votingContract, ("proposal_height_" + id)), "proposal not registered")
135135 let applyStart = valueOrElse(getInteger(votingContract, ("proposal_applystart_" + id)), 0)
136136 let applyEnd = valueOrElse(getInteger(votingContract, ("proposal_applyend_" + id)), 0)
137137 let totalPower = valueOrElse(getInteger(votingContract, ("proposal_power_" + id)), 0)
138138 let enabled = valueOrElse(getBoolean(configAddress, opAllowedStore("governance_apply_tx")), true)
139139 let voteYes = votesYes
140140 let voteNo = votesNo
141141 let totalVotes = (voteYes + voteNo)
142142 let hasQuorum = (((totalVotes * BASE) / totalPower) >= quorumRatio)
143143 let hasPassed = (((voteYes * BASE) / totalVotes) >= passedRatio)
144144 let tooEarly = (applyStart >= HEIGHT)
145145 let tooLate = (HEIGHT >= applyEnd)
146146 let timeDebug = ((((((("proposalHeight = " + toString(proposalHeight)) + ", applyStart = ") + toString(applyStart)) + ", applyEnd = ") + toString(applyEnd)) + ", HEIGHT = ") + toString(HEIGHT))
147147 let byVoting = if (!(enabled))
148148 then throw("tx application throw governance not enabled")
149149 else if (tooEarly)
150150 then throw(("proposal can't be executed as it's too early: " + timeDebug))
151151 else if (tooLate)
152152 then throw(("proposal can't be executed as it's too late:" + timeDebug))
153153 else if (!(hasQuorum))
154154 then throw((((((("no quorum: " + "totalVotes: ") + toString(totalVotes)) + ", totalPower: ") + toString(totalPower)) + ", quorumRatio: ") + toString(quorumRatio)))
155155 else if (!(hasPassed))
156156 then throw((((((("no threshold achieved: " + "voteYes: ") + toString(voteYes)) + ", voteNo: ") + toString(voteNo)) + ", passedRatio: ") + toString(passedRatio)))
157157 else true
158158 if (sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey))
159159 then true
160160 else byVoting
161161 }
162162

github/deemru/w8io/3ef1775 
31.39 ms