tx · Hk6SLLL1Zw69rEVDJrbVKZcR7UDbBgzD2Rv4VA1Vp26x

3PJqzSu5ShM2qzkSkxDr2oc47TBH8zfBaUq:  -0.01100000 Waves

2023.10.18 19:44 [3870138] smart account 3PJqzSu5ShM2qzkSkxDr2oc47TBH8zfBaUq > SELF 0.00000000 Waves

{ "type": 13, "id": "Hk6SLLL1Zw69rEVDJrbVKZcR7UDbBgzD2Rv4VA1Vp26x", "fee": 1100000, "feeAssetId": null, "timestamp": 1697647547577, "version": 1, "sender": "3PJqzSu5ShM2qzkSkxDr2oc47TBH8zfBaUq", "senderPublicKey": "3JbL1AeoE8AP9xDHYyrbLCFxXtzyx5EPexG4H3CMdBMS", "proofs": [ "2LjD2N4t4z7kyUCSo4tnt1o3JJivbYYqkmL1XQJk3fRPiiZPMvLUfw96itrtGpc3kSirW6z914T86qn6t5WgGhuz" ], "script": "base64:BgIhCAISBQoDCAEEEgQKAgEEEgQKAgEEEgoKCAgICAgICAgIHAASY29uZmlnQWRkcmVzc1N0b3JlAg1jb25maWdBZGRyZXNzAA1jb25maWdBZGRyZXNzCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMFEmNvbmZpZ0FkZHJlc3NTdG9yZQIZcmVzZXJ2ZTogbm8gY29uZmlnQWRkcmVzcwIWaW52YWxpZCBjb25maWcgYWRkcmVzcwAGSEVJR0hUBQZoZWlnaHQBCW9wQWxsb3dlZAICb3AHcmVzZXJ2ZQQHJG1hdGNoMAkA/AcEBQ1jb25maWdBZGRyZXNzAglvcEFsbG93ZWQJAMwIAgUHcmVzZXJ2ZQkAzAgCBQJvcAUDbmlsBQNuaWwDCQABAgUHJG1hdGNoMAIHQm9vbGVhbgQBYgUHJG1hdGNoMAMFAWIGCQACAQILbm90IGFsbG93ZWQJAAIBAiFvcEFsbG93ZWQ6IHVuZXhwZWN0ZWQgcmVzdWx0IHR5cGUBEHdyaXRlQ29uc3RTdHJpbmcCA2tleQV2YWx1ZQMJAQEhAQkBCWlzRGVmaW5lZAEJAJ0IAgUEdGhpcwUDa2V5CQELU3RyaW5nRW50cnkCBQNrZXkFBXZhbHVlCQACAQkArAICAhVhbHJlYWR5IGluaXRpYWxpemVkOiAFA2tleQEKZ2V0QWRkcmVzcwEDa2V5CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCiCAEFA2tleQkArAICBQNrZXkCCiBub3QgZm91bmQJAKwCAgUDa2V5AhAgaW52YWxpZCBhZGRyZXNzAQhnZXRBc3NldAEDa2V5CQDZBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAoggBBQNrZXkJAKwCAgUDa2V5Agogbm90IGZvdW5kAAdsMlN0b3JlAgJMMgAIeHRuU3RvcmUCA1hUTgAPbDJDb250cmFjdFN0b3JlAgtMMl9jb250cmFjdAANbDJTdGFrZXJTdG9yZQISTDJfc3Rha2VyX2NvbnRyYWN0AA12ZXN0bkFsbFN0b3JlAgl2ZXN0bl9hbGwAD3Zlc3RuV2hhbGVTdG9yZQIFdmVzdG4ACm1haW40U3RvcmUCBW1haW40AAJsMgkBCGdldEFzc2V0AQUHbDJTdG9yZQADeHRuCQEIZ2V0QXNzZXQBBQh4dG5TdG9yZQAKbDJDb250cmFjdAkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTgpAQUPbDJDb250cmFjdFN0b3JlAAhsMnN0YWtlcgkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTgpAQUNbDJTdGFrZXJTdG9yZQAFbWFpbjQJARFAZXh0ck5hdGl2ZSgxMDYyKQEJARFAZXh0ck5hdGl2ZSgxMDU4KQEFCm1haW40U3RvcmUACXByb3RlY3RlZAkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTMpAgUNY29uZmlnQWRkcmVzcwIRcHJvdGVjdGVkX3Jlc2VydmUAA2FjYwkBEUBleHRyTmF0aXZlKDEwNTMpAgUFbWFpbjQCA2FjYwAIdmVzdG5BbGwJAQpnZXRBZGRyZXNzAQUNdmVzdG5BbGxTdG9yZQAKdmVzdG5XaGFsZQkBCmdldEFkZHJlc3MBBQ92ZXN0bldoYWxlU3RvcmUAC3Jlc2VydmVzU3RyCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUNY29uZmlnQWRkcmVzcwIQcHJpbWFyeV9yZXNlcnZlcwIWbm8gcmVzZXJ2ZXMgcmVnaXN0ZXJlZAEDdmxSAQFyAwkBCGNvbnRhaW5zAgULcmVzZXJ2ZXNTdHIFAXIJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBBQFyAg1tYWluOiBiYWQgcnNyCQACAQkArAICAgx1bmtub3duIHJzcjoFAXIBFmNvbnZlcnRYdG5Ub0wySW50ZXJuYWwDB2FkZHJlc3MJeHRuQW1vdW50BXN0YWtlBAFjCQD8BwQFCmwyQ29udHJhY3QCBHN3YXAJAMwIAgcFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUDeHRuBQl4dG5BbW91bnQFA25pbAMJAAACBQFjBQFjBAhsMkFtb3VudAkAaAIFCXh0bkFtb3VudABkAwUFc3Rha2UEAXMJAPwHBAUIbDJzdGFrZXICCHN0YWtlRm9yCQDMCAIJAKUIAQUHYWRkcmVzcwUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQJsMgUIbDJBbW91bnQFA25pbAMJAAACBQFzBQFzBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUHYWRkcmVzcwUIbDJBbW91bnQFAmwyBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BDWJlZm9yZVZlc3RpbmcBA2FtdAQLdmVzdGluZ1RvTDIAmOYFBARiYXNlAKCNBgQGYmVmb3JlCQBrAwUDYW10BQt2ZXN0aW5nVG9MMgUEYmFzZQQIbGVmdG92ZXIJAGUCBQNhbXQFBmJlZm9yZQkAlAoCBQZiZWZvcmUFCGxlZnRvdmVyAQVhc0ludAEFdmFsdWUEByRtYXRjaDAFBXZhbHVlAwkAAQIFByRtYXRjaDACA0ludAQDaW50BQckbWF0Y2gwBQNpbnQJAAIBAgRzbToxBAFpAQx3aXRoZHJhd1RvTDIDB3Jlc2VydmUGYW1vdW50BXN0YWtlBAZjaGVja3MJAQlvcEFsbG93ZWQCAgx3aXRoZHJhd1RvTDIFB3Jlc2VydmUDCQAAAgUGY2hlY2tzBQZjaGVja3MEAXIJAQN2bFIBBQdyZXNlcnZlAwkAAAIFAXIFAXIDCQBnAgAABQZhbW91bnQJAAIBAg5pbnZhbGlkIGFtb3VudAQJeHRuQW1vdW50CQEFYXNJbnQBCQD8BwQFBW1haW40Ag9zdGFydFZlc3RpbmdGb3IJAMwIAgkApQgBCAUBaQZjYWxsZXIJAMwIAgUHcmVzZXJ2ZQkAzAgCBQZhbW91bnQFA25pbAUDbmlsAwkAAAIFCXh0bkFtb3VudAUJeHRuQW1vdW50BAJ3ZAkA/AcEBQh2ZXN0bkFsbAIacGFydGlhbFdpdGhkcmF3VmVzdGVkRm9yVG8JAMwIAgkApQgBCAUBaQZjYWxsZXIJAMwIAgkApQgBBQR0aGlzCQDMCAIFCXh0bkFtb3VudAUDbmlsBQNuaWwDCQAAAgUCd2QFAndkCQEWY29udmVydFh0blRvTDJJbnRlcm5hbAMIBQFpBmNhbGxlcgUJeHRuQW1vdW50BQVzdGFrZQkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpARl3aXRoZHJhd1Zlc3RlZFJlZ3VsYXJUb0wyAgNhbXQFc3Rha2UEBmNoZWNrcwkBCW9wQWxsb3dlZAICDHdpdGhkcmF3VG9MMgIOdmVzdGVkX3JlZ3VsYXIDCQAAAgUGY2hlY2tzBQZjaGVja3MDCQBnAgAABQNhbXQJAAIBAg5pbnZhbGlkIGFtb3VudAQCd2QJAPwHBAUIdmVzdG5BbGwCGnBhcnRpYWxXaXRoZHJhd1Zlc3RlZEZvclRvCQDMCAIJAKUIAQgFAWkGY2FsbGVyCQDMCAIJAKUIAQUEdGhpcwkAzAgCBQNhbXQFA25pbAUDbmlsAwkAAAIFAndkBQJ3ZAQLJHQwMzY0OTM2OTMJAQ1iZWZvcmVWZXN0aW5nAQUDYW10BAd1c2RuQW10CAULJHQwMzY0OTM2OTMCXzEECGxlZnRvdmVyCAULJHQwMzY0OTM2OTMCXzIJAMwIAgkBBEJ1cm4CBQN4dG4FCGxlZnRvdmVyCQEWY29udmVydFh0blRvTDJJbnRlcm5hbAMIBQFpBmNhbGxlcgUHdXNkbkFtdAUFc3Rha2UJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEXd2l0aGRyYXdWZXN0ZWRXaGFsZVRvTDICA2FtdAVzdGFrZQQGY2hlY2tzCQEJb3BBbGxvd2VkAgIMd2l0aGRyYXdUb0wyAgx2ZXN0ZWRfd2hhbGUDCQAAAgUGY2hlY2tzBQZjaGVja3MDCQBnAgAABQNhbXQJAAIBAg5pbnZhbGlkIGFtb3VudAQCd2QJAPwHBAUKdmVzdG5XaGFsZQIZcGFydGlhbFdpdGhkcmF3VmVzdGVkVG9MMgkAzAgCCQClCAEIBQFpBmNhbGxlcgkAzAgCCQClCAEFBHRoaXMJAMwIAgUDYW10BQNuaWwFA25pbAMJAAACBQJ3ZAUCd2QECyR0MDQwODI0MTI2CQENYmVmb3JlVmVzdGluZwEFA2FtdAQHdXNkbkFtdAgFCyR0MDQwODI0MTI2Al8xBAhsZWZ0b3ZlcggFCyR0MDQwODI0MTI2Al8yCQDMCAIJAQRCdXJuAgUDeHRuBQhsZWZ0b3ZlcgkBFmNvbnZlcnRYdG5Ub0wySW50ZXJuYWwDCAUBaQZjYWxsZXIFB3VzZG5BbXQFBXN0YWtlCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBCmluaXRpYWxpemUIDWNvbmZpZ0FkZHJlc3MCbDIDeHRuCWwyQ290cmFjdAhsMlN0YWtlcgh2ZXN0bkFsbAp2ZXN0bldoYWxlBW1haW40CQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgUSY29uZmlnQWRkcmVzc1N0b3JlBQ1jb25maWdBZGRyZXNzCQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgUHbDJTdG9yZQUCbDIJAMwIAgkBEHdyaXRlQ29uc3RTdHJpbmcCBQh4dG5TdG9yZQUDeHRuCQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgUPbDJDb250cmFjdFN0b3JlBQlsMkNvdHJhY3QJAMwIAgkBEHdyaXRlQ29uc3RTdHJpbmcCBQ1sMlN0YWtlclN0b3JlBQhsMlN0YWtlcgkAzAgCCQEQd3JpdGVDb25zdFN0cmluZwIFDXZlc3RuQWxsU3RvcmUFCHZlc3RuQWxsCQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgUPdmVzdG5XaGFsZVN0b3JlBQp2ZXN0bldoYWxlCQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgUKbWFpbjRTdG9yZQUFbWFpbjQFA25pbAECdHgBBnZlcmlmeQAEBEJBU0UA6AcEC3F1b3J1bVJhdGlvCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUNY29uZmlnQWRkcmVzcwIVcHJvcG9zYWxfcXVvcnVtX3JhdGlvAiJwcm9wb3NhbFF1b3J1bVJhdGlvIGlzIG5vdCBkZWZpbmVkBAtwYXNzZWRSYXRpbwkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFDWNvbmZpZ0FkZHJlc3MCFXByb3Bvc2FsX3Bhc3NlZF9yYXRpbwIlcHJvcG9zYWxUaHJlc2hvbGRSYXRpbyBpcyBub3QgZGVmaW5lZAQOZ1ZpcmVzQ29udHJhY3QJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUNY29uZmlnQWRkcmVzcwISZGl2aWRlbmRzX2NvbnRyYWN0AhVubyBkaXZpZGVuZHNfY29udHJhY3QCGmludmFsaWQgZGl2aWRlbmRzX2NvbnRyYWN0BA52b3RpbmdDb250cmFjdAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQ1jb25maWdBZGRyZXNzAg92b3RpbmdfY29udHJhY3QCEm5vIHZvdGluZ19jb250cmFjdAIXaW52YWxpZCB2b3RpbmdfY29udHJhY3QEAmlkCQDYBAEIBQJ0eAJpZAQIdm90ZXNZZXMJAQt2YWx1ZU9yRWxzZQIJAJoIAgUOdm90aW5nQ29udHJhY3QJAKwCAgINcHJvcG9zYWxfeWVzXwUCaWQAAAQHdm90ZXNObwkBC3ZhbHVlT3JFbHNlAgkAmggCBQ52b3RpbmdDb250cmFjdAkArAICAgxwcm9wb3NhbF9ub18FAmlkAAAEDnByb3Bvc2FsSGVpZ2h0CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUOdm90aW5nQ29udHJhY3QJAKwCAgIQcHJvcG9zYWxfaGVpZ2h0XwUCaWQCF3Byb3Bvc2FsIG5vdCByZWdpc3RlcmVkBAphcHBseVN0YXJ0CQELdmFsdWVPckVsc2UCCQCaCAIFDnZvdGluZ0NvbnRyYWN0CQCsAgICFHByb3Bvc2FsX2FwcGx5c3RhcnRfBQJpZAAABAhhcHBseUVuZAkBC3ZhbHVlT3JFbHNlAgkAmggCBQ52b3RpbmdDb250cmFjdAkArAICAhJwcm9wb3NhbF9hcHBseWVuZF8FAmlkAAAEC3RvdGFsR1ZpcmVzCQELdmFsdWVPckVsc2UCCQCaCAIFDnZvdGluZ0NvbnRyYWN0CQCsAgICEHByb3Bvc2FsX2d2aXJlc18FAmlkAAAEB2VuYWJsZWQJAQt2YWx1ZU9yRWxzZQIJAJsIAgUNY29uZmlnQWRkcmVzcwIdb3BfZ292ZXJuYW5jZV9hcHBseV90eF9wYXVzZWQHBAd2b3RlWWVzBQh2b3Rlc1llcwQGdm90ZU5vBQd2b3Rlc05vBAp0b3RhbFZvdGVzCQBkAgUHdm90ZVllcwUGdm90ZU5vBAloYXNRdW9ydW0JAGcCCQBpAgkAaAIFCnRvdGFsVm90ZXMFBEJBU0UFC3RvdGFsR1ZpcmVzBQtxdW9ydW1SYXRpbwQJaGFzUGFzc2VkCQBnAgkAaQIJAGgCBQd2b3RlWWVzBQRCQVNFBQp0b3RhbFZvdGVzBQtwYXNzZWRSYXRpbwQIdG9vRWFybHkJAGcCBQphcHBseVN0YXJ0BQZIRUlHSFQEB3Rvb0xhdGUJAGcCBQZIRUlHSFQFCGFwcGx5RW5kBAl0aW1lRGVidWcJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgIRcHJvcG9zYWxIZWlnaHQgPSAJAKQDAQUOcHJvcG9zYWxIZWlnaHQCDywgYXBwbHlTdGFydCA9IAkApAMBBQphcHBseVN0YXJ0Ag0sIGFwcGx5RW5kID0gCQCkAwEFCGFwcGx5RW5kAgssIEhFSUdIVCA9IAkApAMBBQZIRUlHSFQECGJ5Vm90aW5nAwkBASEBBQdlbmFibGVkCQACAQIrdHggYXBwbGljYXRpb24gdGhyb3cgZ292ZXJuYW5jZSBub3QgZW5hYmxlZAMFCHRvb0Vhcmx5CQACAQkArAICAi5wcm9wb3NhbCBjYW4ndCBiZSBleGVjdXRlZCBhcyBpdCdzIHRvbyBlYXJseTogBQl0aW1lRGVidWcDBQd0b29MYXRlCQACAQkArAICAixwcm9wb3NhbCBjYW4ndCBiZSBleGVjdXRlZCBhcyBpdCdzIHRvbyBsYXRlOgUJdGltZURlYnVnAwkBASEBBQloYXNRdW9ydW0JAAIBCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAgtubyBxdW9ydW06IAIMdG90YWxWb3RlczogCQCkAwEFCnRvdGFsVm90ZXMCDywgdG90YWxHVmlyZXM6IAkApAMBBQt0b3RhbEdWaXJlcwIPLCBxdW9ydW1SYXRpbzogCQCkAwEFC3F1b3J1bVJhdGlvAwkBASEBBQloYXNQYXNzZWQJAAIBCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAhdubyB0aHJlc2hvbGQgYWNoaWV2ZWQ6IAIJdm90ZVllczogCQCkAwEFB3ZvdGVZZXMCCiwgdm90ZU5vOiAJAKQDAQUGdm90ZU5vAg8sIHBhc3NlZFJhdGlvOiAJAKQDAQULcGFzc2VkUmF0aW8GAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAgFAnR4D3NlbmRlclB1YmxpY0tleQYFCGJ5Vm90aW5nT7hcYw==", "chainId": 87, "height": 3870138, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 8HVVuWCeBTL6g4yTACLEWhvZ941C1MuTDVETjtcUgdCK Next: none Diff:
OldNewDifferences
112112 then if ((0 >= amount))
113113 then throw("invalid amount")
114114 else {
115- let vesing = invoke(main4, "startVestingFor", [toString(i.caller), reserve, amount], nil)
116- if ((vesing == vesing))
115+ let xtnAmount = asInt(invoke(main4, "startVestingFor", [toString(i.caller), reserve, amount], nil))
116+ if ((xtnAmount == xtnAmount))
117117 then {
118- let xtnAmount = asInt(invoke(vestnAll, "partialWithdrawVestedForTo", [toString(i.caller), toString(this), amount], nil))
119- if ((xtnAmount == xtnAmount))
118+ let wd = invoke(vestnAll, "partialWithdrawVestedForTo", [toString(i.caller), toString(this), xtnAmount], nil)
119+ if ((wd == wd))
120120 then convertXtnToL2Internal(i.caller, xtnAmount, stake)
121121 else throw("Strict value is not equal to itself.")
122122 }
139139 let wd = invoke(vestnAll, "partialWithdrawVestedForTo", [toString(i.caller), toString(this), amt], nil)
140140 if ((wd == wd))
141141 then {
142- let $t036503694 = beforeVesting(amt)
143- let usdnAmt = $t036503694._1
144- let leftover = $t036503694._2
142+ let $t036493693 = beforeVesting(amt)
143+ let usdnAmt = $t036493693._1
144+ let leftover = $t036493693._2
145145 [Burn(xtn, leftover), convertXtnToL2Internal(i.caller, usdnAmt, stake)]
146146 }
147147 else throw("Strict value is not equal to itself.")
161161 let wd = invoke(vestnWhale, "partialWithdrawVestedToL2", [toString(i.caller), toString(this), amt], nil)
162162 if ((wd == wd))
163163 then {
164- let $t040834127 = beforeVesting(amt)
165- let usdnAmt = $t040834127._1
166- let leftover = $t040834127._2
164+ let $t040824126 = beforeVesting(amt)
165+ let usdnAmt = $t040824126._1
166+ let leftover = $t040824126._2
167167 [Burn(xtn, leftover), convertXtnToL2Internal(i.caller, usdnAmt, stake)]
168168 }
169169 else throw("Strict value is not equal to itself.")
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
2525 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 protected = addressFromStringValue(getStringValue(configAddress, "protected_reserve"))
5656
5757 let acc = getStringValue(main4, "acc")
5858
5959 let vestnAll = getAddress(vestnAllStore)
6060
6161 let vestnWhale = getAddress(vestnWhaleStore)
6262
6363 let reservesStr = valueOrErrorMessage(getString(configAddress, "primary_reserves"), "no reserves registered")
6464
6565 func vlR (r) = if (contains(reservesStr, r))
6666 then valueOrErrorMessage(addressFromString(r), "main: bad rsr")
6767 else throw(("unknown rsr:" + r))
6868
6969
7070 func convertXtnToL2Internal (address,xtnAmount,stake) = {
7171 let c = invoke(l2Contract, "swap", [false], [AttachedPayment(xtn, xtnAmount)])
7272 if ((c == c))
7373 then {
7474 let l2Amount = (xtnAmount * 100)
7575 if (stake)
7676 then {
7777 let s = invoke(l2staker, "stakeFor", [toString(address)], [AttachedPayment(l2, l2Amount)])
7878 if ((s == s))
7979 then nil
8080 else throw("Strict value is not equal to itself.")
8181 }
8282 else [ScriptTransfer(address, l2Amount, l2)]
8383 }
8484 else throw("Strict value is not equal to itself.")
8585 }
8686
8787
8888 func beforeVesting (amt) = {
8989 let vestingToL2 = 95000
9090 let base = 100000
9191 let before = fraction(amt, vestingToL2, base)
9292 let leftover = (amt - before)
9393 $Tuple2(before, leftover)
9494 }
9595
9696
9797 func asInt (value) = match value {
9898 case int: Int =>
9999 int
100100 case _ =>
101101 throw("sm:1")
102102 }
103103
104104
105105 @Callable(i)
106106 func withdrawToL2 (reserve,amount,stake) = {
107107 let checks = opAllowed("withdrawToL2", reserve)
108108 if ((checks == checks))
109109 then {
110110 let r = vlR(reserve)
111111 if ((r == r))
112112 then if ((0 >= amount))
113113 then throw("invalid amount")
114114 else {
115- let vesing = invoke(main4, "startVestingFor", [toString(i.caller), reserve, amount], nil)
116- if ((vesing == vesing))
115+ let xtnAmount = asInt(invoke(main4, "startVestingFor", [toString(i.caller), reserve, amount], nil))
116+ if ((xtnAmount == xtnAmount))
117117 then {
118- let xtnAmount = asInt(invoke(vestnAll, "partialWithdrawVestedForTo", [toString(i.caller), toString(this), amount], nil))
119- if ((xtnAmount == xtnAmount))
118+ let wd = invoke(vestnAll, "partialWithdrawVestedForTo", [toString(i.caller), toString(this), xtnAmount], nil)
119+ if ((wd == wd))
120120 then convertXtnToL2Internal(i.caller, xtnAmount, stake)
121121 else throw("Strict value is not equal to itself.")
122122 }
123123 else throw("Strict value is not equal to itself.")
124124 }
125125 else throw("Strict value is not equal to itself.")
126126 }
127127 else throw("Strict value is not equal to itself.")
128128 }
129129
130130
131131
132132 @Callable(i)
133133 func withdrawVestedRegularToL2 (amt,stake) = {
134134 let checks = opAllowed("withdrawToL2", "vested_regular")
135135 if ((checks == checks))
136136 then if ((0 >= amt))
137137 then throw("invalid amount")
138138 else {
139139 let wd = invoke(vestnAll, "partialWithdrawVestedForTo", [toString(i.caller), toString(this), amt], nil)
140140 if ((wd == wd))
141141 then {
142- let $t036503694 = beforeVesting(amt)
143- let usdnAmt = $t036503694._1
144- let leftover = $t036503694._2
142+ let $t036493693 = beforeVesting(amt)
143+ let usdnAmt = $t036493693._1
144+ let leftover = $t036493693._2
145145 [Burn(xtn, leftover), convertXtnToL2Internal(i.caller, usdnAmt, stake)]
146146 }
147147 else throw("Strict value is not equal to itself.")
148148 }
149149 else throw("Strict value is not equal to itself.")
150150 }
151151
152152
153153
154154 @Callable(i)
155155 func withdrawVestedWhaleToL2 (amt,stake) = {
156156 let checks = opAllowed("withdrawToL2", "vested_whale")
157157 if ((checks == checks))
158158 then if ((0 >= amt))
159159 then throw("invalid amount")
160160 else {
161161 let wd = invoke(vestnWhale, "partialWithdrawVestedToL2", [toString(i.caller), toString(this), amt], nil)
162162 if ((wd == wd))
163163 then {
164- let $t040834127 = beforeVesting(amt)
165- let usdnAmt = $t040834127._1
166- let leftover = $t040834127._2
164+ let $t040824126 = beforeVesting(amt)
165+ let usdnAmt = $t040824126._1
166+ let leftover = $t040824126._2
167167 [Burn(xtn, leftover), convertXtnToL2Internal(i.caller, usdnAmt, stake)]
168168 }
169169 else throw("Strict value is not equal to itself.")
170170 }
171171 else throw("Strict value is not equal to itself.")
172172 }
173173
174174
175175
176176 @Callable(i)
177177 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)]
178178
179179
180180 @Verifier(tx)
181181 func verify () = {
182182 let BASE = 1000
183183 let quorumRatio = valueOrErrorMessage(getInteger(configAddress, "proposal_quorum_ratio"), "proposalQuorumRatio is not defined")
184184 let passedRatio = valueOrErrorMessage(getInteger(configAddress, "proposal_passed_ratio"), "proposalThresholdRatio is not defined")
185185 let gViresContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "dividends_contract"), "no dividends_contract")), "invalid dividends_contract")
186186 let votingContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "voting_contract"), "no voting_contract")), "invalid voting_contract")
187187 let id = toBase58String(tx.id)
188188 let votesYes = valueOrElse(getInteger(votingContract, ("proposal_yes_" + id)), 0)
189189 let votesNo = valueOrElse(getInteger(votingContract, ("proposal_no_" + id)), 0)
190190 let proposalHeight = valueOrErrorMessage(getInteger(votingContract, ("proposal_height_" + id)), "proposal not registered")
191191 let applyStart = valueOrElse(getInteger(votingContract, ("proposal_applystart_" + id)), 0)
192192 let applyEnd = valueOrElse(getInteger(votingContract, ("proposal_applyend_" + id)), 0)
193193 let totalGVires = valueOrElse(getInteger(votingContract, ("proposal_gvires_" + id)), 0)
194194 let enabled = valueOrElse(getBoolean(configAddress, "op_governance_apply_tx_paused"), false)
195195 let voteYes = votesYes
196196 let voteNo = votesNo
197197 let totalVotes = (voteYes + voteNo)
198198 let hasQuorum = (((totalVotes * BASE) / totalGVires) >= quorumRatio)
199199 let hasPassed = (((voteYes * BASE) / totalVotes) >= passedRatio)
200200 let tooEarly = (applyStart >= HEIGHT)
201201 let tooLate = (HEIGHT >= applyEnd)
202202 let timeDebug = ((((((("proposalHeight = " + toString(proposalHeight)) + ", applyStart = ") + toString(applyStart)) + ", applyEnd = ") + toString(applyEnd)) + ", HEIGHT = ") + toString(HEIGHT))
203203 let byVoting = if (!(enabled))
204204 then throw("tx application throw governance not enabled")
205205 else if (tooEarly)
206206 then throw(("proposal can't be executed as it's too early: " + timeDebug))
207207 else if (tooLate)
208208 then throw(("proposal can't be executed as it's too late:" + timeDebug))
209209 else if (!(hasQuorum))
210210 then throw((((((("no quorum: " + "totalVotes: ") + toString(totalVotes)) + ", totalGVires: ") + toString(totalGVires)) + ", quorumRatio: ") + toString(quorumRatio)))
211211 else if (!(hasPassed))
212212 then throw((((((("no threshold achieved: " + "voteYes: ") + toString(voteYes)) + ", voteNo: ") + toString(voteNo)) + ", passedRatio: ") + toString(passedRatio)))
213213 else true
214214 if (sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey))
215215 then true
216216 else byVoting
217217 }
218218

github/deemru/w8io/6500d08 
42.67 ms