tx · C2yx39jrJFeueHMVz7hmCqXDzcgmNLidtPatGDCTZeg4

3PJqzSu5ShM2qzkSkxDr2oc47TBH8zfBaUq:  -0.01100000 Waves

2023.10.06 14:37 [3852546] smart account 3PJqzSu5ShM2qzkSkxDr2oc47TBH8zfBaUq > SELF 0.00000000 Waves

{ "type": 13, "id": "C2yx39jrJFeueHMVz7hmCqXDzcgmNLidtPatGDCTZeg4", "fee": 1100000, "feeAssetId": null, "timestamp": 1696592240499, "version": 1, "sender": "3PJqzSu5ShM2qzkSkxDr2oc47TBH8zfBaUq", "senderPublicKey": "3JbL1AeoE8AP9xDHYyrbLCFxXtzyx5EPexG4H3CMdBMS", "proofs": [ "4M9ryweRWdFZbqrVKreXpuHEoMCSsk27Nt7dWPzL7U4Udn6sh2kFbg2eNrFSsnbbpqLXboFYExHYXWxd5pxEeuzU" ], "script": "base64:BgIhCAISBQoDCAEEEgQKAgEEEgQKAgEEEgoKCAgICAgICAgIGwASY29uZmlnQWRkcmVzc1N0b3JlAg1jb25maWdBZGRyZXNzAA1jb25maWdBZGRyZXNzCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMFEmNvbmZpZ0FkZHJlc3NTdG9yZQIZcmVzZXJ2ZTogbm8gY29uZmlnQWRkcmVzcwIWaW52YWxpZCBjb25maWcgYWRkcmVzcwAGSEVJR0hUBQZoZWlnaHQBCW9wQWxsb3dlZAICb3AHcmVzZXJ2ZQQHJG1hdGNoMAkA/AcEBQ1jb25maWdBZGRyZXNzAglvcEFsbG93ZWQJAMwIAgUHcmVzZXJ2ZQkAzAgCBQJvcAUDbmlsBQNuaWwDCQABAgUHJG1hdGNoMAIHQm9vbGVhbgQBYgUHJG1hdGNoMAMFAWIGCQACAQILbm90IGFsbG93ZWQJAAIBAiFvcEFsbG93ZWQ6IHVuZXhwZWN0ZWQgcmVzdWx0IHR5cGUBEHdyaXRlQ29uc3RTdHJpbmcCA2tleQV2YWx1ZQMJAQEhAQkBCWlzRGVmaW5lZAEJAJ0IAgUEdGhpcwUDa2V5CQELU3RyaW5nRW50cnkCBQNrZXkFBXZhbHVlCQACAQkArAICAhVhbHJlYWR5IGluaXRpYWxpemVkOiAFA2tleQEKZ2V0QWRkcmVzcwEDa2V5CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCiCAEFA2tleQkArAICBQNrZXkCCiBub3QgZm91bmQJAKwCAgUDa2V5AhAgaW52YWxpZCBhZGRyZXNzAQhnZXRBc3NldAEDa2V5CQDZBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAoggBBQNrZXkJAKwCAgUDa2V5Agogbm90IGZvdW5kAAdsMlN0b3JlAgJMMgAIeHRuU3RvcmUCA1hUTgAPbDJDb250cmFjdFN0b3JlAgtMMl9jb250cmFjdAANbDJTdGFrZXJTdG9yZQISTDJfc3Rha2VyX2NvbnRyYWN0AA12ZXN0bkFsbFN0b3JlAgl2ZXN0bl9hbGwAD3Zlc3RuV2hhbGVTdG9yZQIFdmVzdG4ACm1haW40U3RvcmUCBW1haW40AAJsMgkBCGdldEFzc2V0AQUHbDJTdG9yZQADeHRuCQEIZ2V0QXNzZXQBBQh4dG5TdG9yZQAKbDJDb250cmFjdAkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTgpAQUPbDJDb250cmFjdFN0b3JlAAhsMnN0YWtlcgkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTgpAQUNbDJTdGFrZXJTdG9yZQAFbWFpbjQJARFAZXh0ck5hdGl2ZSgxMDYyKQEJARFAZXh0ck5hdGl2ZSgxMDU4KQEFCm1haW40U3RvcmUACXByb3RlY3RlZAkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTMpAgUNY29uZmlnQWRkcmVzcwIRcHJvdGVjdGVkX3Jlc2VydmUAA2FjYwkBEUBleHRyTmF0aXZlKDEwNTMpAgUFbWFpbjQCA2FjYwAIdmVzdG5BbGwJAQpnZXRBZGRyZXNzAQUNdmVzdG5BbGxTdG9yZQAKdmVzdG5XaGFsZQkBCmdldEFkZHJlc3MBBQ92ZXN0bldoYWxlU3RvcmUAC3Jlc2VydmVzU3RyCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUNY29uZmlnQWRkcmVzcwIQcHJpbWFyeV9yZXNlcnZlcwIWbm8gcmVzZXJ2ZXMgcmVnaXN0ZXJlZAEDdmxSAQFyAwkBCGNvbnRhaW5zAgULcmVzZXJ2ZXNTdHIFAXIJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBBQFyAg1tYWluOiBiYWQgcnNyCQACAQkArAICAgx1bmtub3duIHJzcjoFAXIBFmNvbnZlcnRYdG5Ub0wySW50ZXJuYWwDB2FkZHJlc3MJeHRuQW1vdW50BXN0YWtlBAFjCQD8BwQFCmwyQ29udHJhY3QCBHN3YXAJAMwIAgcFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUDeHRuBQl4dG5BbW91bnQFA25pbAMJAAACBQFjBQFjBAhsMkFtb3VudAkAaAIFCXh0bkFtb3VudABkAwUFc3Rha2UEAXMJAPwHBAUIbDJzdGFrZXICCHN0YWtlRm9yCQDMCAIJAKUIAQUHYWRkcmVzcwUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQJsMgUIbDJBbW91bnQFA25pbAMJAAACBQFzBQFzBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUHYWRkcmVzcwUIbDJBbW91bnQFAmwyBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BDWJlZm9yZVZlc3RpbmcBA2FtdAQLdmVzdGluZ1RvTDIAmOYFBARiYXNlAKCNBgQGYmVmb3JlCQBrAwUDYW10BQt2ZXN0aW5nVG9MMgUEYmFzZQQIbGVmdG92ZXIJAGUCBQNhbXQFBmJlZm9yZQkAlAoCBQZiZWZvcmUFCGxlZnRvdmVyBAFpAQx3aXRoZHJhd1RvTDIDB3Jlc2VydmUGYW1vdW50BXN0YWtlBAZjaGVja3MJAQlvcEFsbG93ZWQCAgx3aXRoZHJhd1RvTDIFB3Jlc2VydmUDCQAAAgUGY2hlY2tzBQZjaGVja3MEAXIJAQN2bFIBBQdyZXNlcnZlAwkAAAIFAXIFAXIDCQBnAgAABQZhbW91bnQJAAIBAg5pbnZhbGlkIGFtb3VudAQGdmVzaW5nCQD8BwQFBW1haW40Ag9zdGFydFZlc3RpbmdGb3IJAMwIAgkApQgBCAUBaQZjYWxsZXIJAMwIAgUHcmVzZXJ2ZQkAzAgCBQZhbW91bnQFA25pbAUDbmlsAwkAAAIFBnZlc2luZwUGdmVzaW5nBAJ3ZAkA/AcEBQh2ZXN0bkFsbAIacGFydGlhbFdpdGhkcmF3VmVzdGVkRm9yVG8JAMwIAgkApQgBCAUBaQZjYWxsZXIJAMwIAgkApQgBBQR0aGlzCQDMCAIFBmFtb3VudAUDbmlsBQNuaWwDCQAAAgUCd2QFAndkCQEWY29udmVydFh0blRvTDJJbnRlcm5hbAMIBQFpBmNhbGxlcgUGYW1vdW50BQVzdGFrZQkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpARl3aXRoZHJhd1Zlc3RlZFJlZ3VsYXJUb0wyAgNhbXQFc3Rha2UEBmNoZWNrcwkBCW9wQWxsb3dlZAICDHdpdGhkcmF3VG9MMgIOdmVzdGVkX3JlZ3VsYXIDCQAAAgUGY2hlY2tzBQZjaGVja3MDCQBnAgAABQNhbXQJAAIBAg5pbnZhbGlkIGFtb3VudAQCd2QJAPwHBAUIdmVzdG5BbGwCGnBhcnRpYWxXaXRoZHJhd1Zlc3RlZEZvclRvCQDMCAIJAKUIAQgFAWkGY2FsbGVyCQDMCAIJAKUIAQUEdGhpcwkAzAgCBQNhbXQFA25pbAUDbmlsAwkAAAIFAndkBQJ3ZAQLJHQwMzU0MDM1ODQJAQ1iZWZvcmVWZXN0aW5nAQUDYW10BAd1c2RuQW10CAULJHQwMzU0MDM1ODQCXzEECGxlZnRvdmVyCAULJHQwMzU0MDM1ODQCXzIJAMwIAgkBBEJ1cm4CBQN4dG4FCGxlZnRvdmVyCQEWY29udmVydFh0blRvTDJJbnRlcm5hbAMIBQFpBmNhbGxlcgUHdXNkbkFtdAUFc3Rha2UJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEXd2l0aGRyYXdWZXN0ZWRXaGFsZVRvTDICA2FtdAVzdGFrZQQGY2hlY2tzCQEJb3BBbGxvd2VkAgIMd2l0aGRyYXdUb0wyAgx2ZXN0ZWRfd2hhbGUDCQAAAgUGY2hlY2tzBQZjaGVja3MDCQBnAgAABQNhbXQJAAIBAg5pbnZhbGlkIGFtb3VudAQCd2QJAPwHBAUKdmVzdG5XaGFsZQIZcGFydGlhbFdpdGhkcmF3VmVzdGVkVG9MMgkAzAgCCQClCAEIBQFpBmNhbGxlcgkAzAgCCQClCAEFBHRoaXMJAMwIAgUDYW10BQNuaWwFA25pbAMJAAACBQJ3ZAUCd2QECyR0MDM5NzM0MDE3CQENYmVmb3JlVmVzdGluZwEFA2FtdAQHdXNkbkFtdAgFCyR0MDM5NzM0MDE3Al8xBAhsZWZ0b3ZlcggFCyR0MDM5NzM0MDE3Al8yCQDMCAIJAQRCdXJuAgUDeHRuBQhsZWZ0b3ZlcgkBFmNvbnZlcnRYdG5Ub0wySW50ZXJuYWwDCAUBaQZjYWxsZXIFB3VzZG5BbXQFBXN0YWtlCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBCmluaXRpYWxpemUIDWNvbmZpZ0FkZHJlc3MCbDIDeHRuCWwyQ290cmFjdAhsMlN0YWtlcgh2ZXN0bkFsbAp2ZXN0bldoYWxlBW1haW40CQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgUSY29uZmlnQWRkcmVzc1N0b3JlBQ1jb25maWdBZGRyZXNzCQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgUHbDJTdG9yZQUCbDIJAMwIAgkBEHdyaXRlQ29uc3RTdHJpbmcCBQh4dG5TdG9yZQUDeHRuCQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgUPbDJDb250cmFjdFN0b3JlBQlsMkNvdHJhY3QJAMwIAgkBEHdyaXRlQ29uc3RTdHJpbmcCBQ1sMlN0YWtlclN0b3JlBQhsMlN0YWtlcgkAzAgCCQEQd3JpdGVDb25zdFN0cmluZwIFDXZlc3RuQWxsU3RvcmUFCHZlc3RuQWxsCQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgUPdmVzdG5XaGFsZVN0b3JlBQp2ZXN0bldoYWxlCQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgUKbWFpbjRTdG9yZQUFbWFpbjQFA25pbAECdHgBBnZlcmlmeQAEBEJBU0UA6AcEC3F1b3J1bVJhdGlvCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUNY29uZmlnQWRkcmVzcwIVcHJvcG9zYWxfcXVvcnVtX3JhdGlvAiJwcm9wb3NhbFF1b3J1bVJhdGlvIGlzIG5vdCBkZWZpbmVkBAtwYXNzZWRSYXRpbwkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFDWNvbmZpZ0FkZHJlc3MCFXByb3Bvc2FsX3Bhc3NlZF9yYXRpbwIlcHJvcG9zYWxUaHJlc2hvbGRSYXRpbyBpcyBub3QgZGVmaW5lZAQOZ1ZpcmVzQ29udHJhY3QJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUNY29uZmlnQWRkcmVzcwISZGl2aWRlbmRzX2NvbnRyYWN0AhVubyBkaXZpZGVuZHNfY29udHJhY3QCGmludmFsaWQgZGl2aWRlbmRzX2NvbnRyYWN0BA52b3RpbmdDb250cmFjdAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQ1jb25maWdBZGRyZXNzAg92b3RpbmdfY29udHJhY3QCEm5vIHZvdGluZ19jb250cmFjdAIXaW52YWxpZCB2b3RpbmdfY29udHJhY3QEAmlkCQDYBAEIBQJ0eAJpZAQIdm90ZXNZZXMJAQt2YWx1ZU9yRWxzZQIJAJoIAgUOdm90aW5nQ29udHJhY3QJAKwCAgINcHJvcG9zYWxfeWVzXwUCaWQAAAQHdm90ZXNObwkBC3ZhbHVlT3JFbHNlAgkAmggCBQ52b3RpbmdDb250cmFjdAkArAICAgxwcm9wb3NhbF9ub18FAmlkAAAEDnByb3Bvc2FsSGVpZ2h0CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUOdm90aW5nQ29udHJhY3QJAKwCAgIQcHJvcG9zYWxfaGVpZ2h0XwUCaWQCF3Byb3Bvc2FsIG5vdCByZWdpc3RlcmVkBAphcHBseVN0YXJ0CQELdmFsdWVPckVsc2UCCQCaCAIFDnZvdGluZ0NvbnRyYWN0CQCsAgICFHByb3Bvc2FsX2FwcGx5c3RhcnRfBQJpZAAABAhhcHBseUVuZAkBC3ZhbHVlT3JFbHNlAgkAmggCBQ52b3RpbmdDb250cmFjdAkArAICAhJwcm9wb3NhbF9hcHBseWVuZF8FAmlkAAAEC3RvdGFsR1ZpcmVzCQELdmFsdWVPckVsc2UCCQCaCAIFDnZvdGluZ0NvbnRyYWN0CQCsAgICEHByb3Bvc2FsX2d2aXJlc18FAmlkAAAEB2VuYWJsZWQJAQt2YWx1ZU9yRWxzZQIJAJsIAgUNY29uZmlnQWRkcmVzcwIdb3BfZ292ZXJuYW5jZV9hcHBseV90eF9wYXVzZWQHBAd2b3RlWWVzBQh2b3Rlc1llcwQGdm90ZU5vBQd2b3Rlc05vBAp0b3RhbFZvdGVzCQBkAgUHdm90ZVllcwUGdm90ZU5vBAloYXNRdW9ydW0JAGcCCQBpAgkAaAIFCnRvdGFsVm90ZXMFBEJBU0UFC3RvdGFsR1ZpcmVzBQtxdW9ydW1SYXRpbwQJaGFzUGFzc2VkCQBnAgkAaQIJAGgCBQd2b3RlWWVzBQRCQVNFBQp0b3RhbFZvdGVzBQtwYXNzZWRSYXRpbwQIdG9vRWFybHkJAGcCBQphcHBseVN0YXJ0BQZIRUlHSFQEB3Rvb0xhdGUJAGcCBQZIRUlHSFQFCGFwcGx5RW5kBAl0aW1lRGVidWcJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgIRcHJvcG9zYWxIZWlnaHQgPSAJAKQDAQUOcHJvcG9zYWxIZWlnaHQCDywgYXBwbHlTdGFydCA9IAkApAMBBQphcHBseVN0YXJ0Ag0sIGFwcGx5RW5kID0gCQCkAwEFCGFwcGx5RW5kAgssIEhFSUdIVCA9IAkApAMBBQZIRUlHSFQECGJ5Vm90aW5nAwkBASEBBQdlbmFibGVkCQACAQIrdHggYXBwbGljYXRpb24gdGhyb3cgZ292ZXJuYW5jZSBub3QgZW5hYmxlZAMFCHRvb0Vhcmx5CQACAQkArAICAi5wcm9wb3NhbCBjYW4ndCBiZSBleGVjdXRlZCBhcyBpdCdzIHRvbyBlYXJseTogBQl0aW1lRGVidWcDBQd0b29MYXRlCQACAQkArAICAixwcm9wb3NhbCBjYW4ndCBiZSBleGVjdXRlZCBhcyBpdCdzIHRvbyBsYXRlOgUJdGltZURlYnVnAwkBASEBBQloYXNRdW9ydW0JAAIBCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAgtubyBxdW9ydW06IAIMdG90YWxWb3RlczogCQCkAwEFCnRvdGFsVm90ZXMCDywgdG90YWxHVmlyZXM6IAkApAMBBQt0b3RhbEdWaXJlcwIPLCBxdW9ydW1SYXRpbzogCQCkAwEFC3F1b3J1bVJhdGlvAwkBASEBBQloYXNQYXNzZWQJAAIBCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAhdubyB0aHJlc2hvbGQgYWNoaWV2ZWQ6IAIJdm90ZVllczogCQCkAwEFB3ZvdGVZZXMCCiwgdm90ZU5vOiAJAKQDAQUGdm90ZU5vAg8sIHBhc3NlZFJhdGlvOiAJAKQDAQULcGFzc2VkUmF0aW8GAwkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAgFAnR4D3NlbmRlclB1YmxpY0tleQYFCGJ5Vm90aW5njQsSRw==", "chainId": 87, "height": 3852546, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: Ab9S5YAzonrnGJaJADDnqVgJyeAfSapBypTrMrGFad8D Next: 8HVVuWCeBTL6g4yTACLEWhvZ941C1MuTDVETjtcUgdCK Diff:
OldNewDifferences
134134 let $t035403584 = beforeVesting(amt)
135135 let usdnAmt = $t035403584._1
136136 let leftover = $t035403584._2
137- let p = invoke(protected, "supplyFor", [acc], [AttachedPayment(xtn, leftover)])
138- if ((p == p))
139- then convertXtnToL2Internal(i.caller, usdnAmt, stake)
140- else throw("Strict value is not equal to itself.")
137+[Burn(xtn, leftover), convertXtnToL2Internal(i.caller, usdnAmt, stake)]
141138 }
142139 else throw("Strict value is not equal to itself.")
143140 }
156153 let wd = invoke(vestnWhale, "partialWithdrawVestedToL2", [toString(i.caller), toString(this), amt], nil)
157154 if ((wd == wd))
158155 then {
159- let $t040354079 = beforeVesting(amt)
160- let usdnAmt = $t040354079._1
161- let leftover = $t040354079._2
162- let p = invoke(protected, "supplyFor", [acc], [AttachedPayment(xtn, leftover)])
163- if ((p == p))
164- then convertXtnToL2Internal(i.caller, usdnAmt, stake)
165- else throw("Strict value is not equal to itself.")
156+ let $t039734017 = beforeVesting(amt)
157+ let usdnAmt = $t039734017._1
158+ let leftover = $t039734017._2
159+[Burn(xtn, leftover), convertXtnToL2Internal(i.caller, usdnAmt, stake)]
166160 }
167161 else throw("Strict value is not equal to itself.")
168162 }
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 @Callable(i)
9898 func withdrawToL2 (reserve,amount,stake) = {
9999 let checks = opAllowed("withdrawToL2", reserve)
100100 if ((checks == checks))
101101 then {
102102 let r = vlR(reserve)
103103 if ((r == r))
104104 then if ((0 >= amount))
105105 then throw("invalid amount")
106106 else {
107107 let vesing = invoke(main4, "startVestingFor", [toString(i.caller), reserve, amount], nil)
108108 if ((vesing == vesing))
109109 then {
110110 let wd = invoke(vestnAll, "partialWithdrawVestedForTo", [toString(i.caller), toString(this), amount], nil)
111111 if ((wd == wd))
112112 then convertXtnToL2Internal(i.caller, amount, stake)
113113 else throw("Strict value is not equal to itself.")
114114 }
115115 else throw("Strict value is not equal to itself.")
116116 }
117117 else throw("Strict value is not equal to itself.")
118118 }
119119 else throw("Strict value is not equal to itself.")
120120 }
121121
122122
123123
124124 @Callable(i)
125125 func withdrawVestedRegularToL2 (amt,stake) = {
126126 let checks = opAllowed("withdrawToL2", "vested_regular")
127127 if ((checks == checks))
128128 then if ((0 >= amt))
129129 then throw("invalid amount")
130130 else {
131131 let wd = invoke(vestnAll, "partialWithdrawVestedForTo", [toString(i.caller), toString(this), amt], nil)
132132 if ((wd == wd))
133133 then {
134134 let $t035403584 = beforeVesting(amt)
135135 let usdnAmt = $t035403584._1
136136 let leftover = $t035403584._2
137- let p = invoke(protected, "supplyFor", [acc], [AttachedPayment(xtn, leftover)])
138- if ((p == p))
139- then convertXtnToL2Internal(i.caller, usdnAmt, stake)
140- else throw("Strict value is not equal to itself.")
137+[Burn(xtn, leftover), convertXtnToL2Internal(i.caller, usdnAmt, stake)]
141138 }
142139 else throw("Strict value is not equal to itself.")
143140 }
144141 else throw("Strict value is not equal to itself.")
145142 }
146143
147144
148145
149146 @Callable(i)
150147 func withdrawVestedWhaleToL2 (amt,stake) = {
151148 let checks = opAllowed("withdrawToL2", "vested_whale")
152149 if ((checks == checks))
153150 then if ((0 >= amt))
154151 then throw("invalid amount")
155152 else {
156153 let wd = invoke(vestnWhale, "partialWithdrawVestedToL2", [toString(i.caller), toString(this), amt], nil)
157154 if ((wd == wd))
158155 then {
159- let $t040354079 = beforeVesting(amt)
160- let usdnAmt = $t040354079._1
161- let leftover = $t040354079._2
162- let p = invoke(protected, "supplyFor", [acc], [AttachedPayment(xtn, leftover)])
163- if ((p == p))
164- then convertXtnToL2Internal(i.caller, usdnAmt, stake)
165- else throw("Strict value is not equal to itself.")
156+ let $t039734017 = beforeVesting(amt)
157+ let usdnAmt = $t039734017._1
158+ let leftover = $t039734017._2
159+[Burn(xtn, leftover), convertXtnToL2Internal(i.caller, usdnAmt, stake)]
166160 }
167161 else throw("Strict value is not equal to itself.")
168162 }
169163 else throw("Strict value is not equal to itself.")
170164 }
171165
172166
173167
174168 @Callable(i)
175169 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)]
176170
177171
178172 @Verifier(tx)
179173 func verify () = {
180174 let BASE = 1000
181175 let quorumRatio = valueOrErrorMessage(getInteger(configAddress, "proposal_quorum_ratio"), "proposalQuorumRatio is not defined")
182176 let passedRatio = valueOrErrorMessage(getInteger(configAddress, "proposal_passed_ratio"), "proposalThresholdRatio is not defined")
183177 let gViresContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "dividends_contract"), "no dividends_contract")), "invalid dividends_contract")
184178 let votingContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "voting_contract"), "no voting_contract")), "invalid voting_contract")
185179 let id = toBase58String(tx.id)
186180 let votesYes = valueOrElse(getInteger(votingContract, ("proposal_yes_" + id)), 0)
187181 let votesNo = valueOrElse(getInteger(votingContract, ("proposal_no_" + id)), 0)
188182 let proposalHeight = valueOrErrorMessage(getInteger(votingContract, ("proposal_height_" + id)), "proposal not registered")
189183 let applyStart = valueOrElse(getInteger(votingContract, ("proposal_applystart_" + id)), 0)
190184 let applyEnd = valueOrElse(getInteger(votingContract, ("proposal_applyend_" + id)), 0)
191185 let totalGVires = valueOrElse(getInteger(votingContract, ("proposal_gvires_" + id)), 0)
192186 let enabled = valueOrElse(getBoolean(configAddress, "op_governance_apply_tx_paused"), false)
193187 let voteYes = votesYes
194188 let voteNo = votesNo
195189 let totalVotes = (voteYes + voteNo)
196190 let hasQuorum = (((totalVotes * BASE) / totalGVires) >= quorumRatio)
197191 let hasPassed = (((voteYes * BASE) / totalVotes) >= passedRatio)
198192 let tooEarly = (applyStart >= HEIGHT)
199193 let tooLate = (HEIGHT >= applyEnd)
200194 let timeDebug = ((((((("proposalHeight = " + toString(proposalHeight)) + ", applyStart = ") + toString(applyStart)) + ", applyEnd = ") + toString(applyEnd)) + ", HEIGHT = ") + toString(HEIGHT))
201195 let byVoting = if (!(enabled))
202196 then throw("tx application throw governance not enabled")
203197 else if (tooEarly)
204198 then throw(("proposal can't be executed as it's too early: " + timeDebug))
205199 else if (tooLate)
206200 then throw(("proposal can't be executed as it's too late:" + timeDebug))
207201 else if (!(hasQuorum))
208202 then throw((((((("no quorum: " + "totalVotes: ") + toString(totalVotes)) + ", totalGVires: ") + toString(totalGVires)) + ", quorumRatio: ") + toString(quorumRatio)))
209203 else if (!(hasPassed))
210204 then throw((((((("no threshold achieved: " + "voteYes: ") + toString(voteYes)) + ", voteNo: ") + toString(voteNo)) + ", passedRatio: ") + toString(passedRatio)))
211205 else true
212206 if (sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey))
213207 then true
214208 else byVoting
215209 }
216210

github/deemru/w8io/3ef1775 
39.00 ms