tx · 94askssZKP4paZXxNBuBnZLRNJEkJuLjp4QZoPRZvTJ7 3PJFu8MmVa2rSVGM48wdLm4jhLznEgu6XSe: -0.00400000 Waves 2023.01.25 16:01 [3486046] smart account 3PJFu8MmVa2rSVGM48wdLm4jhLznEgu6XSe > SELF 0.00000000 Waves
{ "type": 13, "id": "94askssZKP4paZXxNBuBnZLRNJEkJuLjp4QZoPRZvTJ7", "fee": 400000, "feeAssetId": null, "timestamp": 1674651672903, "version": 1, "sender": "3PJFu8MmVa2rSVGM48wdLm4jhLznEgu6XSe", "senderPublicKey": "5k59JsDv4Nh9KgnBQFfggScT4ce5vtoDmzQwivD8hgpc", "proofs": [ "yMpwuxAoP6y8MFEgdVLWiGDbA4w9itj2qFzj5Muj5UFBG5XnJXqeJ34VEH4CmF3KdtnjmKj5V67AWZtmjxEPLpQ" ], "script": "base64:BgIRCAISBAoCCAgSAwoBCBIAEgAIARB3cml0ZUNvbnN0U3RyaW5nAgNrZXkFdmFsdWUDCQEBIQEJAQlpc0RlZmluZWQBCQCdCAIFBHRoaXMFA2tleQkBC1N0cmluZ0VudHJ5AgUDa2V5BQV2YWx1ZQkAAgEJAKwCAgIVYWxyZWFkeSBpbml0aWFsaXplZDogBQNrZXkAEHVzZG5Bc3NldElkU3RvcmUCC3VzZG5Bc3NldElkABJ1c2RuTFBBc3NldElkU3RvcmUCDXVzZG5MUEFzc2V0SWQAC2NvbmZpZ1N0b3JlAgZjb25maWcAC3VzZG5Bc3NldElkCQDZBAEJARFAZXh0ck5hdGl2ZSgxMDU4KQEFEHVzZG5Bc3NldElkU3RvcmUADXVzZG5MUEFzc2V0SWQJANkEAQkBEUBleHRyTmF0aXZlKDEwNTgpAQUSdXNkbkxQQXNzZXRJZFN0b3JlAA1jb25maWdBZGRyZXNzCQERQGV4dHJOYXRpdmUoMTA2MikBCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzBQtjb25maWdTdG9yZQEHdGhyb3dJZgIJY29uZGl0aW9uBWVycm9yAwUJY29uZGl0aW9uCQACAQUFZXJyb3IGBAFpAQRpbml0AgR1c2RuA2NmZwMJAQIhPQIIBQFpBmNhbGxlcgUEdGhpcwkAAgECEm9ubHkgc2VsZiBjYW4gaW5pdAQJbHBUb2tlbklkCQDCCAUCCFZWVVNETkxQAhRWaXJlcyBWZXN0ZWQgVVNETiBMUAAAAAYGCQDMCAIFCWxwVG9rZW5JZAkAzAgCCQEQd3JpdGVDb25zdFN0cmluZwIFEHVzZG5Bc3NldElkU3RvcmUFBHVzZG4JAMwIAgkBEHdyaXRlQ29uc3RTdHJpbmcCBRJ1c2RuTFBBc3NldElkU3RvcmUJANgEAQkAuAgBBQlscFRva2VuSWQJAMwIAgkBEHdyaXRlQ29uc3RTdHJpbmcCBQtjb25maWdTdG9yZQUDY2ZnBQNuaWwBaQEGbWludFRvAQdhZGRyZXNzBAZjaGVja3MJAQd0aHJvd0lmAgkBAiE9AgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQCCXVzZG4gb25seQULdXNkbkFzc2V0SWQCEnVzZG4gb25seSBhY2NlcHRlZAMJAAACBQZjaGVja3MFBmNoZWNrcwQGYW1vdW50CAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAkAzAgCCQEHUmVpc3N1ZQMFDXVzZG5MUEFzc2V0SWQFBmFtb3VudAYJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwkBEUBleHRyTmF0aXZlKDEwNjIpAQUHYWRkcmVzcwUGYW1vdW50BQ11c2RuTFBBc3NldElkBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEGcmVkZWVtAAkAAgECD25vdCBpbXBsZW1lbnRlZAFpAQZpbXBvcnQABAZjaGVja3MDCQEHdGhyb3dJZgIJAQIhPQIJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAggJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkAgl1c2RuIG9ubHkFDXVzZG5MUEFzc2V0SWQCFnZ2dXNkbmxwIG9ubHkgYWNjZXB0ZWQJAQd0aHJvd0lmAgkAZgIJAQt2YWx1ZU9yRWxzZQIJAJoIAgUNY29uZmlnQWRkcmVzcwITbWluX2ltcG9ydF92dnVzZG5scAkAaAIJAGgCCQBoAgBkAOgHAOgHAOgHCAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAIUbGVzcyB0aGFuIG1pbiBhbW91bnQHAwkAAAIFBmNoZWNrcwUGY2hlY2tzCQACAQIPbm90IGltcGxlbWVudGVkCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJ0eAEGdmVyaWZ5AAQSbWF5YmVPcmFjbGVBZGRyZXNzBAckbWF0Y2gwCQCdCAIFDWNvbmZpZ0FkZHJlc3MCDm9yYWNsZV9hZGRyZXNzAwkAAQIFByRtYXRjaDACBlN0cmluZwQBcwUHJG1hdGNoMAkApggBBQFzBQR1bml0BAZIRUlHSFQFBmhlaWdodAQEQkFTRQDoBwQLcXVvcnVtUmF0aW8JARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQ1jb25maWdBZGRyZXNzAhVwcm9wb3NhbF9xdW9ydW1fcmF0aW8CInByb3Bvc2FsUXVvcnVtUmF0aW8gaXMgbm90IGRlZmluZWQEC3Bhc3NlZFJhdGlvCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUNY29uZmlnQWRkcmVzcwIVcHJvcG9zYWxfcGFzc2VkX3JhdGlvAiVwcm9wb3NhbFRocmVzaG9sZFJhdGlvIGlzIG5vdCBkZWZpbmVkBA5nVmlyZXNDb250cmFjdAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQ1jb25maWdBZGRyZXNzAhJkaXZpZGVuZHNfY29udHJhY3QCFW5vIGRpdmlkZW5kc19jb250cmFjdAIaaW52YWxpZCBkaXZpZGVuZHNfY29udHJhY3QEDnZvdGluZ0NvbnRyYWN0CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFDWNvbmZpZ0FkZHJlc3MCD3ZvdGluZ19jb250cmFjdAISbm8gdm90aW5nX2NvbnRyYWN0AhdpbnZhbGlkIHZvdGluZ19jb250cmFjdAQCaWQJANgEAQgFAnR4AmlkBAh2b3Rlc1llcwkBC3ZhbHVlT3JFbHNlAgkAmggCBQ52b3RpbmdDb250cmFjdAkArAICAg1wcm9wb3NhbF95ZXNfBQJpZAAABAd2b3Rlc05vCQELdmFsdWVPckVsc2UCCQCaCAIFDnZvdGluZ0NvbnRyYWN0CQCsAgICDHByb3Bvc2FsX25vXwUCaWQAAAQOcHJvcG9zYWxIZWlnaHQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQ52b3RpbmdDb250cmFjdAkArAICAhBwcm9wb3NhbF9oZWlnaHRfBQJpZAIXcHJvcG9zYWwgbm90IHJlZ2lzdGVyZWQECmFwcGx5U3RhcnQJAQt2YWx1ZU9yRWxzZQIJAJoIAgUOdm90aW5nQ29udHJhY3QJAKwCAgIUcHJvcG9zYWxfYXBwbHlzdGFydF8FAmlkAAAECGFwcGx5RW5kCQELdmFsdWVPckVsc2UCCQCaCAIFDnZvdGluZ0NvbnRyYWN0CQCsAgICEnByb3Bvc2FsX2FwcGx5ZW5kXwUCaWQAAAQLdG90YWxHVmlyZXMJAQt2YWx1ZU9yRWxzZQIJAJoIAgUOdm90aW5nQ29udHJhY3QJAKwCAgIQcHJvcG9zYWxfZ3ZpcmVzXwUCaWQAAAQHZW5hYmxlZAkBC3ZhbHVlT3JFbHNlAgkAmwgCBQ1jb25maWdBZGRyZXNzAh1vcF9nb3Zlcm5hbmNlX2FwcGx5X3R4X3BhdXNlZAcEB3ZvdGVZZXMFCHZvdGVzWWVzBAZ2b3RlTm8FB3ZvdGVzTm8ECnRvdGFsVm90ZXMJAGQCBQd2b3RlWWVzBQZ2b3RlTm8ECWhhc1F1b3J1bQkAZwIJAGkCCQBoAgUKdG90YWxWb3RlcwUEQkFTRQULdG90YWxHVmlyZXMFC3F1b3J1bVJhdGlvBAloYXNQYXNzZWQJAGcCCQBpAgkAaAIFB3ZvdGVZZXMFBEJBU0UFCnRvdGFsVm90ZXMFC3Bhc3NlZFJhdGlvBAh0b29FYXJseQkAZwIFCmFwcGx5U3RhcnQFBkhFSUdIVAQHdG9vTGF0ZQkAZwIFBkhFSUdIVAUIYXBwbHlFbmQECXRpbWVEZWJ1ZwkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAhFwcm9wb3NhbEhlaWdodCA9IAkApAMBBQ5wcm9wb3NhbEhlaWdodAIPLCBhcHBseVN0YXJ0ID0gCQCkAwEFCmFwcGx5U3RhcnQCDSwgYXBwbHlFbmQgPSAJAKQDAQUIYXBwbHlFbmQCCywgSEVJR0hUID0gCQCkAwEFBkhFSUdIVAQIYnlWb3RpbmcDCQEBIQEFB2VuYWJsZWQJAAIBAit0eCBhcHBsaWNhdGlvbiB0aHJvdyBnb3Zlcm5hbmNlIG5vdCBlbmFibGVkAwUIdG9vRWFybHkJAAIBCQCsAgICLnByb3Bvc2FsIGNhbid0IGJlIGV4ZWN1dGVkIGFzIGl0J3MgdG9vIGVhcmx5OiAFCXRpbWVEZWJ1ZwMFB3Rvb0xhdGUJAAIBCQCsAgICLHByb3Bvc2FsIGNhbid0IGJlIGV4ZWN1dGVkIGFzIGl0J3MgdG9vIGxhdGU6BQl0aW1lRGVidWcDCQEBIQEFCWhhc1F1b3J1bQkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICC25vIHF1b3J1bTogAgx0b3RhbFZvdGVzOiAJAKQDAQUKdG90YWxWb3RlcwIPLCB0b3RhbEdWaXJlczogCQCkAwEFC3RvdGFsR1ZpcmVzAg8sIHF1b3J1bVJhdGlvOiAJAKQDAQULcXVvcnVtUmF0aW8DCQEBIQEFCWhhc1Bhc3NlZAkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICF25vIHRocmVzaG9sZCBhY2hpZXZlZDogAgl2b3RlWWVzOiAJAKQDAQUHdm90ZVllcwIKLCB2b3RlTm86IAkApAMBBQZ2b3RlTm8CDywgcGFzc2VkUmF0aW86IAkApAMBBQtwYXNzZWRSYXRpbwYDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAACAUCdHgPc2VuZGVyUHVibGljS2V5BgUIYnlWb3Rpbmc4P48g", "chainId": 87, "height": 3486046, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 9qFyH1iCB7gRXMTsPDxshbdCeCQUacT1za4xfV7amU2e Next: 2TgF5TpmckiRHDNKwphbQ3K4x53FcZktNPW9YxgTMbaw Diff:
Old | New | Differences | |
---|---|---|---|
53 | 53 | ||
54 | 54 | @Callable(i) | |
55 | 55 | func import () = { | |
56 | - | let checks = if (throwIf((valueOrErrorMessage(i.payments[0].assetId, "usdn | |
56 | + | let checks = if (throwIf((valueOrErrorMessage(i.payments[0].assetId, "usdn only") != usdnLPAssetId), "vvusdnlp only accepted")) | |
57 | 57 | then throwIf((valueOrElse(getInteger(configAddress, "min_import_vvusdnlp"), (((100 * 1000) * 1000) * 1000)) > i.payments[0].amount), "less than min amount") | |
58 | 58 | else false | |
59 | 59 | if ((checks == checks)) | |
62 | 62 | } | |
63 | 63 | ||
64 | 64 | ||
65 | + | @Verifier(tx) | |
66 | + | func verify () = { | |
67 | + | let maybeOracleAddress = match getString(configAddress, "oracle_address") { | |
68 | + | case s: String => | |
69 | + | addressFromString(s) | |
70 | + | case _ => | |
71 | + | unit | |
72 | + | } | |
73 | + | let HEIGHT = height | |
74 | + | let BASE = 1000 | |
75 | + | let quorumRatio = valueOrErrorMessage(getInteger(configAddress, "proposal_quorum_ratio"), "proposalQuorumRatio is not defined") | |
76 | + | let passedRatio = valueOrErrorMessage(getInteger(configAddress, "proposal_passed_ratio"), "proposalThresholdRatio is not defined") | |
77 | + | let gViresContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "dividends_contract"), "no dividends_contract")), "invalid dividends_contract") | |
78 | + | let votingContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "voting_contract"), "no voting_contract")), "invalid voting_contract") | |
79 | + | let id = toBase58String(tx.id) | |
80 | + | let votesYes = valueOrElse(getInteger(votingContract, ("proposal_yes_" + id)), 0) | |
81 | + | let votesNo = valueOrElse(getInteger(votingContract, ("proposal_no_" + id)), 0) | |
82 | + | let proposalHeight = valueOrErrorMessage(getInteger(votingContract, ("proposal_height_" + id)), "proposal not registered") | |
83 | + | let applyStart = valueOrElse(getInteger(votingContract, ("proposal_applystart_" + id)), 0) | |
84 | + | let applyEnd = valueOrElse(getInteger(votingContract, ("proposal_applyend_" + id)), 0) | |
85 | + | let totalGVires = valueOrElse(getInteger(votingContract, ("proposal_gvires_" + id)), 0) | |
86 | + | let enabled = valueOrElse(getBoolean(configAddress, "op_governance_apply_tx_paused"), false) | |
87 | + | let voteYes = votesYes | |
88 | + | let voteNo = votesNo | |
89 | + | let totalVotes = (voteYes + voteNo) | |
90 | + | let hasQuorum = (((totalVotes * BASE) / totalGVires) >= quorumRatio) | |
91 | + | let hasPassed = (((voteYes * BASE) / totalVotes) >= passedRatio) | |
92 | + | let tooEarly = (applyStart >= HEIGHT) | |
93 | + | let tooLate = (HEIGHT >= applyEnd) | |
94 | + | let timeDebug = ((((((("proposalHeight = " + toString(proposalHeight)) + ", applyStart = ") + toString(applyStart)) + ", applyEnd = ") + toString(applyEnd)) + ", HEIGHT = ") + toString(HEIGHT)) | |
95 | + | let byVoting = if (!(enabled)) | |
96 | + | then throw("tx application throw governance not enabled") | |
97 | + | else if (tooEarly) | |
98 | + | then throw(("proposal can't be executed as it's too early: " + timeDebug)) | |
99 | + | else if (tooLate) | |
100 | + | then throw(("proposal can't be executed as it's too late:" + timeDebug)) | |
101 | + | else if (!(hasQuorum)) | |
102 | + | then throw((((((("no quorum: " + "totalVotes: ") + toString(totalVotes)) + ", totalGVires: ") + toString(totalGVires)) + ", quorumRatio: ") + toString(quorumRatio))) | |
103 | + | else if (!(hasPassed)) | |
104 | + | then throw((((((("no threshold achieved: " + "voteYes: ") + toString(voteYes)) + ", voteNo: ") + toString(voteNo)) + ", passedRatio: ") + toString(passedRatio))) | |
105 | + | else true | |
106 | + | if (sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)) | |
107 | + | then true | |
108 | + | else byVoting | |
109 | + | } | |
110 | + |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | func writeConstString (key,value) = if (!(isDefined(getString(this, key)))) | |
5 | 5 | then StringEntry(key, value) | |
6 | 6 | else throw(("already initialized: " + key)) | |
7 | 7 | ||
8 | 8 | ||
9 | 9 | let usdnAssetIdStore = "usdnAssetId" | |
10 | 10 | ||
11 | 11 | let usdnLPAssetIdStore = "usdnLPAssetId" | |
12 | 12 | ||
13 | 13 | let configStore = "config" | |
14 | 14 | ||
15 | 15 | let usdnAssetId = fromBase58String(getStringValue(usdnAssetIdStore)) | |
16 | 16 | ||
17 | 17 | let usdnLPAssetId = fromBase58String(getStringValue(usdnLPAssetIdStore)) | |
18 | 18 | ||
19 | 19 | let configAddress = addressFromStringValue(getStringValue(this, configStore)) | |
20 | 20 | ||
21 | 21 | func throwIf (condition,error) = if (condition) | |
22 | 22 | then throw(error) | |
23 | 23 | else true | |
24 | 24 | ||
25 | 25 | ||
26 | 26 | @Callable(i) | |
27 | 27 | func init (usdn,cfg) = if ((i.caller != this)) | |
28 | 28 | then throw("only self can init") | |
29 | 29 | else { | |
30 | 30 | let lpTokenId = Issue("VVUSDNLP", "Vires Vested USDN LP", 0, 6, true) | |
31 | 31 | [lpTokenId, writeConstString(usdnAssetIdStore, usdn), writeConstString(usdnLPAssetIdStore, toBase58String(calculateAssetId(lpTokenId))), writeConstString(configStore, cfg)] | |
32 | 32 | } | |
33 | 33 | ||
34 | 34 | ||
35 | 35 | ||
36 | 36 | @Callable(i) | |
37 | 37 | func mintTo (address) = { | |
38 | 38 | let checks = throwIf((valueOrErrorMessage(i.payments[0].assetId, "usdn only") != usdnAssetId), "usdn only accepted") | |
39 | 39 | if ((checks == checks)) | |
40 | 40 | then { | |
41 | 41 | let amount = i.payments[0].amount | |
42 | 42 | [Reissue(usdnLPAssetId, amount, true), ScriptTransfer(addressFromStringValue(address), amount, usdnLPAssetId)] | |
43 | 43 | } | |
44 | 44 | else throw("Strict value is not equal to itself.") | |
45 | 45 | } | |
46 | 46 | ||
47 | 47 | ||
48 | 48 | ||
49 | 49 | @Callable(i) | |
50 | 50 | func redeem () = throw("not implemented") | |
51 | 51 | ||
52 | 52 | ||
53 | 53 | ||
54 | 54 | @Callable(i) | |
55 | 55 | func import () = { | |
56 | - | let checks = if (throwIf((valueOrErrorMessage(i.payments[0].assetId, "usdn | |
56 | + | let checks = if (throwIf((valueOrErrorMessage(i.payments[0].assetId, "usdn only") != usdnLPAssetId), "vvusdnlp only accepted")) | |
57 | 57 | then throwIf((valueOrElse(getInteger(configAddress, "min_import_vvusdnlp"), (((100 * 1000) * 1000) * 1000)) > i.payments[0].amount), "less than min amount") | |
58 | 58 | else false | |
59 | 59 | if ((checks == checks)) | |
60 | 60 | then throw("not implemented") | |
61 | 61 | else throw("Strict value is not equal to itself.") | |
62 | 62 | } | |
63 | 63 | ||
64 | 64 | ||
65 | + | @Verifier(tx) | |
66 | + | func verify () = { | |
67 | + | let maybeOracleAddress = match getString(configAddress, "oracle_address") { | |
68 | + | case s: String => | |
69 | + | addressFromString(s) | |
70 | + | case _ => | |
71 | + | unit | |
72 | + | } | |
73 | + | let HEIGHT = height | |
74 | + | let BASE = 1000 | |
75 | + | let quorumRatio = valueOrErrorMessage(getInteger(configAddress, "proposal_quorum_ratio"), "proposalQuorumRatio is not defined") | |
76 | + | let passedRatio = valueOrErrorMessage(getInteger(configAddress, "proposal_passed_ratio"), "proposalThresholdRatio is not defined") | |
77 | + | let gViresContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "dividends_contract"), "no dividends_contract")), "invalid dividends_contract") | |
78 | + | let votingContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "voting_contract"), "no voting_contract")), "invalid voting_contract") | |
79 | + | let id = toBase58String(tx.id) | |
80 | + | let votesYes = valueOrElse(getInteger(votingContract, ("proposal_yes_" + id)), 0) | |
81 | + | let votesNo = valueOrElse(getInteger(votingContract, ("proposal_no_" + id)), 0) | |
82 | + | let proposalHeight = valueOrErrorMessage(getInteger(votingContract, ("proposal_height_" + id)), "proposal not registered") | |
83 | + | let applyStart = valueOrElse(getInteger(votingContract, ("proposal_applystart_" + id)), 0) | |
84 | + | let applyEnd = valueOrElse(getInteger(votingContract, ("proposal_applyend_" + id)), 0) | |
85 | + | let totalGVires = valueOrElse(getInteger(votingContract, ("proposal_gvires_" + id)), 0) | |
86 | + | let enabled = valueOrElse(getBoolean(configAddress, "op_governance_apply_tx_paused"), false) | |
87 | + | let voteYes = votesYes | |
88 | + | let voteNo = votesNo | |
89 | + | let totalVotes = (voteYes + voteNo) | |
90 | + | let hasQuorum = (((totalVotes * BASE) / totalGVires) >= quorumRatio) | |
91 | + | let hasPassed = (((voteYes * BASE) / totalVotes) >= passedRatio) | |
92 | + | let tooEarly = (applyStart >= HEIGHT) | |
93 | + | let tooLate = (HEIGHT >= applyEnd) | |
94 | + | let timeDebug = ((((((("proposalHeight = " + toString(proposalHeight)) + ", applyStart = ") + toString(applyStart)) + ", applyEnd = ") + toString(applyEnd)) + ", HEIGHT = ") + toString(HEIGHT)) | |
95 | + | let byVoting = if (!(enabled)) | |
96 | + | then throw("tx application throw governance not enabled") | |
97 | + | else if (tooEarly) | |
98 | + | then throw(("proposal can't be executed as it's too early: " + timeDebug)) | |
99 | + | else if (tooLate) | |
100 | + | then throw(("proposal can't be executed as it's too late:" + timeDebug)) | |
101 | + | else if (!(hasQuorum)) | |
102 | + | then throw((((((("no quorum: " + "totalVotes: ") + toString(totalVotes)) + ", totalGVires: ") + toString(totalGVires)) + ", quorumRatio: ") + toString(quorumRatio))) | |
103 | + | else if (!(hasPassed)) | |
104 | + | then throw((((((("no threshold achieved: " + "voteYes: ") + toString(voteYes)) + ", voteNo: ") + toString(voteNo)) + ", passedRatio: ") + toString(passedRatio))) | |
105 | + | else true | |
106 | + | if (sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)) | |
107 | + | then true | |
108 | + | else byVoting | |
109 | + | } | |
110 | + |
github/deemru/w8io/6500d08 30.01 ms ◑