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:
Old | New | Differences | |
---|---|---|---|
112 | 112 | then if ((0 >= amount)) | |
113 | 113 | then throw("invalid amount") | |
114 | 114 | else { | |
115 | - | let | |
116 | - | if (( | |
115 | + | let xtnAmount = asInt(invoke(main4, "startVestingFor", [toString(i.caller), reserve, amount], nil)) | |
116 | + | if ((xtnAmount == xtnAmount)) | |
117 | 117 | then { | |
118 | - | let | |
119 | - | if (( | |
118 | + | let wd = invoke(vestnAll, "partialWithdrawVestedForTo", [toString(i.caller), toString(this), xtnAmount], nil) | |
119 | + | if ((wd == wd)) | |
120 | 120 | then convertXtnToL2Internal(i.caller, xtnAmount, stake) | |
121 | 121 | else throw("Strict value is not equal to itself.") | |
122 | 122 | } | |
139 | 139 | let wd = invoke(vestnAll, "partialWithdrawVestedForTo", [toString(i.caller), toString(this), amt], nil) | |
140 | 140 | if ((wd == wd)) | |
141 | 141 | then { | |
142 | - | let $ | |
143 | - | let usdnAmt = $ | |
144 | - | let leftover = $ | |
142 | + | let $t036493693 = beforeVesting(amt) | |
143 | + | let usdnAmt = $t036493693._1 | |
144 | + | let leftover = $t036493693._2 | |
145 | 145 | [Burn(xtn, leftover), convertXtnToL2Internal(i.caller, usdnAmt, stake)] | |
146 | 146 | } | |
147 | 147 | else throw("Strict value is not equal to itself.") | |
161 | 161 | let wd = invoke(vestnWhale, "partialWithdrawVestedToL2", [toString(i.caller), toString(this), amt], nil) | |
162 | 162 | if ((wd == wd)) | |
163 | 163 | then { | |
164 | - | let $ | |
165 | - | let usdnAmt = $ | |
166 | - | let leftover = $ | |
164 | + | let $t040824126 = beforeVesting(amt) | |
165 | + | let usdnAmt = $t040824126._1 | |
166 | + | let leftover = $t040824126._2 | |
167 | 167 | [Burn(xtn, leftover), convertXtnToL2Internal(i.caller, usdnAmt, stake)] | |
168 | 168 | } | |
169 | 169 | else throw("Strict value is not equal to itself.") |
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 | 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 protected = addressFromStringValue(getStringValue(configAddress, "protected_reserve")) | |
56 | 56 | ||
57 | 57 | let acc = getStringValue(main4, "acc") | |
58 | 58 | ||
59 | 59 | let vestnAll = getAddress(vestnAllStore) | |
60 | 60 | ||
61 | 61 | let vestnWhale = getAddress(vestnWhaleStore) | |
62 | 62 | ||
63 | 63 | let reservesStr = valueOrErrorMessage(getString(configAddress, "primary_reserves"), "no reserves registered") | |
64 | 64 | ||
65 | 65 | func vlR (r) = if (contains(reservesStr, r)) | |
66 | 66 | then valueOrErrorMessage(addressFromString(r), "main: bad rsr") | |
67 | 67 | else throw(("unknown rsr:" + r)) | |
68 | 68 | ||
69 | 69 | ||
70 | 70 | func convertXtnToL2Internal (address,xtnAmount,stake) = { | |
71 | 71 | let c = invoke(l2Contract, "swap", [false], [AttachedPayment(xtn, xtnAmount)]) | |
72 | 72 | if ((c == c)) | |
73 | 73 | then { | |
74 | 74 | let l2Amount = (xtnAmount * 100) | |
75 | 75 | if (stake) | |
76 | 76 | then { | |
77 | 77 | let s = invoke(l2staker, "stakeFor", [toString(address)], [AttachedPayment(l2, l2Amount)]) | |
78 | 78 | if ((s == s)) | |
79 | 79 | then nil | |
80 | 80 | else throw("Strict value is not equal to itself.") | |
81 | 81 | } | |
82 | 82 | else [ScriptTransfer(address, l2Amount, l2)] | |
83 | 83 | } | |
84 | 84 | else throw("Strict value is not equal to itself.") | |
85 | 85 | } | |
86 | 86 | ||
87 | 87 | ||
88 | 88 | func beforeVesting (amt) = { | |
89 | 89 | let vestingToL2 = 95000 | |
90 | 90 | let base = 100000 | |
91 | 91 | let before = fraction(amt, vestingToL2, base) | |
92 | 92 | let leftover = (amt - before) | |
93 | 93 | $Tuple2(before, leftover) | |
94 | 94 | } | |
95 | 95 | ||
96 | 96 | ||
97 | 97 | func asInt (value) = match value { | |
98 | 98 | case int: Int => | |
99 | 99 | int | |
100 | 100 | case _ => | |
101 | 101 | throw("sm:1") | |
102 | 102 | } | |
103 | 103 | ||
104 | 104 | ||
105 | 105 | @Callable(i) | |
106 | 106 | func withdrawToL2 (reserve,amount,stake) = { | |
107 | 107 | let checks = opAllowed("withdrawToL2", reserve) | |
108 | 108 | if ((checks == checks)) | |
109 | 109 | then { | |
110 | 110 | let r = vlR(reserve) | |
111 | 111 | if ((r == r)) | |
112 | 112 | then if ((0 >= amount)) | |
113 | 113 | then throw("invalid amount") | |
114 | 114 | else { | |
115 | - | let | |
116 | - | if (( | |
115 | + | let xtnAmount = asInt(invoke(main4, "startVestingFor", [toString(i.caller), reserve, amount], nil)) | |
116 | + | if ((xtnAmount == xtnAmount)) | |
117 | 117 | then { | |
118 | - | let | |
119 | - | if (( | |
118 | + | let wd = invoke(vestnAll, "partialWithdrawVestedForTo", [toString(i.caller), toString(this), xtnAmount], nil) | |
119 | + | if ((wd == wd)) | |
120 | 120 | then convertXtnToL2Internal(i.caller, xtnAmount, stake) | |
121 | 121 | else throw("Strict value is not equal to itself.") | |
122 | 122 | } | |
123 | 123 | else throw("Strict value is not equal to itself.") | |
124 | 124 | } | |
125 | 125 | else throw("Strict value is not equal to itself.") | |
126 | 126 | } | |
127 | 127 | else throw("Strict value is not equal to itself.") | |
128 | 128 | } | |
129 | 129 | ||
130 | 130 | ||
131 | 131 | ||
132 | 132 | @Callable(i) | |
133 | 133 | func withdrawVestedRegularToL2 (amt,stake) = { | |
134 | 134 | let checks = opAllowed("withdrawToL2", "vested_regular") | |
135 | 135 | if ((checks == checks)) | |
136 | 136 | then if ((0 >= amt)) | |
137 | 137 | then throw("invalid amount") | |
138 | 138 | else { | |
139 | 139 | let wd = invoke(vestnAll, "partialWithdrawVestedForTo", [toString(i.caller), toString(this), amt], nil) | |
140 | 140 | if ((wd == wd)) | |
141 | 141 | then { | |
142 | - | let $ | |
143 | - | let usdnAmt = $ | |
144 | - | let leftover = $ | |
142 | + | let $t036493693 = beforeVesting(amt) | |
143 | + | let usdnAmt = $t036493693._1 | |
144 | + | let leftover = $t036493693._2 | |
145 | 145 | [Burn(xtn, leftover), convertXtnToL2Internal(i.caller, usdnAmt, stake)] | |
146 | 146 | } | |
147 | 147 | else throw("Strict value is not equal to itself.") | |
148 | 148 | } | |
149 | 149 | else throw("Strict value is not equal to itself.") | |
150 | 150 | } | |
151 | 151 | ||
152 | 152 | ||
153 | 153 | ||
154 | 154 | @Callable(i) | |
155 | 155 | func withdrawVestedWhaleToL2 (amt,stake) = { | |
156 | 156 | let checks = opAllowed("withdrawToL2", "vested_whale") | |
157 | 157 | if ((checks == checks)) | |
158 | 158 | then if ((0 >= amt)) | |
159 | 159 | then throw("invalid amount") | |
160 | 160 | else { | |
161 | 161 | let wd = invoke(vestnWhale, "partialWithdrawVestedToL2", [toString(i.caller), toString(this), amt], nil) | |
162 | 162 | if ((wd == wd)) | |
163 | 163 | then { | |
164 | - | let $ | |
165 | - | let usdnAmt = $ | |
166 | - | let leftover = $ | |
164 | + | let $t040824126 = beforeVesting(amt) | |
165 | + | let usdnAmt = $t040824126._1 | |
166 | + | let leftover = $t040824126._2 | |
167 | 167 | [Burn(xtn, leftover), convertXtnToL2Internal(i.caller, usdnAmt, stake)] | |
168 | 168 | } | |
169 | 169 | else throw("Strict value is not equal to itself.") | |
170 | 170 | } | |
171 | 171 | else throw("Strict value is not equal to itself.") | |
172 | 172 | } | |
173 | 173 | ||
174 | 174 | ||
175 | 175 | ||
176 | 176 | @Callable(i) | |
177 | 177 | 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)] | |
178 | 178 | ||
179 | 179 | ||
180 | 180 | @Verifier(tx) | |
181 | 181 | func verify () = { | |
182 | 182 | let BASE = 1000 | |
183 | 183 | let quorumRatio = valueOrErrorMessage(getInteger(configAddress, "proposal_quorum_ratio"), "proposalQuorumRatio is not defined") | |
184 | 184 | let passedRatio = valueOrErrorMessage(getInteger(configAddress, "proposal_passed_ratio"), "proposalThresholdRatio is not defined") | |
185 | 185 | let gViresContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "dividends_contract"), "no dividends_contract")), "invalid dividends_contract") | |
186 | 186 | let votingContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "voting_contract"), "no voting_contract")), "invalid voting_contract") | |
187 | 187 | let id = toBase58String(tx.id) | |
188 | 188 | let votesYes = valueOrElse(getInteger(votingContract, ("proposal_yes_" + id)), 0) | |
189 | 189 | let votesNo = valueOrElse(getInteger(votingContract, ("proposal_no_" + id)), 0) | |
190 | 190 | let proposalHeight = valueOrErrorMessage(getInteger(votingContract, ("proposal_height_" + id)), "proposal not registered") | |
191 | 191 | let applyStart = valueOrElse(getInteger(votingContract, ("proposal_applystart_" + id)), 0) | |
192 | 192 | let applyEnd = valueOrElse(getInteger(votingContract, ("proposal_applyend_" + id)), 0) | |
193 | 193 | let totalGVires = valueOrElse(getInteger(votingContract, ("proposal_gvires_" + id)), 0) | |
194 | 194 | let enabled = valueOrElse(getBoolean(configAddress, "op_governance_apply_tx_paused"), false) | |
195 | 195 | let voteYes = votesYes | |
196 | 196 | let voteNo = votesNo | |
197 | 197 | let totalVotes = (voteYes + voteNo) | |
198 | 198 | let hasQuorum = (((totalVotes * BASE) / totalGVires) >= quorumRatio) | |
199 | 199 | let hasPassed = (((voteYes * BASE) / totalVotes) >= passedRatio) | |
200 | 200 | let tooEarly = (applyStart >= HEIGHT) | |
201 | 201 | let tooLate = (HEIGHT >= applyEnd) | |
202 | 202 | let timeDebug = ((((((("proposalHeight = " + toString(proposalHeight)) + ", applyStart = ") + toString(applyStart)) + ", applyEnd = ") + toString(applyEnd)) + ", HEIGHT = ") + toString(HEIGHT)) | |
203 | 203 | let byVoting = if (!(enabled)) | |
204 | 204 | then throw("tx application throw governance not enabled") | |
205 | 205 | else if (tooEarly) | |
206 | 206 | then throw(("proposal can't be executed as it's too early: " + timeDebug)) | |
207 | 207 | else if (tooLate) | |
208 | 208 | then throw(("proposal can't be executed as it's too late:" + timeDebug)) | |
209 | 209 | else if (!(hasQuorum)) | |
210 | 210 | then throw((((((("no quorum: " + "totalVotes: ") + toString(totalVotes)) + ", totalGVires: ") + toString(totalGVires)) + ", quorumRatio: ") + toString(quorumRatio))) | |
211 | 211 | else if (!(hasPassed)) | |
212 | 212 | then throw((((((("no threshold achieved: " + "voteYes: ") + toString(voteYes)) + ", voteNo: ") + toString(voteNo)) + ", passedRatio: ") + toString(passedRatio))) | |
213 | 213 | else true | |
214 | 214 | if (sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)) | |
215 | 215 | then true | |
216 | 216 | else byVoting | |
217 | 217 | } | |
218 | 218 |
github/deemru/w8io/6500d08 42.67 ms ◑