tx · DhUYBwMh5PgmeZd7Qig3HrYeg9QTtqACj5qnbqmQWNPH 3PJFu8MmVa2rSVGM48wdLm4jhLznEgu6XSe: -0.00900000 Waves 2023.12.22 12:12 [3963622] smart account 3PJFu8MmVa2rSVGM48wdLm4jhLznEgu6XSe > SELF 0.00000000 Waves
{ "type": 13, "id": "DhUYBwMh5PgmeZd7Qig3HrYeg9QTtqACj5qnbqmQWNPH", "fee": 900000, "feeAssetId": null, "timestamp": 1703236309664, "version": 1, "sender": "3PJFu8MmVa2rSVGM48wdLm4jhLznEgu6XSe", "senderPublicKey": "5k59JsDv4Nh9KgnBQFfggScT4ce5vtoDmzQwivD8hgpc", "proofs": [ "48eMFHmVjrsYKtDWkyX2arrn9N9BsLZFeqEAESwwuxkqKUUK5731fppF8vY6o2Z2ZjdGL6F9fZmy2xkPYqnEn9qK" ], "script": "base64:BgIPCAISBAoCCAgSAwoBCBIACgEQd3JpdGVDb25zdFN0cmluZwIDa2V5BXZhbHVlAwkBASEBCQEJaXNEZWZpbmVkAQkAnQgCBQR0aGlzBQNrZXkJAQtTdHJpbmdFbnRyeQIFA2tleQUFdmFsdWUJAAIBCQCsAgICFWFscmVhZHkgaW5pdGlhbGl6ZWQ6IAUDa2V5ABB1c2RuQXNzZXRJZFN0b3JlAgt1c2RuQXNzZXRJZAASdXNkbkxQQXNzZXRJZFN0b3JlAg11c2RuTFBBc3NldElkAAtjb25maWdTdG9yZQIGY29uZmlnAAt1c2RuQXNzZXRJZAkA2QQBCQERQGV4dHJOYXRpdmUoMTA1OCkBBRB1c2RuQXNzZXRJZFN0b3JlAA11c2RuTFBBc3NldElkCQDZBAEJARFAZXh0ck5hdGl2ZSgxMDU4KQEFEnVzZG5MUEFzc2V0SWRTdG9yZQANY29uZmlnQWRkcmVzcwkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwULY29uZmlnU3RvcmUBB3Rocm93SWYCCWNvbmRpdGlvbgVlcnJvcgMFCWNvbmRpdGlvbgkAAgEFBWVycm9yBgEIbWFpbk9ubHkBAWkDCQEIY29udGFpbnMCCQERQGV4dHJOYXRpdmUoMTA1MykCBQ1jb25maWdBZGRyZXNzAgRtYWluCQClCAEIBQFpBmNhbGxlcgYJAAIBAhBvbmx5IG1haW4gY2FuIGRvAQlvcEFsbG93ZWQBAm9wBAckbWF0Y2gwCQD8BwQFDWNvbmZpZ0FkZHJlc3MCCW9wQWxsb3dlZAkAzAgCAgR1c2RuCQDMCAIFAm9wBQNuaWwFA25pbAMJAAECBQckbWF0Y2gwAgdCb29sZWFuBAFiBQckbWF0Y2gwAwUBYgYJAAIBAgtub3QgYWxsb3dlZAkAAgECIW9wQWxsb3dlZDogdW5leHBlY3RlZCByZXN1bHQgdHlwZQMBaQEEaW5pdAIEdXNkbgNjZmcDCQECIT0CCAUBaQZjYWxsZXIFBHRoaXMJAAIBAhJvbmx5IHNlbGYgY2FuIGluaXQECWxwVG9rZW5JZAkAwggFAghWVlVTRE5MUAIUVmlyZXMgVmVzdGVkIFVTRE4gTFAAAAAGBgkAzAgCBQlscFRva2VuSWQJAMwIAgkBEHdyaXRlQ29uc3RTdHJpbmcCBRB1c2RuQXNzZXRJZFN0b3JlBQR1c2RuCQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgUSdXNkbkxQQXNzZXRJZFN0b3JlCQDYBAEJALgIAQUJbHBUb2tlbklkCQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgULY29uZmlnU3RvcmUFA2NmZwUDbmlsAWkBBm1pbnRUbwEHYWRkcmVzcwQBZAkAAgECBnBhdXNlZAMJAAACBQFkBQFkBAZjaGVja3MJAQd0aHJvd0lmAgkBAiE9AgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQCCXVzZG4gb25seQULdXNkbkFzc2V0SWQCEnVzZG4gb25seSBhY2NlcHRlZAMJAAACBQZjaGVja3MFBmNoZWNrcwQGYW1vdW50CAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAkAzAgCCQEHUmVpc3N1ZQMFDXVzZG5MUEFzc2V0SWQFBmFtb3VudAYJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwkBEUBleHRyTmF0aXZlKDEwNjIpAQUHYWRkcmVzcwUGYW1vdW50BQ11c2RuTFBBc3NldElkBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEGaW1wb3J0AAQGY2hlY2tzAwMDCQEIbWFpbk9ubHkBBQFpCQEJb3BBbGxvd2VkAQIRaW1wb3J0X3Zlc3RlZF94dG4HCQEHdGhyb3dJZgIJAQIhPQIJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAggJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkAgx1c2RuIGxwIG9ubHkFDXVzZG5MUEFzc2V0SWQCFnZ2dXNkbmxwIG9ubHkgYWNjZXB0ZWQHCQEHdGhyb3dJZgIJAGYCCQELdmFsdWVPckVsc2UCCQCaCAIFDWNvbmZpZ0FkZHJlc3MCE21pbl9pbXBvcnRfdnZ1c2RubHAJAGgCCQBoAgkAaAIJAGgCAGQA6AcA6AcA6AcA6AcICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50AhRsZXNzIHRoYW4gbWluIGFtb3VudAcDCQAAAgUGY2hlY2tzBQZjaGVja3MEDGltcG9ydEFtb3VudAgJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQJAJQKAgkAzAgCCQEEQnVybgIFDXVzZG5MUEFzc2V0SWQFDGltcG9ydEFtb3VudAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFDGltcG9ydEFtb3VudAULdXNkbkFzc2V0SWQFA25pbAUMaW1wb3J0QW1vdW50CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJ0eAEGdmVyaWZ5AAQSbWF5YmVPcmFjbGVBZGRyZXNzBAckbWF0Y2gwCQCdCAIFDWNvbmZpZ0FkZHJlc3MCDm9yYWNsZV9hZGRyZXNzAwkAAQIFByRtYXRjaDACBlN0cmluZwQBcwUHJG1hdGNoMAkApggBBQFzBQR1bml0BAZIRUlHSFQFBmhlaWdodAQEQkFTRQDoBwQLcXVvcnVtUmF0aW8JARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQ1jb25maWdBZGRyZXNzAhVwcm9wb3NhbF9xdW9ydW1fcmF0aW8CInByb3Bvc2FsUXVvcnVtUmF0aW8gaXMgbm90IGRlZmluZWQEC3Bhc3NlZFJhdGlvCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUNY29uZmlnQWRkcmVzcwIVcHJvcG9zYWxfcGFzc2VkX3JhdGlvAiVwcm9wb3NhbFRocmVzaG9sZFJhdGlvIGlzIG5vdCBkZWZpbmVkBA5nVmlyZXNDb250cmFjdAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQ1jb25maWdBZGRyZXNzAhJkaXZpZGVuZHNfY29udHJhY3QCFW5vIGRpdmlkZW5kc19jb250cmFjdAIaaW52YWxpZCBkaXZpZGVuZHNfY29udHJhY3QEDnZvdGluZ0NvbnRyYWN0CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFDWNvbmZpZ0FkZHJlc3MCD3ZvdGluZ19jb250cmFjdAISbm8gdm90aW5nX2NvbnRyYWN0AhdpbnZhbGlkIHZvdGluZ19jb250cmFjdAQCaWQJANgEAQgFAnR4AmlkBAh2b3Rlc1llcwkBC3ZhbHVlT3JFbHNlAgkAmggCBQ52b3RpbmdDb250cmFjdAkArAICAg1wcm9wb3NhbF95ZXNfBQJpZAAABAd2b3Rlc05vCQELdmFsdWVPckVsc2UCCQCaCAIFDnZvdGluZ0NvbnRyYWN0CQCsAgICDHByb3Bvc2FsX25vXwUCaWQAAAQOcHJvcG9zYWxIZWlnaHQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQ52b3RpbmdDb250cmFjdAkArAICAhBwcm9wb3NhbF9oZWlnaHRfBQJpZAIXcHJvcG9zYWwgbm90IHJlZ2lzdGVyZWQECmFwcGx5U3RhcnQJAQt2YWx1ZU9yRWxzZQIJAJoIAgUOdm90aW5nQ29udHJhY3QJAKwCAgIUcHJvcG9zYWxfYXBwbHlzdGFydF8FAmlkAAAECGFwcGx5RW5kCQELdmFsdWVPckVsc2UCCQCaCAIFDnZvdGluZ0NvbnRyYWN0CQCsAgICEnByb3Bvc2FsX2FwcGx5ZW5kXwUCaWQAAAQLdG90YWxHVmlyZXMJAQt2YWx1ZU9yRWxzZQIJAJoIAgUOdm90aW5nQ29udHJhY3QJAKwCAgIQcHJvcG9zYWxfZ3ZpcmVzXwUCaWQAAAQHZW5hYmxlZAkBC3ZhbHVlT3JFbHNlAgkAmwgCBQ1jb25maWdBZGRyZXNzAh1vcF9nb3Zlcm5hbmNlX2FwcGx5X3R4X3BhdXNlZAcEB3ZvdGVZZXMFCHZvdGVzWWVzBAZ2b3RlTm8FB3ZvdGVzTm8ECnRvdGFsVm90ZXMJAGQCBQd2b3RlWWVzBQZ2b3RlTm8ECWhhc1F1b3J1bQkAZwIJAGkCCQBoAgUKdG90YWxWb3RlcwUEQkFTRQULdG90YWxHVmlyZXMFC3F1b3J1bVJhdGlvBAloYXNQYXNzZWQJAGcCCQBpAgkAaAIFB3ZvdGVZZXMFBEJBU0UFCnRvdGFsVm90ZXMFC3Bhc3NlZFJhdGlvBAh0b29FYXJseQkAZwIFCmFwcGx5U3RhcnQFBkhFSUdIVAQHdG9vTGF0ZQkAZwIFBkhFSUdIVAUIYXBwbHlFbmQECXRpbWVEZWJ1ZwkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAhFwcm9wb3NhbEhlaWdodCA9IAkApAMBBQ5wcm9wb3NhbEhlaWdodAIPLCBhcHBseVN0YXJ0ID0gCQCkAwEFCmFwcGx5U3RhcnQCDSwgYXBwbHlFbmQgPSAJAKQDAQUIYXBwbHlFbmQCCywgSEVJR0hUID0gCQCkAwEFBkhFSUdIVAQIYnlWb3RpbmcDCQEBIQEFB2VuYWJsZWQJAAIBAit0eCBhcHBsaWNhdGlvbiB0aHJvdyBnb3Zlcm5hbmNlIG5vdCBlbmFibGVkAwUIdG9vRWFybHkJAAIBCQCsAgICLnByb3Bvc2FsIGNhbid0IGJlIGV4ZWN1dGVkIGFzIGl0J3MgdG9vIGVhcmx5OiAFCXRpbWVEZWJ1ZwMFB3Rvb0xhdGUJAAIBCQCsAgICLHByb3Bvc2FsIGNhbid0IGJlIGV4ZWN1dGVkIGFzIGl0J3MgdG9vIGxhdGU6BQl0aW1lRGVidWcDCQEBIQEFCWhhc1F1b3J1bQkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICC25vIHF1b3J1bTogAgx0b3RhbFZvdGVzOiAJAKQDAQUKdG90YWxWb3RlcwIPLCB0b3RhbEdWaXJlczogCQCkAwEFC3RvdGFsR1ZpcmVzAg8sIHF1b3J1bVJhdGlvOiAJAKQDAQULcXVvcnVtUmF0aW8DCQEBIQEFCWhhc1Bhc3NlZAkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICF25vIHRocmVzaG9sZCBhY2hpZXZlZDogAgl2b3RlWWVzOiAJAKQDAQUHdm90ZVllcwIKLCB2b3RlTm86IAkApAMBBQZ2b3RlTm8CDywgcGFzc2VkUmF0aW86IAkApAMBBQtwYXNzZWRSYXRpbwYDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAACAUCdHgPc2VuZGVyUHVibGljS2V5BgUIYnlWb3RpbmebUwVg", "chainId": 87, "height": 3963622, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 2TgF5TpmckiRHDNKwphbQ3K4x53FcZktNPW9YxgTMbaw Next: DXAiAiu3Qx4Zf8UjFpj1YxazV88AkRKTBN9zKAC68ZKf Diff:
Old | New | Differences | |
---|---|---|---|
28 | 28 | else throw("only main can do") | |
29 | 29 | ||
30 | 30 | ||
31 | + | func opAllowed (op) = match invoke(configAddress, "opAllowed", ["usdn", op], nil) { | |
32 | + | case b: Boolean => | |
33 | + | if (b) | |
34 | + | then true | |
35 | + | else throw("not allowed") | |
36 | + | case _ => | |
37 | + | throw("opAllowed: unexpected result type") | |
38 | + | } | |
39 | + | ||
40 | + | ||
31 | 41 | @Callable(i) | |
32 | 42 | func init (usdn,cfg) = if ((i.caller != this)) | |
33 | 43 | then throw("only self can init") | |
40 | 50 | ||
41 | 51 | @Callable(i) | |
42 | 52 | func mintTo (address) = { | |
43 | - | let | |
44 | - | if (( | |
53 | + | let d = throw("paused") | |
54 | + | if ((d == d)) | |
45 | 55 | then { | |
46 | - | 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 | |
47 | 60 | [Reissue(usdnLPAssetId, amount, true), ScriptTransfer(addressFromStringValue(address), amount, usdnLPAssetId)] | |
61 | + | } | |
62 | + | else throw("Strict value is not equal to itself.") | |
48 | 63 | } | |
49 | 64 | else throw("Strict value is not equal to itself.") | |
50 | 65 | } | |
53 | 68 | ||
54 | 69 | @Callable(i) | |
55 | 70 | func import () = { | |
56 | - | let checks = if (if (mainOnly(i)) | |
71 | + | let checks = if (if (if (mainOnly(i)) | |
72 | + | then opAllowed("import_vested_xtn") | |
73 | + | else false) | |
57 | 74 | then throwIf((valueOrErrorMessage(i.payments[0].assetId, "usdn lp only") != usdnLPAssetId), "vvusdnlp only accepted") | |
58 | 75 | else false) | |
59 | 76 | then throwIf((valueOrElse(getInteger(configAddress, "min_import_vvusdnlp"), ((((100 * 1000) * 1000) * 1000) * 1000)) > i.payments[0].amount), "less than min amount") |
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 | func mainOnly (i) = if (contains(getStringValue(configAddress, "main"), toString(i.caller))) | |
27 | 27 | then true | |
28 | 28 | else throw("only main can do") | |
29 | 29 | ||
30 | 30 | ||
31 | + | func opAllowed (op) = match invoke(configAddress, "opAllowed", ["usdn", op], nil) { | |
32 | + | case b: Boolean => | |
33 | + | if (b) | |
34 | + | then true | |
35 | + | else throw("not allowed") | |
36 | + | case _ => | |
37 | + | throw("opAllowed: unexpected result type") | |
38 | + | } | |
39 | + | ||
40 | + | ||
31 | 41 | @Callable(i) | |
32 | 42 | func init (usdn,cfg) = if ((i.caller != this)) | |
33 | 43 | then throw("only self can init") | |
34 | 44 | else { | |
35 | 45 | let lpTokenId = Issue("VVUSDNLP", "Vires Vested USDN LP", 0, 6, true) | |
36 | 46 | [lpTokenId, writeConstString(usdnAssetIdStore, usdn), writeConstString(usdnLPAssetIdStore, toBase58String(calculateAssetId(lpTokenId))), writeConstString(configStore, cfg)] | |
37 | 47 | } | |
38 | 48 | ||
39 | 49 | ||
40 | 50 | ||
41 | 51 | @Callable(i) | |
42 | 52 | func mintTo (address) = { | |
43 | - | let | |
44 | - | if (( | |
53 | + | let d = throw("paused") | |
54 | + | if ((d == d)) | |
45 | 55 | then { | |
46 | - | 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 | |
47 | 60 | [Reissue(usdnLPAssetId, amount, true), ScriptTransfer(addressFromStringValue(address), amount, usdnLPAssetId)] | |
61 | + | } | |
62 | + | else throw("Strict value is not equal to itself.") | |
48 | 63 | } | |
49 | 64 | else throw("Strict value is not equal to itself.") | |
50 | 65 | } | |
51 | 66 | ||
52 | 67 | ||
53 | 68 | ||
54 | 69 | @Callable(i) | |
55 | 70 | func import () = { | |
56 | - | let checks = if (if (mainOnly(i)) | |
71 | + | let checks = if (if (if (mainOnly(i)) | |
72 | + | then opAllowed("import_vested_xtn") | |
73 | + | else false) | |
57 | 74 | then throwIf((valueOrErrorMessage(i.payments[0].assetId, "usdn lp only") != usdnLPAssetId), "vvusdnlp only accepted") | |
58 | 75 | else false) | |
59 | 76 | then throwIf((valueOrElse(getInteger(configAddress, "min_import_vvusdnlp"), ((((100 * 1000) * 1000) * 1000) * 1000)) > i.payments[0].amount), "less than min amount") | |
60 | 77 | else false | |
61 | 78 | if ((checks == checks)) | |
62 | 79 | then { | |
63 | 80 | let importAmount = i.payments[0].amount | |
64 | 81 | $Tuple2([Burn(usdnLPAssetId, importAmount), ScriptTransfer(i.caller, importAmount, usdnAssetId)], importAmount) | |
65 | 82 | } | |
66 | 83 | else throw("Strict value is not equal to itself.") | |
67 | 84 | } | |
68 | 85 | ||
69 | 86 | ||
70 | 87 | @Verifier(tx) | |
71 | 88 | func verify () = { | |
72 | 89 | let maybeOracleAddress = match getString(configAddress, "oracle_address") { | |
73 | 90 | case s: String => | |
74 | 91 | addressFromString(s) | |
75 | 92 | case _ => | |
76 | 93 | unit | |
77 | 94 | } | |
78 | 95 | let HEIGHT = height | |
79 | 96 | let BASE = 1000 | |
80 | 97 | let quorumRatio = valueOrErrorMessage(getInteger(configAddress, "proposal_quorum_ratio"), "proposalQuorumRatio is not defined") | |
81 | 98 | let passedRatio = valueOrErrorMessage(getInteger(configAddress, "proposal_passed_ratio"), "proposalThresholdRatio is not defined") | |
82 | 99 | let gViresContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "dividends_contract"), "no dividends_contract")), "invalid dividends_contract") | |
83 | 100 | let votingContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "voting_contract"), "no voting_contract")), "invalid voting_contract") | |
84 | 101 | let id = toBase58String(tx.id) | |
85 | 102 | let votesYes = valueOrElse(getInteger(votingContract, ("proposal_yes_" + id)), 0) | |
86 | 103 | let votesNo = valueOrElse(getInteger(votingContract, ("proposal_no_" + id)), 0) | |
87 | 104 | let proposalHeight = valueOrErrorMessage(getInteger(votingContract, ("proposal_height_" + id)), "proposal not registered") | |
88 | 105 | let applyStart = valueOrElse(getInteger(votingContract, ("proposal_applystart_" + id)), 0) | |
89 | 106 | let applyEnd = valueOrElse(getInteger(votingContract, ("proposal_applyend_" + id)), 0) | |
90 | 107 | let totalGVires = valueOrElse(getInteger(votingContract, ("proposal_gvires_" + id)), 0) | |
91 | 108 | let enabled = valueOrElse(getBoolean(configAddress, "op_governance_apply_tx_paused"), false) | |
92 | 109 | let voteYes = votesYes | |
93 | 110 | let voteNo = votesNo | |
94 | 111 | let totalVotes = (voteYes + voteNo) | |
95 | 112 | let hasQuorum = (((totalVotes * BASE) / totalGVires) >= quorumRatio) | |
96 | 113 | let hasPassed = (((voteYes * BASE) / totalVotes) >= passedRatio) | |
97 | 114 | let tooEarly = (applyStart >= HEIGHT) | |
98 | 115 | let tooLate = (HEIGHT >= applyEnd) | |
99 | 116 | let timeDebug = ((((((("proposalHeight = " + toString(proposalHeight)) + ", applyStart = ") + toString(applyStart)) + ", applyEnd = ") + toString(applyEnd)) + ", HEIGHT = ") + toString(HEIGHT)) | |
100 | 117 | let byVoting = if (!(enabled)) | |
101 | 118 | then throw("tx application throw governance not enabled") | |
102 | 119 | else if (tooEarly) | |
103 | 120 | then throw(("proposal can't be executed as it's too early: " + timeDebug)) | |
104 | 121 | else if (tooLate) | |
105 | 122 | then throw(("proposal can't be executed as it's too late:" + timeDebug)) | |
106 | 123 | else if (!(hasQuorum)) | |
107 | 124 | then throw((((((("no quorum: " + "totalVotes: ") + toString(totalVotes)) + ", totalGVires: ") + toString(totalGVires)) + ", quorumRatio: ") + toString(quorumRatio))) | |
108 | 125 | else if (!(hasPassed)) | |
109 | 126 | then throw((((((("no threshold achieved: " + "voteYes: ") + toString(voteYes)) + ", voteNo: ") + toString(voteNo)) + ", passedRatio: ") + toString(passedRatio))) | |
110 | 127 | else true | |
111 | 128 | if (sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)) | |
112 | 129 | then true | |
113 | 130 | else byVoting | |
114 | 131 | } | |
115 | 132 |
github/deemru/w8io/873ac7e 55.41 ms ◑![]()