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:
OldNewDifferences
2222 else throw(("already initialized: " + key))
2323
2424
25-func getAddress (key) = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString("key"), (key + " not found"))), (key + " invalid address"))
25+func getAddress (key) = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(key), (key + " not found"))), (key + " invalid address"))
2626
2727
2828 func getAsset (key) = fromBase58String(valueOrErrorMessage(getString(key), (key + " not found")))
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let configAddressStore = "configAddress"
55
66 let configAddress = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(this, configAddressStore), "reserve: no configAddress")), "invalid config address")
77
88 let HEIGHT = height
99
1010 func opAllowed (op,reserve) = match invoke(configAddress, "opAllowed", [reserve, op], nil) {
1111 case b: Boolean =>
1212 if (b)
1313 then true
1414 else throw("not allowed")
1515 case _ =>
1616 throw("opAllowed: unexpected result type")
1717 }
1818
1919
2020 func writeConstString (key,value) = if (!(isDefined(getString(this, key))))
2121 then StringEntry(key, value)
2222 else throw(("already initialized: " + key))
2323
2424
25-func getAddress (key) = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString("key"), (key + " not found"))), (key + " invalid address"))
25+func getAddress (key) = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(key), (key + " not found"))), (key + " invalid address"))
2626
2727
2828 func getAsset (key) = fromBase58String(valueOrErrorMessage(getString(key), (key + " not found")))
2929
3030
3131 let l2Store = "L2"
3232
3333 let xtnStore = "XTN"
3434
3535 let l2ContractStore = "L2_contract"
3636
3737 let l2StakerStore = "L2_staker_contract"
3838
3939 let vestnAllStore = "vestn_all"
4040
4141 let vestnWhaleStore = "vestn"
4242
4343 let main4Store = "main4"
4444
4545 let l2 = getAsset(l2Store)
4646
4747 let xtn = getAsset(xtnStore)
4848
4949 let l2Contract = addressFromStringValue(getStringValue(l2ContractStore))
5050
5151 let l2staker = addressFromStringValue(getStringValue(l2StakerStore))
5252
5353 let main4 = addressFromStringValue(getStringValue(main4Store))
5454
5555 let vestnAll = getAddress(vestnAllStore)
5656
5757 let vestnWhale = getAddress(vestnWhaleStore)
5858
5959 func convertXtnToL2Internal (address,xtnAmount,stake) = if ((xtnAmount > 1000000))
6060 then throw("to many")
6161 else {
6262 let c = invoke(l2Contract, "swap", nil, [AttachedPayment(xtn, xtnAmount)])
6363 if ((c == c))
6464 then {
6565 let l2Amount = (xtnAmount * 100)
6666 if (stake)
6767 then {
6868 let s = invoke(l2staker, "stakeFor", [toString(address)], [AttachedPayment(l2, l2Amount)])
6969 if ((s == s))
7070 then nil
7171 else throw("Strict value is not equal to itself.")
7272 }
7373 else [ScriptTransfer(address, l2Amount, l2)]
7474 }
7575 else throw("Strict value is not equal to itself.")
7676 }
7777
7878
7979 @Callable(i)
8080 func withdrawToL2 (reserve,amount,stake) = {
8181 let a = throw("not implementd")
8282 if ((a == a))
8383 then {
8484 let checks = opAllowed("withdrawToL2", reserve)
8585 if ((checks == checks))
8686 then {
8787 let vesing = invoke(main4, "startVesting", [reserve, amount], nil)
8888 if ((vesing == vesing))
8989 then {
9090 let wd = invoke(vestnAll, "partialWithdrawVestedForTo", [toString(i.caller), toString(this), amount], nil)
9191 if ((wd == wd))
9292 then convertXtnToL2Internal(i.caller, amount, stake)
9393 else throw("Strict value is not equal to itself.")
9494 }
9595 else throw("Strict value is not equal to itself.")
9696 }
9797 else throw("Strict value is not equal to itself.")
9898 }
9999 else throw("Strict value is not equal to itself.")
100100 }
101101
102102
103103
104104 @Callable(i)
105105 func withdrawVestedRegularToL2 (amt,stake) = {
106106 let checks = opAllowed("withdrawToL2", "vested_regular")
107107 if ((checks == checks))
108108 then {
109109 let wd = invoke(vestnAll, "partialWithdrawVestedForTo", [toString(i.caller), toString(this), amt], nil)
110110 if ((wd == wd))
111111 then {
112112 let vestingToL2 = 95000
113113 let base = 100000
114114 let usdnAmt = fraction(amt, vestingToL2, base)
115115 let leftover = (amt - usdnAmt)
116116 (convertXtnToL2Internal(i.caller, usdnAmt, stake) ++ [Burn(xtn, leftover)])
117117 }
118118 else throw("Strict value is not equal to itself.")
119119 }
120120 else throw("Strict value is not equal to itself.")
121121 }
122122
123123
124124
125125 @Callable(i)
126126 func withdrawVestedWhaleToL2 (amt,stake) = {
127127 let a = throw("not implementd")
128128 if ((a == a))
129129 then {
130130 let checks = opAllowed("withdrawToL2", "vested_whale")
131131 if ((checks == checks))
132132 then {
133133 let wd = invoke(vestnWhale, "partialWithdrawVestedForTo", [toString(i.caller), toString(this), amt], nil)
134134 if ((wd == wd))
135135 then convertXtnToL2Internal(i.caller, amt, stake)
136136 else throw("Strict value is not equal to itself.")
137137 }
138138 else throw("Strict value is not equal to itself.")
139139 }
140140 else throw("Strict value is not equal to itself.")
141141 }
142142
143143
144144
145145 @Callable(i)
146146 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)]
147147
148148
149149 @Verifier(tx)
150150 func verify () = {
151151 let BASE = 1000
152152 let quorumRatio = valueOrErrorMessage(getInteger(configAddress, "proposal_quorum_ratio"), "proposalQuorumRatio is not defined")
153153 let passedRatio = valueOrErrorMessage(getInteger(configAddress, "proposal_passed_ratio"), "proposalThresholdRatio is not defined")
154154 let gViresContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "dividends_contract"), "no dividends_contract")), "invalid dividends_contract")
155155 let votingContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "voting_contract"), "no voting_contract")), "invalid voting_contract")
156156 let id = toBase58String(tx.id)
157157 let votesYes = valueOrElse(getInteger(votingContract, ("proposal_yes_" + id)), 0)
158158 let votesNo = valueOrElse(getInteger(votingContract, ("proposal_no_" + id)), 0)
159159 let proposalHeight = valueOrErrorMessage(getInteger(votingContract, ("proposal_height_" + id)), "proposal not registered")
160160 let applyStart = valueOrElse(getInteger(votingContract, ("proposal_applystart_" + id)), 0)
161161 let applyEnd = valueOrElse(getInteger(votingContract, ("proposal_applyend_" + id)), 0)
162162 let totalGVires = valueOrElse(getInteger(votingContract, ("proposal_gvires_" + id)), 0)
163163 let enabled = valueOrElse(getBoolean(configAddress, "op_governance_apply_tx_paused"), false)
164164 let voteYes = votesYes
165165 let voteNo = votesNo
166166 let totalVotes = (voteYes + voteNo)
167167 let hasQuorum = (((totalVotes * BASE) / totalGVires) >= quorumRatio)
168168 let hasPassed = (((voteYes * BASE) / totalVotes) >= passedRatio)
169169 let tooEarly = (applyStart >= HEIGHT)
170170 let tooLate = (HEIGHT >= applyEnd)
171171 let timeDebug = ((((((("proposalHeight = " + toString(proposalHeight)) + ", applyStart = ") + toString(applyStart)) + ", applyEnd = ") + toString(applyEnd)) + ", HEIGHT = ") + toString(HEIGHT))
172172 let byVoting = if (!(enabled))
173173 then throw("tx application throw governance not enabled")
174174 else if (tooEarly)
175175 then throw(("proposal can't be executed as it's too early: " + timeDebug))
176176 else if (tooLate)
177177 then throw(("proposal can't be executed as it's too late:" + timeDebug))
178178 else if (!(hasQuorum))
179179 then throw((((((("no quorum: " + "totalVotes: ") + toString(totalVotes)) + ", totalGVires: ") + toString(totalGVires)) + ", quorumRatio: ") + toString(quorumRatio)))
180180 else if (!(hasPassed))
181181 then throw((((((("no threshold achieved: " + "voteYes: ") + toString(voteYes)) + ", voteNo: ") + toString(voteNo)) + ", passedRatio: ") + toString(passedRatio)))
182182 else true
183183 if (sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey))
184184 then true
185185 else byVoting
186186 }
187187

github/deemru/w8io/3ef1775 
45.72 ms