tx · 36jr6JkS9LGEpEEqt2gsk7cNxp1he6Bno6fQSXuFEmbQ 3PJqzSu5ShM2qzkSkxDr2oc47TBH8zfBaUq: -0.01000000 Waves 2023.07.25 19:12 [3747251] smart account 3PJqzSu5ShM2qzkSkxDr2oc47TBH8zfBaUq > SELF 0.00000000 Waves
{ "type": 13, "id": "36jr6JkS9LGEpEEqt2gsk7cNxp1he6Bno6fQSXuFEmbQ", "fee": 1000000, "feeAssetId": null, "timestamp": 1690301581964, "version": 1, "sender": "3PJqzSu5ShM2qzkSkxDr2oc47TBH8zfBaUq", "senderPublicKey": "3JbL1AeoE8AP9xDHYyrbLCFxXtzyx5EPexG4H3CMdBMS", "proofs": [ "5tEvRq3k46LWRVHNjXhwSWQ41VPBRPL3CnTKYsAgQHCa7Nae9z5bep3P16b2XjsZiJWwk171hCDGKoFDZpMr5Lo2" ], "script": "base64:BgIhCAISBQoDCAEEEgQKAgEEEgQKAgEEEgoKCAgICAgICAgIFgASY29uZmlnQWRkcmVzc1N0b3JlAg1jb25maWdBZGRyZXNzAA1jb25maWdBZGRyZXNzCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMFEmNvbmZpZ0FkZHJlc3NTdG9yZQIZcmVzZXJ2ZTogbm8gY29uZmlnQWRkcmVzcwIWaW52YWxpZCBjb25maWcgYWRkcmVzcwAGSEVJR0hUBQZoZWlnaHQBCW9wQWxsb3dlZAICb3AHcmVzZXJ2ZQQHJG1hdGNoMAkA/AcEBQ1jb25maWdBZGRyZXNzAglvcEFsbG93ZWQJAMwIAgUHcmVzZXJ2ZQkAzAgCBQJvcAUDbmlsBQNuaWwDCQABAgUHJG1hdGNoMAIHQm9vbGVhbgQBYgUHJG1hdGNoMAMFAWIGCQACAQILbm90IGFsbG93ZWQJAAIBAiFvcEFsbG93ZWQ6IHVuZXhwZWN0ZWQgcmVzdWx0IHR5cGUBEHdyaXRlQ29uc3RTdHJpbmcCA2tleQV2YWx1ZQMJAQEhAQkBCWlzRGVmaW5lZAEJAJ0IAgUEdGhpcwUDa2V5CQELU3RyaW5nRW50cnkCBQNrZXkFBXZhbHVlCQACAQkArAICAhVhbHJlYWR5IGluaXRpYWxpemVkOiAFA2tleQEKZ2V0QWRkcmVzcwEDa2V5CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCiCAEFA2tleQkArAICBQNrZXkCCiBub3QgZm91bmQJAKwCAgUDa2V5AhAgaW52YWxpZCBhZGRyZXNzAQhnZXRBc3NldAEDa2V5CQDZBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAoggBBQNrZXkJAKwCAgUDa2V5Agogbm90IGZvdW5kAAdsMlN0b3JlAgJMMgAIeHRuU3RvcmUCA1hUTgAPbDJDb250cmFjdFN0b3JlAgtMMl9jb250cmFjdAANbDJTdGFrZXJTdG9yZQISTDJfc3Rha2VyX2NvbnRyYWN0AA12ZXN0bkFsbFN0b3JlAgl2ZXN0bl9hbGwAD3Zlc3RuV2hhbGVTdG9yZQIFdmVzdG4ACm1haW40U3RvcmUCBW1haW40AAJsMgkBCGdldEFzc2V0AQUHbDJTdG9yZQADeHRuCQEIZ2V0QXNzZXQBBQh4dG5TdG9yZQAKbDJDb250cmFjdAkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTgpAQUPbDJDb250cmFjdFN0b3JlAAhsMnN0YWtlcgkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTgpAQUNbDJTdGFrZXJTdG9yZQAFbWFpbjQJARFAZXh0ck5hdGl2ZSgxMDYyKQEJARFAZXh0ck5hdGl2ZSgxMDU4KQEFCm1haW40U3RvcmUACHZlc3RuQWxsCQEKZ2V0QWRkcmVzcwEFDXZlc3RuQWxsU3RvcmUACnZlc3RuV2hhbGUJAQpnZXRBZGRyZXNzAQUPdmVzdG5XaGFsZVN0b3JlARZjb252ZXJ0WHRuVG9MMkludGVybmFsAwdhZGRyZXNzCXh0bkFtb3VudAVzdGFrZQMJAGYCBQl4dG5BbW91bnQAwIQ9CQACAQIHdG8gbWFueQQBYwkA/AcEBQpsMkNvbnRyYWN0AgRzd2FwBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFA3h0bgUJeHRuQW1vdW50BQNuaWwDCQAAAgUBYwUBYwQIbDJBbW91bnQJAGgCBQl4dG5BbW91bnQAZAMFBXN0YWtlBAFzCQD8BwQFCGwyc3Rha2VyAghzdGFrZUZvcgkAzAgCCQClCAEFB2FkZHJlc3MFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUCbDIFCGwyQW1vdW50BQNuaWwDCQAAAgUBcwUBcwUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFB2FkZHJlc3MFCGwyQW1vdW50BQJsMgUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuBAFpAQx3aXRoZHJhd1RvTDIDB3Jlc2VydmUGYW1vdW50BXN0YWtlBAFhCQACAQIObm90IGltcGxlbWVudGQDCQAAAgUBYQUBYQQGY2hlY2tzCQEJb3BBbGxvd2VkAgIMd2l0aGRyYXdUb0wyBQdyZXNlcnZlAwkAAAIFBmNoZWNrcwUGY2hlY2tzBAZ2ZXNpbmcJAPwHBAUFbWFpbjQCDHN0YXJ0VmVzdGluZwkAzAgCBQdyZXNlcnZlCQDMCAIFBmFtb3VudAUDbmlsBQNuaWwDCQAAAgUGdmVzaW5nBQZ2ZXNpbmcEAndkCQD8BwQFCHZlc3RuQWxsAhpwYXJ0aWFsV2l0aGRyYXdWZXN0ZWRGb3JUbwkAzAgCCQClCAEIBQFpBmNhbGxlcgkAzAgCCQClCAEFBHRoaXMJAMwIAgUGYW1vdW50BQNuaWwFA25pbAMJAAACBQJ3ZAUCd2QJARZjb252ZXJ0WHRuVG9MMkludGVybmFsAwgFAWkGY2FsbGVyBQZhbW91bnQFBXN0YWtlCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBGXdpdGhkcmF3VmVzdGVkUmVndWxhclRvTDICA2FtdAVzdGFrZQQGY2hlY2tzCQEJb3BBbGxvd2VkAgIMd2l0aGRyYXdUb0wyAg52ZXN0ZWRfcmVndWxhcgMJAAACBQZjaGVja3MFBmNoZWNrcwQCd2QJAPwHBAUIdmVzdG5BbGwCGnBhcnRpYWxXaXRoZHJhd1Zlc3RlZEZvclRvCQDMCAIJAKUIAQgFAWkGY2FsbGVyCQDMCAIJAKUIAQUEdGhpcwkAzAgCBQNhbXQFA25pbAUDbmlsAwkAAAIFAndkBQJ3ZAQLdmVzdGluZ1RvTDIAmOYFBARiYXNlAKCNBgQHdXNkbkFtdAkAawMFA2FtdAULdmVzdGluZ1RvTDIFBGJhc2UECGxlZnRvdmVyCQBlAgUDYW10BQd1c2RuQW10CQDOCAIJARZjb252ZXJ0WHRuVG9MMkludGVybmFsAwgFAWkGY2FsbGVyBQd1c2RuQW10BQVzdGFrZQkAzAgCCQEEQnVybgIFA3h0bgUIbGVmdG92ZXIFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpARd3aXRoZHJhd1Zlc3RlZFdoYWxlVG9MMgIDYW10BXN0YWtlBAFhCQACAQIObm90IGltcGxlbWVudGQDCQAAAgUBYQUBYQQGY2hlY2tzCQEJb3BBbGxvd2VkAgIMd2l0aGRyYXdUb0wyAgx2ZXN0ZWRfd2hhbGUDCQAAAgUGY2hlY2tzBQZjaGVja3MEAndkCQD8BwQFCnZlc3RuV2hhbGUCGnBhcnRpYWxXaXRoZHJhd1Zlc3RlZEZvclRvCQDMCAIJAKUIAQgFAWkGY2FsbGVyCQDMCAIJAKUIAQUEdGhpcwkAzAgCBQNhbXQFA25pbAUDbmlsAwkAAAIFAndkBQJ3ZAkBFmNvbnZlcnRYdG5Ub0wySW50ZXJuYWwDCAUBaQZjYWxsZXIFA2FtdAUFc3Rha2UJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEKaW5pdGlhbGl6ZQgNY29uZmlnQWRkcmVzcwJsMgN4dG4JbDJDb3RyYWN0CGwyU3Rha2VyCHZlc3RuQWxsCnZlc3RuV2hhbGUFbWFpbjQJAMwIAgkBEHdyaXRlQ29uc3RTdHJpbmcCBRJjb25maWdBZGRyZXNzU3RvcmUFDWNvbmZpZ0FkZHJlc3MJAMwIAgkBEHdyaXRlQ29uc3RTdHJpbmcCBQdsMlN0b3JlBQJsMgkAzAgCCQEQd3JpdGVDb25zdFN0cmluZwIFCHh0blN0b3JlBQN4dG4JAMwIAgkBEHdyaXRlQ29uc3RTdHJpbmcCBQ9sMkNvbnRyYWN0U3RvcmUFCWwyQ290cmFjdAkAzAgCCQEQd3JpdGVDb25zdFN0cmluZwIFDWwyU3Rha2VyU3RvcmUFCGwyU3Rha2VyCQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgUNdmVzdG5BbGxTdG9yZQUIdmVzdG5BbGwJAMwIAgkBEHdyaXRlQ29uc3RTdHJpbmcCBQ92ZXN0bldoYWxlU3RvcmUFCnZlc3RuV2hhbGUJAMwIAgkBEHdyaXRlQ29uc3RTdHJpbmcCBQptYWluNFN0b3JlBQVtYWluNAUDbmlsAQJ0eAEGdmVyaWZ5AAQEQkFTRQDoBwQLcXVvcnVtUmF0aW8JARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQ1jb25maWdBZGRyZXNzAhVwcm9wb3NhbF9xdW9ydW1fcmF0aW8CInByb3Bvc2FsUXVvcnVtUmF0aW8gaXMgbm90IGRlZmluZWQEC3Bhc3NlZFJhdGlvCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUNY29uZmlnQWRkcmVzcwIVcHJvcG9zYWxfcGFzc2VkX3JhdGlvAiVwcm9wb3NhbFRocmVzaG9sZFJhdGlvIGlzIG5vdCBkZWZpbmVkBA5nVmlyZXNDb250cmFjdAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQ1jb25maWdBZGRyZXNzAhJkaXZpZGVuZHNfY29udHJhY3QCFW5vIGRpdmlkZW5kc19jb250cmFjdAIaaW52YWxpZCBkaXZpZGVuZHNfY29udHJhY3QEDnZvdGluZ0NvbnRyYWN0CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFDWNvbmZpZ0FkZHJlc3MCD3ZvdGluZ19jb250cmFjdAISbm8gdm90aW5nX2NvbnRyYWN0AhdpbnZhbGlkIHZvdGluZ19jb250cmFjdAQCaWQJANgEAQgFAnR4AmlkBAh2b3Rlc1llcwkBC3ZhbHVlT3JFbHNlAgkAmggCBQ52b3RpbmdDb250cmFjdAkArAICAg1wcm9wb3NhbF95ZXNfBQJpZAAABAd2b3Rlc05vCQELdmFsdWVPckVsc2UCCQCaCAIFDnZvdGluZ0NvbnRyYWN0CQCsAgICDHByb3Bvc2FsX25vXwUCaWQAAAQOcHJvcG9zYWxIZWlnaHQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQ52b3RpbmdDb250cmFjdAkArAICAhBwcm9wb3NhbF9oZWlnaHRfBQJpZAIXcHJvcG9zYWwgbm90IHJlZ2lzdGVyZWQECmFwcGx5U3RhcnQJAQt2YWx1ZU9yRWxzZQIJAJoIAgUOdm90aW5nQ29udHJhY3QJAKwCAgIUcHJvcG9zYWxfYXBwbHlzdGFydF8FAmlkAAAECGFwcGx5RW5kCQELdmFsdWVPckVsc2UCCQCaCAIFDnZvdGluZ0NvbnRyYWN0CQCsAgICEnByb3Bvc2FsX2FwcGx5ZW5kXwUCaWQAAAQLdG90YWxHVmlyZXMJAQt2YWx1ZU9yRWxzZQIJAJoIAgUOdm90aW5nQ29udHJhY3QJAKwCAgIQcHJvcG9zYWxfZ3ZpcmVzXwUCaWQAAAQHZW5hYmxlZAkBC3ZhbHVlT3JFbHNlAgkAmwgCBQ1jb25maWdBZGRyZXNzAh1vcF9nb3Zlcm5hbmNlX2FwcGx5X3R4X3BhdXNlZAcEB3ZvdGVZZXMFCHZvdGVzWWVzBAZ2b3RlTm8FB3ZvdGVzTm8ECnRvdGFsVm90ZXMJAGQCBQd2b3RlWWVzBQZ2b3RlTm8ECWhhc1F1b3J1bQkAZwIJAGkCCQBoAgUKdG90YWxWb3RlcwUEQkFTRQULdG90YWxHVmlyZXMFC3F1b3J1bVJhdGlvBAloYXNQYXNzZWQJAGcCCQBpAgkAaAIFB3ZvdGVZZXMFBEJBU0UFCnRvdGFsVm90ZXMFC3Bhc3NlZFJhdGlvBAh0b29FYXJseQkAZwIFCmFwcGx5U3RhcnQFBkhFSUdIVAQHdG9vTGF0ZQkAZwIFBkhFSUdIVAUIYXBwbHlFbmQECXRpbWVEZWJ1ZwkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAhFwcm9wb3NhbEhlaWdodCA9IAkApAMBBQ5wcm9wb3NhbEhlaWdodAIPLCBhcHBseVN0YXJ0ID0gCQCkAwEFCmFwcGx5U3RhcnQCDSwgYXBwbHlFbmQgPSAJAKQDAQUIYXBwbHlFbmQCCywgSEVJR0hUID0gCQCkAwEFBkhFSUdIVAQIYnlWb3RpbmcDCQEBIQEFB2VuYWJsZWQJAAIBAit0eCBhcHBsaWNhdGlvbiB0aHJvdyBnb3Zlcm5hbmNlIG5vdCBlbmFibGVkAwUIdG9vRWFybHkJAAIBCQCsAgICLnByb3Bvc2FsIGNhbid0IGJlIGV4ZWN1dGVkIGFzIGl0J3MgdG9vIGVhcmx5OiAFCXRpbWVEZWJ1ZwMFB3Rvb0xhdGUJAAIBCQCsAgICLHByb3Bvc2FsIGNhbid0IGJlIGV4ZWN1dGVkIGFzIGl0J3MgdG9vIGxhdGU6BQl0aW1lRGVidWcDCQEBIQEFCWhhc1F1b3J1bQkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICC25vIHF1b3J1bTogAgx0b3RhbFZvdGVzOiAJAKQDAQUKdG90YWxWb3RlcwIPLCB0b3RhbEdWaXJlczogCQCkAwEFC3RvdGFsR1ZpcmVzAg8sIHF1b3J1bVJhdGlvOiAJAKQDAQULcXVvcnVtUmF0aW8DCQEBIQEFCWhhc1Bhc3NlZAkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICF25vIHRocmVzaG9sZCBhY2hpZXZlZDogAgl2b3RlWWVzOiAJAKQDAQUHdm90ZVllcwIKLCB2b3RlTm86IAkApAMBBQZ2b3RlTm8CDywgcGFzc2VkUmF0aW86IAkApAMBBQtwYXNzZWRSYXRpbwYDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAACAUCdHgPc2VuZGVyUHVibGljS2V5BgUIYnlWb3RpbmfHJnVl", "chainId": 87, "height": 3747251, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 4JvJ6tECkMFJv1Jd8n34JFYSKof6teUuNu8QJzm2af1H Next: AjXeHpqF74URc2vTDWNkuiPEUSB6qG7ErzNBycgZeQ27 Diff:
Old | New | Differences | |
---|---|---|---|
22 | 22 | else throw(("already initialized: " + key)) | |
23 | 23 | ||
24 | 24 | ||
25 | - | func getAddress (key) = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString( | |
25 | + | func getAddress (key) = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(key), (key + " not found"))), (key + " invalid address")) | |
26 | 26 | ||
27 | 27 | ||
28 | 28 | func getAsset (key) = fromBase58String(valueOrErrorMessage(getString(key), (key + " not found"))) |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let configAddressStore = "configAddress" | |
5 | 5 | ||
6 | 6 | let configAddress = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, configAddressStore), "reserve: no configAddress")), "invalid config address") | |
7 | 7 | ||
8 | 8 | let HEIGHT = height | |
9 | 9 | ||
10 | 10 | func opAllowed (op,reserve) = match invoke(configAddress, "opAllowed", [reserve, op], nil) { | |
11 | 11 | case b: Boolean => | |
12 | 12 | if (b) | |
13 | 13 | then true | |
14 | 14 | else throw("not allowed") | |
15 | 15 | case _ => | |
16 | 16 | throw("opAllowed: unexpected result type") | |
17 | 17 | } | |
18 | 18 | ||
19 | 19 | ||
20 | 20 | func writeConstString (key,value) = if (!(isDefined(getString(this, key)))) | |
21 | 21 | then StringEntry(key, value) | |
22 | 22 | else throw(("already initialized: " + key)) | |
23 | 23 | ||
24 | 24 | ||
25 | - | func getAddress (key) = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString( | |
25 | + | func getAddress (key) = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(key), (key + " not found"))), (key + " invalid address")) | |
26 | 26 | ||
27 | 27 | ||
28 | 28 | func getAsset (key) = fromBase58String(valueOrErrorMessage(getString(key), (key + " not found"))) | |
29 | 29 | ||
30 | 30 | ||
31 | 31 | let l2Store = "L2" | |
32 | 32 | ||
33 | 33 | let xtnStore = "XTN" | |
34 | 34 | ||
35 | 35 | let l2ContractStore = "L2_contract" | |
36 | 36 | ||
37 | 37 | let l2StakerStore = "L2_staker_contract" | |
38 | 38 | ||
39 | 39 | let vestnAllStore = "vestn_all" | |
40 | 40 | ||
41 | 41 | let vestnWhaleStore = "vestn" | |
42 | 42 | ||
43 | 43 | let main4Store = "main4" | |
44 | 44 | ||
45 | 45 | let l2 = getAsset(l2Store) | |
46 | 46 | ||
47 | 47 | let xtn = getAsset(xtnStore) | |
48 | 48 | ||
49 | 49 | let l2Contract = addressFromStringValue(getStringValue(l2ContractStore)) | |
50 | 50 | ||
51 | 51 | let l2staker = addressFromStringValue(getStringValue(l2StakerStore)) | |
52 | 52 | ||
53 | 53 | let main4 = addressFromStringValue(getStringValue(main4Store)) | |
54 | 54 | ||
55 | 55 | let vestnAll = getAddress(vestnAllStore) | |
56 | 56 | ||
57 | 57 | let vestnWhale = getAddress(vestnWhaleStore) | |
58 | 58 | ||
59 | 59 | func convertXtnToL2Internal (address,xtnAmount,stake) = if ((xtnAmount > 1000000)) | |
60 | 60 | then throw("to many") | |
61 | 61 | else { | |
62 | 62 | let c = invoke(l2Contract, "swap", nil, [AttachedPayment(xtn, xtnAmount)]) | |
63 | 63 | if ((c == c)) | |
64 | 64 | then { | |
65 | 65 | let l2Amount = (xtnAmount * 100) | |
66 | 66 | if (stake) | |
67 | 67 | then { | |
68 | 68 | let s = invoke(l2staker, "stakeFor", [toString(address)], [AttachedPayment(l2, l2Amount)]) | |
69 | 69 | if ((s == s)) | |
70 | 70 | then nil | |
71 | 71 | else throw("Strict value is not equal to itself.") | |
72 | 72 | } | |
73 | 73 | else [ScriptTransfer(address, l2Amount, l2)] | |
74 | 74 | } | |
75 | 75 | else throw("Strict value is not equal to itself.") | |
76 | 76 | } | |
77 | 77 | ||
78 | 78 | ||
79 | 79 | @Callable(i) | |
80 | 80 | func withdrawToL2 (reserve,amount,stake) = { | |
81 | 81 | let a = throw("not implementd") | |
82 | 82 | if ((a == a)) | |
83 | 83 | then { | |
84 | 84 | let checks = opAllowed("withdrawToL2", reserve) | |
85 | 85 | if ((checks == checks)) | |
86 | 86 | then { | |
87 | 87 | let vesing = invoke(main4, "startVesting", [reserve, amount], nil) | |
88 | 88 | if ((vesing == vesing)) | |
89 | 89 | then { | |
90 | 90 | let wd = invoke(vestnAll, "partialWithdrawVestedForTo", [toString(i.caller), toString(this), amount], nil) | |
91 | 91 | if ((wd == wd)) | |
92 | 92 | then convertXtnToL2Internal(i.caller, amount, stake) | |
93 | 93 | else throw("Strict value is not equal to itself.") | |
94 | 94 | } | |
95 | 95 | else throw("Strict value is not equal to itself.") | |
96 | 96 | } | |
97 | 97 | else throw("Strict value is not equal to itself.") | |
98 | 98 | } | |
99 | 99 | else throw("Strict value is not equal to itself.") | |
100 | 100 | } | |
101 | 101 | ||
102 | 102 | ||
103 | 103 | ||
104 | 104 | @Callable(i) | |
105 | 105 | func withdrawVestedRegularToL2 (amt,stake) = { | |
106 | 106 | let checks = opAllowed("withdrawToL2", "vested_regular") | |
107 | 107 | if ((checks == checks)) | |
108 | 108 | then { | |
109 | 109 | let wd = invoke(vestnAll, "partialWithdrawVestedForTo", [toString(i.caller), toString(this), amt], nil) | |
110 | 110 | if ((wd == wd)) | |
111 | 111 | then { | |
112 | 112 | let vestingToL2 = 95000 | |
113 | 113 | let base = 100000 | |
114 | 114 | let usdnAmt = fraction(amt, vestingToL2, base) | |
115 | 115 | let leftover = (amt - usdnAmt) | |
116 | 116 | (convertXtnToL2Internal(i.caller, usdnAmt, stake) ++ [Burn(xtn, leftover)]) | |
117 | 117 | } | |
118 | 118 | else throw("Strict value is not equal to itself.") | |
119 | 119 | } | |
120 | 120 | else throw("Strict value is not equal to itself.") | |
121 | 121 | } | |
122 | 122 | ||
123 | 123 | ||
124 | 124 | ||
125 | 125 | @Callable(i) | |
126 | 126 | func withdrawVestedWhaleToL2 (amt,stake) = { | |
127 | 127 | let a = throw("not implementd") | |
128 | 128 | if ((a == a)) | |
129 | 129 | then { | |
130 | 130 | let checks = opAllowed("withdrawToL2", "vested_whale") | |
131 | 131 | if ((checks == checks)) | |
132 | 132 | then { | |
133 | 133 | let wd = invoke(vestnWhale, "partialWithdrawVestedForTo", [toString(i.caller), toString(this), amt], nil) | |
134 | 134 | if ((wd == wd)) | |
135 | 135 | then convertXtnToL2Internal(i.caller, amt, stake) | |
136 | 136 | else throw("Strict value is not equal to itself.") | |
137 | 137 | } | |
138 | 138 | else throw("Strict value is not equal to itself.") | |
139 | 139 | } | |
140 | 140 | else throw("Strict value is not equal to itself.") | |
141 | 141 | } | |
142 | 142 | ||
143 | 143 | ||
144 | 144 | ||
145 | 145 | @Callable(i) | |
146 | 146 | func initialize (configAddress,l2,xtn,l2Cotract,l2Staker,vestnAll,vestnWhale,main4) = [writeConstString(configAddressStore, configAddress), writeConstString(l2Store, l2), writeConstString(xtnStore, xtn), writeConstString(l2ContractStore, l2Cotract), writeConstString(l2StakerStore, l2Staker), writeConstString(vestnAllStore, vestnAll), writeConstString(vestnWhaleStore, vestnWhale), writeConstString(main4Store, main4)] | |
147 | 147 | ||
148 | 148 | ||
149 | 149 | @Verifier(tx) | |
150 | 150 | func verify () = { | |
151 | 151 | let BASE = 1000 | |
152 | 152 | let quorumRatio = valueOrErrorMessage(getInteger(configAddress, "proposal_quorum_ratio"), "proposalQuorumRatio is not defined") | |
153 | 153 | let passedRatio = valueOrErrorMessage(getInteger(configAddress, "proposal_passed_ratio"), "proposalThresholdRatio is not defined") | |
154 | 154 | let gViresContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "dividends_contract"), "no dividends_contract")), "invalid dividends_contract") | |
155 | 155 | let votingContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "voting_contract"), "no voting_contract")), "invalid voting_contract") | |
156 | 156 | let id = toBase58String(tx.id) | |
157 | 157 | let votesYes = valueOrElse(getInteger(votingContract, ("proposal_yes_" + id)), 0) | |
158 | 158 | let votesNo = valueOrElse(getInteger(votingContract, ("proposal_no_" + id)), 0) | |
159 | 159 | let proposalHeight = valueOrErrorMessage(getInteger(votingContract, ("proposal_height_" + id)), "proposal not registered") | |
160 | 160 | let applyStart = valueOrElse(getInteger(votingContract, ("proposal_applystart_" + id)), 0) | |
161 | 161 | let applyEnd = valueOrElse(getInteger(votingContract, ("proposal_applyend_" + id)), 0) | |
162 | 162 | let totalGVires = valueOrElse(getInteger(votingContract, ("proposal_gvires_" + id)), 0) | |
163 | 163 | let enabled = valueOrElse(getBoolean(configAddress, "op_governance_apply_tx_paused"), false) | |
164 | 164 | let voteYes = votesYes | |
165 | 165 | let voteNo = votesNo | |
166 | 166 | let totalVotes = (voteYes + voteNo) | |
167 | 167 | let hasQuorum = (((totalVotes * BASE) / totalGVires) >= quorumRatio) | |
168 | 168 | let hasPassed = (((voteYes * BASE) / totalVotes) >= passedRatio) | |
169 | 169 | let tooEarly = (applyStart >= HEIGHT) | |
170 | 170 | let tooLate = (HEIGHT >= applyEnd) | |
171 | 171 | let timeDebug = ((((((("proposalHeight = " + toString(proposalHeight)) + ", applyStart = ") + toString(applyStart)) + ", applyEnd = ") + toString(applyEnd)) + ", HEIGHT = ") + toString(HEIGHT)) | |
172 | 172 | let byVoting = if (!(enabled)) | |
173 | 173 | then throw("tx application throw governance not enabled") | |
174 | 174 | else if (tooEarly) | |
175 | 175 | then throw(("proposal can't be executed as it's too early: " + timeDebug)) | |
176 | 176 | else if (tooLate) | |
177 | 177 | then throw(("proposal can't be executed as it's too late:" + timeDebug)) | |
178 | 178 | else if (!(hasQuorum)) | |
179 | 179 | then throw((((((("no quorum: " + "totalVotes: ") + toString(totalVotes)) + ", totalGVires: ") + toString(totalGVires)) + ", quorumRatio: ") + toString(quorumRatio))) | |
180 | 180 | else if (!(hasPassed)) | |
181 | 181 | then throw((((((("no threshold achieved: " + "voteYes: ") + toString(voteYes)) + ", voteNo: ") + toString(voteNo)) + ", passedRatio: ") + toString(passedRatio))) | |
182 | 182 | else true | |
183 | 183 | if (sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)) | |
184 | 184 | then true | |
185 | 185 | else byVoting | |
186 | 186 | } | |
187 | 187 |
github/deemru/w8io/0e76f2f 44.18 ms ◑