tx · 5SLH9A3UrhELYYwyeDBcdUD8NVrdfkigin3eYGMgDf2F

3PCbvPVQfSvVu88ip8Fm5YjwJhjEYk1Txhk:  -0.02000000 Waves

2024.01.26 13:59 [4014166] smart account 3PCbvPVQfSvVu88ip8Fm5YjwJhjEYk1Txhk > SELF 0.00000000 Waves

{ "type": 13, "id": "5SLH9A3UrhELYYwyeDBcdUD8NVrdfkigin3eYGMgDf2F", "fee": 2000000, "feeAssetId": null, "timestamp": 1706266824576, "version": 1, "sender": "3PCbvPVQfSvVu88ip8Fm5YjwJhjEYk1Txhk", "senderPublicKey": "FwXAX9xcWiwbCejtdF8q1Nz8NpJqaVxXKnKK6JoR24pZ", "proofs": [ "3fgLXYN35J8SPpYcu3FSaKbkXyfKhfkKB2qNfp8Xm4YicZCtfhu5Bqr97kUE5SSd7idfRZVamReMCebhwbADFWg9" ], "script": "base64:BgI/CAISCwoJCAgICAgICAEIEgUKAwgIARIECgIIARIAEgQKAgQEEgQKAgQEEgUKAwEBBBIECgIEBBIECgIBARIALQALZmFjdG9yc0Jhc2UA6AcBEHdyaXRlQ29uc3RTdHJpbmcCA2tleQV2YWx1ZQMJAQEhAQkBCWlzRGVmaW5lZAEJAJ0IAgUEdGhpcwUDa2V5CQELU3RyaW5nRW50cnkCBQNrZXkFBXZhbHVlCQACAQkArAICAhVhbHJlYWR5IGluaXRpYWxpemVkOiAFA2tleQENd3JpdGVDb25zdEludAIDa2V5BXZhbHVlAwkBASEBCQEJaXNEZWZpbmVkAQkAmggCBQR0aGlzBQNrZXkJAQxJbnRlZ2VyRW50cnkCBQNrZXkFBXZhbHVlCQACAQkArAICAhVhbHJlYWR5IGluaXRpYWxpemVkOiAFA2tleQEId3JpdGVJbnQCA2tleQV2YWx1ZQMJAGYCAAAFBXZhbHVlCQACAQkArAICCQCsAgIJAKwCAgIXd3JpdGluZyBuZWdhdGl2ZSB2YWx1ZSAJAKQDAQUFdmFsdWUCCSBmb3Iga2V5IAUDa2V5CQEMSW50ZWdlckVudHJ5AgUDa2V5BQV2YWx1ZQEIYXNTdHJpbmcBBXZhbHVlBAckbWF0Y2gwBQV2YWx1ZQMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAXMFByRtYXRjaDAFAXMJAAIBAhx3cm9uZyB0eXBlLCBleHBlY3RlZDogU3RyaW5nAQVhc0ludAEFdmFsdWUEByRtYXRjaDAFBXZhbHVlAwkAAQIFByRtYXRjaDACA0ludAQDaW50BQckbWF0Y2gwBQNpbnQJAAIBAgRzbToxAQZhc0ludDIBBXZhbHVlBAckbWF0Y2gwBQV2YWx1ZQMJAAECBQckbWF0Y2gwAgooSW50LCBJbnQpBAF4BQckbWF0Y2gwBQF4BAF0BQckbWF0Y2gwCQACAQIad3JvbmcgdHlwZSwgZXhwZWN0ZWQ6IEludDIBEWFzVXNlckJhbGFuY2VEYXRhAQV2YWx1ZQQHJG1hdGNoMAUFdmFsdWUDCQABAgUHJG1hdGNoMAIiKEludCwgSW50LCBJbnQsIEludCwgSW50LCBCb29sZWFuKQQBeAUHJG1hdGNoMAUBeAQBdAUHJG1hdGNoMAkAAgECATMBC3VzZXJCYWxhbmNlAgNyc3IEdXNlcgkBEWFzVXNlckJhbGFuY2VEYXRhAQkA/AcEBQNyc3ICC3VzZXJCYWxhbmNlCQDMCAIFBHVzZXIFA25pbAUDbmlsAQd0aHJvd0lmAgljb25kaXRpb24FZXJyb3IDBQljb25kaXRpb24JAAIBBQVlcnJvcgYBCGNoYW5nZUJ5AgNrZXkFdmFsdWUJAQh3cml0ZUludAIFA2tleQkAZAIJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwUDa2V5AAAFBXZhbHVlAAtjb25maWdTdG9yZQIGY29uZmlnAA1jb25maWdBZGRyZXNzCQERQGV4dHJOYXRpdmUoMTA2MikBCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzBQtjb25maWdTdG9yZQAVdmlyZXNWZXN0ZWRVc2RuTHBEYXBwCQERQGV4dHJOYXRpdmUoMTA2MikBAiMzUEpGdThNbVZhMnJTVkdNNDh3ZExtNGpoTHpuRWd1NlhTZQASbWF5YmVPcmFjbGVBZGRyZXNzBAckbWF0Y2gwCQCdCAIFDWNvbmZpZ0FkZHJlc3MCDm9yYWNsZV9hZGRyZXNzAwkAAQIFByRtYXRjaDACBlN0cmluZwQBcwUHJG1hdGNoMAkApggBBQFzBQR1bml0AAZIRUlHSFQFBmhlaWdodAACdmQJARFAZXh0ck5hdGl2ZSgxMDYyKQEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQ1jb25maWdBZGRyZXNzAhF2aXJlc19kaXN0cmlidXRvcgIVYmFkIHZpcmVzIGRpc3RyaWJ1dG9yABBwcm90ZWN0ZWRSZXNlcnZlCQERQGV4dHJOYXRpdmUoMTA2MikBCQERQGV4dHJOYXRpdmUoMTA1MykCBQ1jb25maWdBZGRyZXNzAhFwcm90ZWN0ZWRfcmVzZXJ2ZQAFbWFpbjEJARFAZXh0ck5hdGl2ZSgxMDYyKQEJARFAZXh0ck5hdGl2ZSgxMDUzKQIFBHRoaXMCBW1haW4xAAt1c2R0UmVzZXJ2ZQkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwILdXNkdFJlc2VydmUAC3VzZGNSZXNlcnZlCQERQGV4dHJOYXRpdmUoMTA2MikBCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzAgt1c2RjUmVzZXJ2ZQADYWNjCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzAgNhY2MADnVzZG5WZXN0aW5nQWxsCQERQGV4dHJOYXRpdmUoMTA2MikBCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzAg51c2RuVmVzdGluZ0FsbAALdXNkblZlc3RpbmcJARFAZXh0ck5hdGl2ZSgxMDYyKQEJARFAZXh0ck5hdGl2ZSgxMDUzKQIFBHRoaXMCC3VzZG5WZXN0aW5nAAt1c2RuQXNzZXRJZAkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwILdXNkbkFzc2V0SWQACXVzZG5Cb251cwkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwIFYm9udXMBCm1vdmVTdHJlYW0FA3JzcgZhY3Rpb24EZnJvbQZzdHJpbmcDYW10CQD8BwQFAnZkAgRtb3ZlCQDMCAIFA3JzcgkAzAgCBQZhY3Rpb24JAMwIAgUEZnJvbQkAzAgCBQZzdHJpbmcJAMwIAgUDYW10BQNuaWwFA25pbAEJb3BBbGxvd2VkAgJvcAphc3NldElkU3RyBAckbWF0Y2gwCQD8BwQFDWNvbmZpZ0FkZHJlc3MCCW9wQWxsb3dlZAkAzAgCBQphc3NldElkU3RyCQDMCAIFAm9wBQNuaWwFA25pbAMJAAECBQckbWF0Y2gwAgdCb29sZWFuBAFiBQckbWF0Y2gwAwUBYgYJAAIBAgtub3QgYWxsb3dlZAkAAgECIW9wQWxsb3dlZDogdW5leHBlY3RlZCByZXN1bHQgdHlwZQEIbWFpbk9ubHkBAWkDCQEIY29udGFpbnMCCQERQGV4dHJOYXRpdmUoMTA1MykCBQ1jb25maWdBZGRyZXNzAgRtYWluCQClCAEIBQFpBmNhbGxlcgYJAAIBAhBvbmx5IG1haW4gY2FuIGRvAQphZHZpc2VVc2VyAQNhY2MECWRhdGFXaGFsZQkBCGFzU3RyaW5nAQkA/AcEBQt1c2RuVmVzdGluZwIHYWR2aXNlVQkAzAgCBQNhY2MFA25pbAUDbmlsAwkAAAIFCWRhdGFXaGFsZQUJZGF0YVdoYWxlBAdkYXRhQWxsCQEIYXNTdHJpbmcBCQD8BwQFDnVzZG5WZXN0aW5nQWxsAgdhZHZpc2VVCQDMCAIFA2FjYwUDbmlsBQNuaWwDCQAAAgUHZGF0YUFsbAUHZGF0YUFsbAkArAICCQCsAgIFCWRhdGFXaGFsZQIDIHwgBQdkYXRhQWxsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAAtzdXJmQWRkcmVzcwkBEUBleHRyTmF0aXZlKDEwNjIpAQIjM1BHMnZNaEs1Q1Bxc0NEb2R2TEd6UTg0UWtvSFhDSjNvTlAAEHN1cmZTdGFrZUFkZHJlc3MJARFAZXh0ck5hdGl2ZSgxMDYyKQECIzNQQmlvdEZwcWpSTWtrZUZCY2NuUU5VWFVvcHk3S0ZlejVDAAtzdXJmQXNzZXRJZAkA2QQBAixBdDhENk5GRnBoZUNidktWbmpWb2VMTDg0RW84TlpuNm92TWFueGZMYUZXTAAGb3JhY2xlCQEHQWRkcmVzcwEBGgFXw4nuidFTWhQUZTvI/d/0hIb99hEAq5RYAAh4dG5QcmljZQkBEUBleHRyTmF0aXZlKDEwNTApAgUGb3JhY2xlAhYlcyVzX19wcmljZV9fVVNETi1VU0RUAQdidXlTdXJmAwZjYWxsZXIFd2hhbGUHcmVndWxhcgQHYWRkcmVzcwkApQgBBQZjYWxsZXIEB3JlZ1BhcnQDBQdyZWd1bGFyCQEFYXNJbnQBCQD8BwQFDnVzZG5WZXN0aW5nQWxsAhZ3aXRoZHJhd0FsbFZlc3RlZEZvclRvCQDMCAIFB2FkZHJlc3MJAMwIAgkApQgBBQR0aGlzBQNuaWwFA25pbAAAAwkAAAIFB3JlZ1BhcnQFB3JlZ1BhcnQECXdoYWxlUGFydAMFBXdoYWxlCQACAQIPbm90IGltcGxlbWVudGVkAAADCQAAAgUJd2hhbGVQYXJ0BQl3aGFsZVBhcnQEBXRvdGFsCQBkAgUJd2hhbGVQYXJ0BQdyZWdQYXJ0BANidXkJAPwHBAULc3VyZkFkZHJlc3MCB2J1eVN1cmYJAMwIAgDAhD0JAMwIAgDAhD0JAMwIAgcFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkA2QQBBQt1c2RuQXNzZXRJZAUFdG90YWwFA25pbAMJAAACBQNidXkFA2J1eQkA8AcCBQR0aGlzBQtzdXJmQXNzZXRJZAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgALcmVzZXJ2ZXNTdHIJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQ1jb25maWdBZGRyZXNzAhBwcmltYXJ5X3Jlc2VydmVzAhZubyByZXNlcnZlcyByZWdpc3RlcmVkAQN2bFIBAXIDCQEIY29udGFpbnMCBQtyZXNlcnZlc1N0cgUBcgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEFAXICDW1haW46IGJhZCByc3IJAAIBCQCsAgICDHVua25vd24gcnNyOgUBcgEXc3RhcnRWZXN0aW5nRm9ySW50ZXJuYWwDB2FkZHJlc3MDcnNyBmFtb3VudAQBcgkBA3ZsUgEFA3JzcgMJAAACBQFyBQFyBAdyZXNlcnZlCQERQGV4dHJOYXRpdmUoMTA2MikBBQNyc3IEB2Fzc2V0SWQJARFAZXh0ck5hdGl2ZSgxMDUzKQIFB3Jlc2VydmUCB2Fzc2V0SWQEAm13CQD8BwQFC3VzZG5WZXN0aW5nAhJzdGFydFZlc3RpbmdBbGxGb3IJAMwIAgUHYWRkcmVzcwUDbmlsBQNuaWwDCQAAAgUCbXcFAm13BAZjaGVja3MJAQlvcEFsbG93ZWQCAg5vcGVuQ29sbGF0ZXJhbAUHYXNzZXRJZAMJAAACBQZjaGVja3MFBmNoZWNrcwQCczMJAQVhc0ludAEJAPwHBAUHcmVzZXJ2ZQIYdHJhbnNmZXJBVG9rZW5zQW1vdW50Rm9yCQDMCAIFB2FkZHJlc3MJAMwIAgUDYWNjCQDMCAIFBmFtb3VudAUDbmlsBQNuaWwDCQAAAgUCczMFAnMzBAZ4dG5BbXQEEnJlc2VydmVWZXN0aW5nUmF0ZQkAmggCBQ1jb25maWdBZGRyZXNzCQCsAgIFA3JzcgIRX3RvX3Zlc3RpbmdfdmFsdWUDCQEJaXNEZWZpbmVkAQUScmVzZXJ2ZVZlc3RpbmdSYXRlCQBrAwUCczMJAQV2YWx1ZQEFEnJlc2VydmVWZXN0aW5nUmF0ZQULZmFjdG9yc0Jhc2UEA3VzZAkBBWFzSW50AQkA/AcEBQdyZXNlcnZlAgV0b1VTRAkAzAgCBQJzMwUDbmlsBQNuaWwJAGsDBQN1c2QAwIQ9BQh4dG5QcmljZQQFcmVoYWIEAndkCQD8BwQFEHByb3RlY3RlZFJlc2VydmUCD3dpdGhkcmF3VG9NYWluMgkAzAgCBQNhY2MJAMwIAgULdXNkbkFzc2V0SWQJAMwIAgUGeHRuQW10BQNuaWwFA25pbAMJAAACBQJ3ZAUCd2QEBXJlaGFiCQD8BwQFDnVzZG5WZXN0aW5nQWxsAgphY2NvdW50Rm9yCQDMCAIFB2FkZHJlc3MFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkA2QQBBQt1c2RuQXNzZXRJZAUGeHRuQW10BQNuaWwDCQAAAgUFcmVoYWIFBXJlaGFiBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAwkAAAIFBXJlaGFiBQVyZWhhYgQLJHQwNTg1MDU5MTIJAQZhc0ludDIBCQD8BwQFBW1haW4xAghoZWFsdGhPZgkAzAgCBQdhZGRyZXNzBQNuaWwFA25pbAQCYnAIBQskdDA1ODUwNTkxMgJfMQQDYnB1CAULJHQwNTg1MDU5MTICXzIDCQBmAgUCYnAJAGgCAGQJAGUCBQJicAUDYnB1CQACAQIqbm90IGVub3VnaCBhZGRyZXNzIGhlYWx0aCBhZnRlciBtb3ZlOiA8IDElCQCUCgIJAMwIAgkBCGNoYW5nZUJ5AgkArAICCQCsAgIFB2FkZHJlc3MCCl9taWdyYXRlZF8FB2Fzc2V0SWQFAnMzBQNuaWwFBnh0bkFtdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgAUbWludERhaWx5R2xvYmFsTGltaXQJAQt2YWx1ZU9yRWxzZQIJAJoIAgUNY29uZmlnQWRkcmVzcwkArAICCQClCAEFBHRoaXMCGF9taW50X2RhaWx5X2dsb2JhbF9saW1pdACA0NvD9AIAGW1pbnRUb2RheUdsb2JhbExpbWl0U3RvcmUJAKwCAgkApAMBCQBrAwUGSEVJR0hUAAEJAGgCADwAGAISX21pbnRfZ2xvYmFsX2xpbWl0ABRtaW50VG9kYXlHbG9iYWxMaW1pdAkBC3ZhbHVlT3JFbHNlAgkAnwgBBRltaW50VG9kYXlHbG9iYWxMaW1pdFN0b3JlBRRtaW50RGFpbHlHbG9iYWxMaW1pdAAWaW1wb3J0RGFpbHlHbG9iYWxMaW1pdAkBC3ZhbHVlT3JFbHNlAgkAmggCBQ1jb25maWdBZGRyZXNzCQCsAgIJAKUIAQUEdGhpcwIaX2ltcG9ydF9kYWlseV9nbG9iYWxfbGltaXQAgNDbw/QCABtpbXBvcnRUb2RheUdsb2JhbExpbWl0U3RvcmUJAKwCAgkApAMBCQBrAwUGSEVJR0hUAAEJAGgCADwAGAIUX2ltcG9ydF9nbG9iYWxfbGltaXQAFmltcG9ydFRvZGF5R2xvYmFsTGltaXQJAQt2YWx1ZU9yRWxzZQIJAJ8IAQUbaW1wb3J0VG9kYXlHbG9iYWxMaW1pdFN0b3JlBRZpbXBvcnREYWlseUdsb2JhbExpbWl0CgFpAQRpbml0CQRjb25mAXQBYwh2ZXN0bkFsbAdhY2NvdW50BG1haW4JdXNkbkFzc2V0BWJvbnVzBXZlc3RuAwkBAiE9AggFAWkGY2FsbGVyBQR0aGlzCQACAQISb25seSBzZWxmIGNhbiBpbml0CQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgULY29uZmlnU3RvcmUFBGNvbmYJAMwIAgkBEHdyaXRlQ29uc3RTdHJpbmcCAgt1c2R0UmVzZXJ2ZQUBdAkAzAgCCQEQd3JpdGVDb25zdFN0cmluZwICC3VzZGNSZXNlcnZlBQFjCQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgIOdXNkblZlc3RpbmdBbGwFCHZlc3RuQWxsCQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgILdXNkblZlc3RpbmcFBXZlc3RuCQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgIDYWNjBQdhY2NvdW50CQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgIFbWFpbjEFBG1haW4JAMwIAgkBEHdyaXRlQ29uc3RTdHJpbmcCAgt1c2RuQXNzZXRJZAUJdXNkbkFzc2V0CQDMCAIJAQxJbnRlZ2VyRW50cnkCAgVib251cwUFYm9udXMFA25pbAFpAQ9zdGFydFZlc3RpbmdGb3IDB2FkZHJlc3MDcnNyBmFtb3VudAQBbQkBCG1haW5Pbmx5AQUBaQMJAAACBQFtBQFtCQEXc3RhcnRWZXN0aW5nRm9ySW50ZXJuYWwDBQdhZGRyZXNzBQNyc3IFBmFtb3VudAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQxzdGFydFZlc3RpbmcCA3JzcgZhbW91bnQJARdzdGFydFZlc3RpbmdGb3JJbnRlcm5hbAMJAKUIAQgFAWkGY2FsbGVyBQNyc3IFBmFtb3VudAFpAQ1jb252ZXJ0VG9VU0ROAAQHYWRkcmVzcwkApQgBCAUBaQZjYWxsZXIKAQdtb3ZlUnNyAQNyc3IEB3Jlc2VydmUJARFAZXh0ck5hdGl2ZSgxMDYyKQEFA3JzcgQHYXNzZXRJZAkBEUBleHRyTmF0aXZlKDEwNTMpAgUHcmVzZXJ2ZQIHYXNzZXRJZAQGY2hlY2tzCQEJb3BBbGxvd2VkAgIOb3BlbkNvbGxhdGVyYWwFB2Fzc2V0SWQDCQAAAgUGY2hlY2tzBQZjaGVja3MDAwkBAiE9AgUDcnNyCQClCAEFC3VzZHRSZXNlcnZlCQECIT0CBQNyc3IJAKUIAQULdXNkY1Jlc2VydmUHCQACAQIPaW52YWxpZCByZXNlcnZlBANzaEMJAPwHBAUCdmQCCnN5bmNIZWlnaHQJAMwIAgUDcnNyBQNuaWwFA25pbAMJAAACBQNzaEMFA3NoQwQLJHQwODEzMDgyMTQJAQZhc0ludDIBCQD8BwQFB3Jlc2VydmUCE3N0b3JlZERlcG9zaXRCb3Jyb3cFA25pbAUDbmlsBAx0b3RhbERlcG9zaXQIBQskdDA4MTMwODIxNAJfMQQJdG90YWxEZWJ0CAULJHQwODEzMDgyMTQCXzIEBHV0aWwDCQBmAgUMdG90YWxEZXBvc2l0AAAJAJcDAQkAzAgCBQtmYWN0b3JzQmFzZQkAzAgCCQBrAwUJdG90YWxEZWJ0BQtmYWN0b3JzQmFzZQUMdG90YWxEZXBvc2l0BQNuaWwAAAQNdXRpbFRocmVzaG9sZAkBC3ZhbHVlT3JFbHNlAgkAmggCBQ1jb25maWdBZGRyZXNzCQCsAgIFB2Fzc2V0SWQCGV9vcGVuX2NvbGxhdGVyYWxfdGhyZXNvbGQA6AcDCQBmAgUNdXRpbFRocmVzaG9sZAUEdXRpbAkAAgECHW5vdCBhbGxvd2VkOiB1dGlsIDwgdGhyZXNob2xkBANkZXAJAQVhc0ludAEJAPwHBAUHcmVzZXJ2ZQIOdXNlckRlcG9zaXRVU0QJAMwIAgUHYWRkcmVzcwUDbmlsBQNuaWwDCQAAAgUDZGVwBQNkZXAEAnMzCQEFYXNJbnQBCQD8BwQFB3Jlc2VydmUCEnRyYW5zZmVyQVRva2Vuc0ZvcgkAzAgCBQdhZGRyZXNzCQDMCAIFA2FjYwkAzAgCBQNkZXAFA25pbAUDbmlsAwkAAAIFAnMzBQJzMwQEcFJ3MwkBCm1vdmVTdHJlYW0FBQNyc3ICB2RlcG9zaXQFB2FkZHJlc3MFA2FjYwUCczMDCQAAAgUEcFJ3MwUEcFJ3MwUCczMJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4EAm13CQD8BwQFC3VzZG5WZXN0aW5nAhJzdGFydFZlc3RpbmdBbGxGb3IJAMwIAgkApQgBCAUBaQZjYWxsZXIFA25pbAUDbmlsAwkAAAIFAm13BQJtdwQCbXQJAQVhc0ludAEJAQdtb3ZlUnNyAQkApQgBBQt1c2R0UmVzZXJ2ZQMJAAACBQJtdAUCbXQEAm1jCQEFYXNJbnQBCQEHbW92ZVJzcgEJAKUIAQULdXNkY1Jlc2VydmUDCQAAAgUCbWMFAm1jBAhkZXBUb3RhbAkAZAIFAm10BQJtYwQFcmVoYWIEB3VzZG5BbXQJAGsDBQhkZXBUb3RhbAkAZAIFC2ZhY3RvcnNCYXNlBQl1c2RuQm9udXMFC2ZhY3RvcnNCYXNlBAJ3ZAkA/AcEBRBwcm90ZWN0ZWRSZXNlcnZlAg93aXRoZHJhd1RvTWFpbjIJAMwIAgUDYWNjCQDMCAIFC3VzZG5Bc3NldElkCQDMCAIFB3VzZG5BbXQFA25pbAUDbmlsAwkAAAIFAndkBQJ3ZAQFcmVoYWIJAPwHBAUOdXNkblZlc3RpbmdBbGwCCmFjY291bnRGb3IJAMwIAgUHYWRkcmVzcwUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQDZBAEFC3VzZG5Bc3NldElkBQd1c2RuQW10BQNuaWwDCQAAAgUFcmVoYWIFBXJlaGFiBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAwkAAAIFBXJlaGFiBQVyZWhhYgQLJHQwOTM2ODk0MzAJAQZhc0ludDIBCQD8BwQFBW1haW4xAghoZWFsdGhPZgkAzAgCBQdhZGRyZXNzBQNuaWwFA25pbAQCYnAIBQskdDA5MzY4OTQzMAJfMQQDYnB1CAULJHQwOTM2ODk0MzACXzIDCQBmAgUCYnAJAGgCAGQJAGUCBQJicAUDYnB1CQACAQIqbm90IGVub3VnaCBhZGRyZXNzIGhlYWx0aCBhZnRlciBtb3ZlOiA8IDElCQDMCAIJAQhjaGFuZ2VCeQIJAKwCAgkArAICBQdhZGRyZXNzAgpfbWlncmF0ZWRfCQERQGV4dHJOYXRpdmUoMTA1MykCBQt1c2R0UmVzZXJ2ZQIHYXNzZXRJZAUCbXQJAMwIAgkBCGNoYW5nZUJ5AgkArAICCQCsAgIFB2FkZHJlc3MCCl9taWdyYXRlZF8JARFAZXh0ck5hdGl2ZSgxMDUzKQIFC3VzZGNSZXNlcnZlAgdhc3NldElkBQJtYwUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBFXdpdGhkcmF3VmVzdGVkQWxsVVNETgIFd2hhbGUHcmVndWxhcgQHYWRkcmVzcwkApQgBCAUBaQZjYWxsZXIEB3JlZ1BhcnQDBQdyZWd1bGFyCQEFYXNJbnQBCQD8BwQFDnVzZG5WZXN0aW5nQWxsAhN3aXRoZHJhd1Zlc3RlZEZvclRvCQDMCAIFB2FkZHJlc3MJAMwIAgUHYWRkcmVzcwUDbmlsBQNuaWwAAAMJAAACBQdyZWdQYXJ0BQdyZWdQYXJ0BAl3aGFsZVBhcnQDBQV3aGFsZQkBBWFzSW50AQkA/AcEBQt1c2RuVmVzdGluZwITd2l0aGRyYXdWZXN0ZWRGb3JUbwkAzAgCBQdhZGRyZXNzCQDMCAIFB2FkZHJlc3MFA25pbAUDbmlsAAADCQAAAgUJd2hhbGVQYXJ0BQl3aGFsZVBhcnQJAJQKAgUDbmlsCQBkAgUJd2hhbGVQYXJ0BQdyZWdQYXJ0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBFXdpdGhkcmF3VmVzdGVkQWxsU1VSRgIFd2hhbGUHcmVndWxhcgQGY2hlY2tzCQEJb3BBbGxvd2VkAgIhbGlxdWlkYW9fYWxsX3dpdGhkcmF3VmVzdGVkQXNTdXJmCQDYBAEFC3N1cmZBc3NldElkAwkAAAIFBmNoZWNrcwUGY2hlY2tzBAtzdXJmQmFsYW5jZQkBB2J1eVN1cmYDCAUBaQZjYWxsZXIFBXdoYWxlBQdyZWd1bGFyAwkAAAIFC3N1cmZCYWxhbmNlBQtzdXJmQmFsYW5jZQkAlAoCCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgULc3VyZkJhbGFuY2UFC3N1cmZBc3NldElkBQNuaWwFC3N1cmZCYWxhbmNlCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBE3dpdGhkcmF3VmVzdGVkU1VSRjIDBXdoYWxlB3JlZ3VsYXIFc3Rha2UEB2FkZHJlc3MJAKUIAQgFAWkGY2FsbGVyBAZjaGVja3MJAQlvcEFsbG93ZWQCAiFsaXF1aWRhb19hbGxfd2l0aGRyYXdWZXN0ZWRBc1N1cmYJANgEAQULc3VyZkFzc2V0SWQDCQAAAgUGY2hlY2tzBQZjaGVja3MEB3JlZ1BhcnQDCQBmAgUHcmVndWxhcgAACQEFYXNJbnQBCQD8BwQFDnVzZG5WZXN0aW5nQWxsAhpwYXJ0aWFsV2l0aGRyYXdWZXN0ZWRGb3JUbwkAzAgCBQdhZGRyZXNzCQDMCAIJAKUIAQUEdGhpcwkAzAgCBQdyZWd1bGFyBQNuaWwFA25pbAAAAwkAAAIFB3JlZ1BhcnQFB3JlZ1BhcnQECXdoYWxlUGFydAMJAGYCBQV3aGFsZQAACQEFYXNJbnQBCQD8BwQFC3VzZG5WZXN0aW5nAhpwYXJ0aWFsV2l0aGRyYXdWZXN0ZWRGb3JUbwkAzAgCBQdhZGRyZXNzCQDMCAIJAKUIAQUEdGhpcwkAzAgCBQV3aGFsZQUDbmlsBQNuaWwAAAMJAAACBQl3aGFsZVBhcnQFCXdoYWxlUGFydAQFdG90YWwJAGQCBQl3aGFsZVBhcnQFB3JlZ1BhcnQEA2J1eQkA/AcEBQtzdXJmQWRkcmVzcwIHYnV5U3VyZgkAzAgCAMCEPQkAzAgCAMCEPQkAzAgCBwUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQDZBAEFC3VzZG5Bc3NldElkBQV0b3RhbAUDbmlsAwkAAAIFA2J1eQUDYnV5BAtzdXJmQmFsYW5jZQkA8AcCBQR0aGlzBQtzdXJmQXNzZXRJZAMJAAACBQtzdXJmQmFsYW5jZQULc3VyZkJhbGFuY2UDBQVzdGFrZQQJc3Rha2VTdXJmCQD8BwQFEHN1cmZTdGFrZUFkZHJlc3MCE3N0YWtlQnlPcmlnaW5DYWxsZXIFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgULc3VyZkFzc2V0SWQFC3N1cmZCYWxhbmNlBQNuaWwDCQAAAgUJc3Rha2VTdXJmBQlzdGFrZVN1cmYJAJQKAgUDbmlsBQtzdXJmQmFsYW5jZQkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAlAoCCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgULc3VyZkJhbGFuY2UFC3N1cmZBc3NldElkBQNuaWwFC3N1cmZCYWxhbmNlCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBHXdpdGhkcmF3VmVzdGVkQWxsU1VSRkFuZFN0YWtlAgV3aGFsZQdyZWd1bGFyBAZjaGVja3MJAQlvcEFsbG93ZWQCAiFsaXF1aWRhb19hbGxfd2l0aGRyYXdWZXN0ZWRBc1N1cmYJANgEAQULc3VyZkFzc2V0SWQDCQAAAgUGY2hlY2tzBQZjaGVja3MEC3N1cmZCYWxhbmNlCQEHYnV5U3VyZgMIBQFpBmNhbGxlcgUFd2hhbGUFB3JlZ3VsYXIDCQAAAgULc3VyZkJhbGFuY2UFC3N1cmZCYWxhbmNlBAlzdGFrZVN1cmYJAPwHBAUQc3VyZlN0YWtlQWRkcmVzcwITc3Rha2VCeU9yaWdpbkNhbGxlcgUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQtzdXJmQXNzZXRJZAULc3VyZkJhbGFuY2UFA25pbAMJAAACBQlzdGFrZVN1cmYFCXN0YWtlU3VyZgkAlAoCBQNuaWwFC3N1cmZCYWxhbmNlCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBDHdpdGhkcmF3QXNMUAIFd2hhbGUHcmVndWxhcgQHYWRkcmVzcwkApQgBCAUBaQZjYWxsZXIDCQAAAgUUbWludFRvZGF5R2xvYmFsTGltaXQAAAkAAgEJAKwCAgIZRGFpbHkgZXhwb3J0IGxpbWl0OiAwIG9mIAkApAMBBRRtaW50RGFpbHlHbG9iYWxMaW1pdAQNJHQwMTIwNjQxMjMxOAMJAGYCBQdyZWd1bGFyBRRtaW50VG9kYXlHbG9iYWxMaW1pdAkAlAoCBRRtaW50VG9kYXlHbG9iYWxMaW1pdAAAAwkAZgIJAGQCBQV3aGFsZQUHcmVndWxhcgUUbWludFRvZGF5R2xvYmFsTGltaXQJAJQKAgUHcmVndWxhcgkAZQIFFG1pbnRUb2RheUdsb2JhbExpbWl0BQdyZWd1bGFyCQCUCgIFB3JlZ3VsYXIFBXdoYWxlBApyZWd1bGFyQW10CAUNJHQwMTIwNjQxMjMxOAJfMQQId2hhbGVBbXQIBQ0kdDAxMjA2NDEyMzE4Al8yBAdyZWdQYXJ0AwkAZgIFCnJlZ3VsYXJBbXQAAAkBBWFzSW50AQkA/AcEBQ51c2RuVmVzdGluZ0FsbAIacGFydGlhbFdpdGhkcmF3VmVzdGVkRm9yVG8JAMwIAgUHYWRkcmVzcwkAzAgCCQClCAEFBHRoaXMJAMwIAgUKcmVndWxhckFtdAUDbmlsBQNuaWwAAAMJAAACBQdyZWdQYXJ0BQdyZWdQYXJ0BAl3aGFsZVBhcnQDCQBmAgUId2hhbGVBbXQAAAkBBWFzSW50AQkA/AcEBQt1c2RuVmVzdGluZwIacGFydGlhbFdpdGhkcmF3VmVzdGVkRm9yVG8JAMwIAgUHYWRkcmVzcwkAzAgCCQClCAEFBHRoaXMJAMwIAgUId2hhbGVBbXQFA25pbAUDbmlsAAADCQAAAgUJd2hhbGVQYXJ0BQl3aGFsZVBhcnQEBXRvdGFsCQBkAgUJd2hhbGVQYXJ0BQdyZWdQYXJ0BAR0b0xwCQD8BwQFFXZpcmVzVmVzdGVkVXNkbkxwRGFwcAIGbWludFRvCQDMCAIFB2FkZHJlc3MFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkA2QQBBQt1c2RuQXNzZXRJZAUFdG90YWwFA25pbAMJAAACBQR0b0xwBQR0b0xwCQCUCgIJAMwIAgkBCGNoYW5nZUJ5AgUZbWludFRvZGF5R2xvYmFsTGltaXRTdG9yZQkBAS0BBQV0b3RhbAUDbmlsBQV0b3RhbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQhpbXBvcnRMUAADCQAAAgUWaW1wb3J0VG9kYXlHbG9iYWxMaW1pdAAACQACAQkArAICAhlEYWlseSBpbXBvcnQgbGltaXQ6IDAgb2YgCQCkAwEFFmltcG9ydERhaWx5R2xvYmFsTGltaXQEB2FkZHJlc3MJAKUIAQgFAWkGY2FsbGVyBApwYXltZW50QW10CAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAQJbHBBc3NldElkCAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQEDSR0MDEzMTU0MTM1MTIDCQBmAgUKcGF5bWVudEFtdAUWaW1wb3J0VG9kYXlHbG9iYWxMaW1pdAkAlQoDCQEPQXR0YWNoZWRQYXltZW50AgUJbHBBc3NldElkBRZpbXBvcnRUb2RheUdsb2JhbExpbWl0CQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgkAZQIFCnBheW1lbnRBbXQFFmltcG9ydFRvZGF5R2xvYmFsTGltaXQFCWxwQXNzZXRJZAUDbmlsAAAJAJUKAwkAkQMCCAUBaQhwYXltZW50cwAABQNuaWwJAGUCBRZpbXBvcnRUb2RheUdsb2JhbExpbWl0BQpwYXltZW50QW10BAdwYXltZW50CAUNJHQwMTMxNTQxMzUxMgJfMQQGY2hhbmdlCAUNJHQwMTMxNTQxMzUxMgJfMgQIbmV3TGltaXQIBQ0kdDAxMzE1NDEzNTEyAl8zBAd1c2RuQW10CQEFYXNJbnQBCQD8BwQFFXZpcmVzVmVzdGVkVXNkbkxwRGFwcAIGaW1wb3J0BQNuaWwJAMwIAgUHcGF5bWVudAUDbmlsAwkAAAIFB3VzZG5BbXQFB3VzZG5BbXQECmFjY291bnRGb3IJAPwHBAUOdXNkblZlc3RpbmdBbGwCCmFjY291bnRGb3IJAMwIAgUHYWRkcmVzcwUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQDZBAEFC3VzZG5Bc3NldElkBQd1c2RuQW10BQNuaWwDCQAAAgUKYWNjb3VudEZvcgUKYWNjb3VudEZvcgkAlAoCCQDMCAIJAQxJbnRlZ2VyRW50cnkCBRtpbXBvcnRUb2RheUdsb2JhbExpbWl0U3RvcmUFCG5ld0xpbWl0BQZjaGFuZ2UFB3VzZG5BbXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BAnR4AQZ2ZXJpZnkABARCQVNFAOgHBAtxdW9ydW1SYXRpbwkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFDWNvbmZpZ0FkZHJlc3MCFXByb3Bvc2FsX3F1b3J1bV9yYXRpbwIicHJvcG9zYWxRdW9ydW1SYXRpbyBpcyBub3QgZGVmaW5lZAQLcGFzc2VkUmF0aW8JARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQ1jb25maWdBZGRyZXNzAhVwcm9wb3NhbF9wYXNzZWRfcmF0aW8CJXByb3Bvc2FsVGhyZXNob2xkUmF0aW8gaXMgbm90IGRlZmluZWQEDmdWaXJlc0NvbnRyYWN0CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFDWNvbmZpZ0FkZHJlc3MCEmRpdmlkZW5kc19jb250cmFjdAIVbm8gZGl2aWRlbmRzX2NvbnRyYWN0AhppbnZhbGlkIGRpdmlkZW5kc19jb250cmFjdAQOdm90aW5nQ29udHJhY3QJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUNY29uZmlnQWRkcmVzcwIPdm90aW5nX2NvbnRyYWN0AhJubyB2b3RpbmdfY29udHJhY3QCF2ludmFsaWQgdm90aW5nX2NvbnRyYWN0BAJpZAkA2AQBCAUCdHgCaWQECHZvdGVzWWVzCQELdmFsdWVPckVsc2UCCQCaCAIFDnZvdGluZ0NvbnRyYWN0CQCsAgICDXByb3Bvc2FsX3llc18FAmlkAAAEB3ZvdGVzTm8JAQt2YWx1ZU9yRWxzZQIJAJoIAgUOdm90aW5nQ29udHJhY3QJAKwCAgIMcHJvcG9zYWxfbm9fBQJpZAAABA5wcm9wb3NhbEhlaWdodAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFDnZvdGluZ0NvbnRyYWN0CQCsAgICEHByb3Bvc2FsX2hlaWdodF8FAmlkAhdwcm9wb3NhbCBub3QgcmVnaXN0ZXJlZAQKYXBwbHlTdGFydAkBC3ZhbHVlT3JFbHNlAgkAmggCBQ52b3RpbmdDb250cmFjdAkArAICAhRwcm9wb3NhbF9hcHBseXN0YXJ0XwUCaWQAAAQIYXBwbHlFbmQJAQt2YWx1ZU9yRWxzZQIJAJoIAgUOdm90aW5nQ29udHJhY3QJAKwCAgIScHJvcG9zYWxfYXBwbHllbmRfBQJpZAAABAt0b3RhbEdWaXJlcwkBC3ZhbHVlT3JFbHNlAgkAmggCBQ52b3RpbmdDb250cmFjdAkArAICAhBwcm9wb3NhbF9ndmlyZXNfBQJpZAAABAdlbmFibGVkCQELdmFsdWVPckVsc2UCCQCbCAIFDWNvbmZpZ0FkZHJlc3MCHW9wX2dvdmVybmFuY2VfYXBwbHlfdHhfcGF1c2VkBwQHdm90ZVllcwUIdm90ZXNZZXMEBnZvdGVObwUHdm90ZXNObwQKdG90YWxWb3RlcwkAZAIFB3ZvdGVZZXMFBnZvdGVObwQJaGFzUXVvcnVtCQBnAgkAaQIJAGgCBQp0b3RhbFZvdGVzBQRCQVNFBQt0b3RhbEdWaXJlcwULcXVvcnVtUmF0aW8ECWhhc1Bhc3NlZAkAZwIJAGkCCQBoAgUHdm90ZVllcwUEQkFTRQUKdG90YWxWb3RlcwULcGFzc2VkUmF0aW8ECHRvb0Vhcmx5CQBnAgUKYXBwbHlTdGFydAUGSEVJR0hUBAd0b29MYXRlCQBnAgUGSEVJR0hUBQhhcHBseUVuZAQJdGltZURlYnVnCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICEXByb3Bvc2FsSGVpZ2h0ID0gCQCkAwEFDnByb3Bvc2FsSGVpZ2h0Ag8sIGFwcGx5U3RhcnQgPSAJAKQDAQUKYXBwbHlTdGFydAINLCBhcHBseUVuZCA9IAkApAMBBQhhcHBseUVuZAILLCBIRUlHSFQgPSAJAKQDAQUGSEVJR0hUBAhieVZvdGluZwMJAQEhAQUHZW5hYmxlZAkAAgECK3R4IGFwcGxpY2F0aW9uIHRocm93IGdvdmVybmFuY2Ugbm90IGVuYWJsZWQDBQh0b29FYXJseQkAAgEJAKwCAgIucHJvcG9zYWwgY2FuJ3QgYmUgZXhlY3V0ZWQgYXMgaXQncyB0b28gZWFybHk6IAUJdGltZURlYnVnAwUHdG9vTGF0ZQkAAgEJAKwCAgIscHJvcG9zYWwgY2FuJ3QgYmUgZXhlY3V0ZWQgYXMgaXQncyB0b28gbGF0ZToFCXRpbWVEZWJ1ZwMJAQEhAQUJaGFzUXVvcnVtCQACAQkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgILbm8gcXVvcnVtOiACDHRvdGFsVm90ZXM6IAkApAMBBQp0b3RhbFZvdGVzAg8sIHRvdGFsR1ZpcmVzOiAJAKQDAQULdG90YWxHVmlyZXMCDywgcXVvcnVtUmF0aW86IAkApAMBBQtxdW9ydW1SYXRpbwMJAQEhAQUJaGFzUGFzc2VkCQACAQkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgIXbm8gdGhyZXNob2xkIGFjaGlldmVkOiACCXZvdGVZZXM6IAkApAMBBQd2b3RlWWVzAgosIHZvdGVObzogCQCkAwEFBnZvdGVObwIPLCBwYXNzZWRSYXRpbzogCQCkAwEFC3Bhc3NlZFJhdGlvBgMJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAIBQJ0eA9zZW5kZXJQdWJsaWNLZXkGBQhieVZvdGluZ6nTrUo=", "chainId": 87, "height": 4014166, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 66UbN1LgjD8AvTDFcmY5Rp7gCWdgN21pZEw1ior5we7e Next: Dgza1RW2FAv26mhq6tGA7uwpct91thdQQfAeSYvJ5B2D Diff:
OldNewDifferences
248248 }
249249
250250
251+let aF = valueOrElse(getInteger(x, (toString(this) + "_mint_daily_global_limit")), 100000000000)
252+
253+let aG = (toString(fraction(A, 1, (60 * 24))) + "_mint_global_limit")
254+
255+let aH = valueOrElse(getInteger(aG), aF)
256+
257+let aI = valueOrElse(getInteger(x, (toString(this) + "_import_daily_global_limit")), 100000000000)
258+
259+let aJ = (toString(fraction(A, 1, (60 * 24))) + "_import_global_limit")
260+
261+let aK = valueOrElse(getInteger(aJ), aI)
262+
251263 @Callable(V)
252-func init (aF,n,aG,aH,aI,aJ,aK,aL,aM) = if ((V.caller != this))
264+func init (aL,n,aM,aN,aO,aP,aQ,aR,aS) = if ((V.caller != this))
253265 then throw("only self can init")
254- else [b(w, aF), b("usdtReserve", n), b("usdcReserve", aG), b("usdnVestingAll", aH), b("usdnVesting", aM), b("acc", aI), b("main1", aJ), b("usdnAssetId", aK), IntegerEntry("bonus", aL)]
266+ else [b(w, aL), b("usdtReserve", n), b("usdcReserve", aM), b("usdnVestingAll", aN), b("usdnVesting", aS), b("acc", aO), b("main1", aP), b("usdnAssetId", aQ), IntegerEntry("bonus", aR)]
255267
256268
257269
258270 @Callable(V)
259271 func startVestingFor (ai,q,ar) = {
260- let aN = U(V)
261- if ((aN == aN))
272+ let aT = U(V)
273+ if ((aT == aT))
262274 then aq(ai, q, ar)
263275 else throw("Strict value is not equal to itself.")
264276 }
273285 @Callable(V)
274286 func convertToUSDN () = {
275287 let ai = toString(V.caller)
276- func aO (q) = {
288+ func aU (q) = {
277289 let as = addressFromStringValue(q)
278290 let at = getStringValue(as, "assetId")
279291 let av = Q("openCollateral", at)
283295 else false)
284296 then throw("invalid reserve")
285297 else {
286- let aP = invoke(B, "syncHeight", [q], nil)
287- if ((aP == aP))
298+ let aV = invoke(B, "syncHeight", [q], nil)
299+ if ((aV == aV))
288300 then {
289- let aQ = l(invoke(as, "storedDepositBorrow", nil, nil))
290- let aR = aQ._1
291- let aS = aQ._2
292- let aT = if ((aR > 0))
293- then min([a, fraction(aS, a, aR)])
301+ let aW = l(invoke(as, "storedDepositBorrow", nil, nil))
302+ let aX = aW._1
303+ let aY = aW._2
304+ let aZ = if ((aX > 0))
305+ then min([a, fraction(aY, a, aX)])
294306 else 0
295- let aU = valueOrElse(getInteger(x, (at + "_open_collateral_thresold")), 1000)
296- if ((aU > aT))
307+ let ba = valueOrElse(getInteger(x, (at + "_open_collateral_thresold")), 1000)
308+ if ((ba > aZ))
297309 then throw("not allowed: util < threshold")
298310 else {
299- let aV = j(invoke(as, "userDepositUSD", [ai], nil))
300- if ((aV == aV))
311+ let bb = j(invoke(as, "userDepositUSD", [ai], nil))
312+ if ((bb == bb))
301313 then {
302- let aw = j(invoke(as, "transferATokensFor", [ai, G, aV], nil))
314+ let aw = j(invoke(as, "transferATokensFor", [ai, G, bb], nil))
303315 if ((aw == aw))
304316 then {
305- let aW = L(q, "deposit", ai, G, aw)
306- if ((aW == aW))
317+ let bc = L(q, "deposit", ai, G, aw)
318+ if ((bc == bc))
307319 then aw
308320 else throw("Strict value is not equal to itself.")
309321 }
320332 let au = invoke(I, "startVestingAllFor", [toString(V.caller)], nil)
321333 if ((au == au))
322334 then {
323- let aX = j(aO(toString(E)))
324- if ((aX == aX))
335+ let bd = j(aU(toString(E)))
336+ if ((bd == bd))
325337 then {
326- let aY = j(aO(toString(F)))
327- if ((aY == aY))
338+ let be = j(aU(toString(F)))
339+ if ((be == be))
328340 then {
329- let aZ = (aX + aY)
341+ let bf = (bd + be)
330342 let aA = {
331- let ba = fraction(aZ, (a + K), a)
332- let aB = invoke(C, "withdrawToMain2", [G, J, ba], nil)
343+ let bg = fraction(bf, (a + K), a)
344+ let aB = invoke(C, "withdrawToMain2", [G, J, bg], nil)
333345 if ((aB == aB))
334346 then {
335- let aA = invoke(H, "accountFor", [ai], [AttachedPayment(fromBase58String(J), ba)])
347+ let aA = invoke(H, "accountFor", [ai], [AttachedPayment(fromBase58String(J), bg)])
336348 if ((aA == aA))
337349 then unit
338350 else throw("Strict value is not equal to itself.")
341353 }
342354 if ((aA == aA))
343355 then {
344- let bb = l(invoke(D, "healthOf", [ai], nil))
345- let aD = bb._1
346- let aE = bb._2
356+ let bh = l(invoke(D, "healthOf", [ai], nil))
357+ let aD = bh._1
358+ let aE = bh._2
347359 if ((aD > (100 * (aD - aE))))
348360 then throw("not enough address health after move: < 1%")
349- else [v(((ai + "_migrated_") + getStringValue(E, "assetId")), aX), v(((ai + "_migrated_") + getStringValue(F, "assetId")), aY)]
361+ else [v(((ai + "_migrated_") + getStringValue(E, "assetId")), bd), v(((ai + "_migrated_") + getStringValue(F, "assetId")), be)]
350362 }
351363 else throw("Strict value is not equal to itself.")
352364 }
384396 let av = Q("liquidao_all_withdrawVestedAsSurf", toBase58String(ab))
385397 if ((av == av))
386398 then {
387- let bc = ae(V.caller, ag, ah)
388- if ((bc == bc))
389- then $Tuple2([ScriptTransfer(V.caller, bc, ab)], bc)
399+ let bi = ae(V.caller, ag, ah)
400+ if ((bi == bi))
401+ then $Tuple2([ScriptTransfer(V.caller, bi, ab)], bi)
390402 else throw("Strict value is not equal to itself.")
391403 }
392404 else throw("Strict value is not equal to itself.")
395407
396408
397409 @Callable(V)
398-func withdrawVestedSURF2 (ag,ah,bd) = {
410+func withdrawVestedSURF2 (ag,ah,bj) = {
399411 let ai = toString(V.caller)
400412 let av = Q("liquidao_all_withdrawVestedAsSurf", toBase58String(ab))
401413 if ((av == av))
414426 let am = invoke(Z, "buySurf", [1000000, 1000000, false], [AttachedPayment(fromBase58String(J), al)])
415427 if ((am == am))
416428 then {
417- let bc = assetBalance(this, ab)
418- if ((bc == bc))
419- then if (bd)
429+ let bi = assetBalance(this, ab)
430+ if ((bi == bi))
431+ then if (bj)
420432 then {
421- let be = invoke(aa, "stakeByOriginCaller", nil, [AttachedPayment(ab, bc)])
422- if ((be == be))
423- then $Tuple2(nil, bc)
433+ let bk = invoke(aa, "stakeByOriginCaller", nil, [AttachedPayment(ab, bi)])
434+ if ((bk == bk))
435+ then $Tuple2(nil, bi)
424436 else throw("Strict value is not equal to itself.")
425437 }
426- else $Tuple2([ScriptTransfer(V.caller, bc, ab)], bc)
438+ else $Tuple2([ScriptTransfer(V.caller, bi, ab)], bi)
427439 else throw("Strict value is not equal to itself.")
428440 }
429441 else throw("Strict value is not equal to itself.")
442454 let av = Q("liquidao_all_withdrawVestedAsSurf", toBase58String(ab))
443455 if ((av == av))
444456 then {
445- let bc = ae(V.caller, ag, ah)
446- if ((bc == bc))
457+ let bi = ae(V.caller, ag, ah)
458+ if ((bi == bi))
447459 then {
448- let be = invoke(aa, "stakeByOriginCaller", nil, [AttachedPayment(ab, bc)])
449- if ((be == be))
450- then $Tuple2(nil, bc)
460+ let bk = invoke(aa, "stakeByOriginCaller", nil, [AttachedPayment(ab, bi)])
461+ if ((bk == bk))
462+ then $Tuple2(nil, bi)
451463 else throw("Strict value is not equal to itself.")
452464 }
453465 else throw("Strict value is not equal to itself.")
460472 @Callable(V)
461473 func withdrawAsLP (ag,ah) = {
462474 let ai = toString(V.caller)
463- let aj = if ((ah > 0))
464- then j(invoke(H, "partialWithdrawVestedForTo", [ai, toString(this), ah], nil))
465- else 0
466- if ((aj == aj))
467- then {
468- let ak = if ((ag > 0))
469- then j(invoke(I, "partialWithdrawVestedForTo", [ai, toString(this), ag], nil))
475+ if ((aH == 0))
476+ then throw(("Daily export limit: 0 of " + toString(aF)))
477+ else {
478+ let bl = if ((ah > aH))
479+ then $Tuple2(aH, 0)
480+ else if (((ag + ah) > aH))
481+ then $Tuple2(ah, (aH - ah))
482+ else $Tuple2(ah, ag)
483+ let bm = bl._1
484+ let bn = bl._2
485+ let aj = if ((bm > 0))
486+ then j(invoke(H, "partialWithdrawVestedForTo", [ai, toString(this), bm], nil))
470487 else 0
471- if ((ak == ak))
488+ if ((aj == aj))
472489 then {
473- let al = (ak + aj)
474- let bf = invoke(y, "mintTo", [ai], [AttachedPayment(fromBase58String(J), al)])
475- if ((bf == bf))
476- then $Tuple2(nil, al)
490+ let ak = if ((bn > 0))
491+ then j(invoke(I, "partialWithdrawVestedForTo", [ai, toString(this), bn], nil))
492+ else 0
493+ if ((ak == ak))
494+ then {
495+ let al = (ak + aj)
496+ let bo = invoke(y, "mintTo", [ai], [AttachedPayment(fromBase58String(J), al)])
497+ if ((bo == bo))
498+ then $Tuple2([v(aG, -(al))], al)
499+ else throw("Strict value is not equal to itself.")
500+ }
477501 else throw("Strict value is not equal to itself.")
478502 }
479503 else throw("Strict value is not equal to itself.")
480504 }
481- else throw("Strict value is not equal to itself.")
482505 }
483506
484507
485508
486509 @Callable(V)
487-func importLP () = {
488- let ai = toString(V.caller)
489- let ba = j(invoke(y, "import", nil, V.payments))
490- if ((ba == ba))
491- then {
492- let bg = invoke(H, "accountFor", [ai], [AttachedPayment(fromBase58String(J), ba)])
493- if ((bg == bg))
494- then $Tuple2(nil, ba)
495- else throw("Strict value is not equal to itself.")
496- }
497- else throw("Strict value is not equal to itself.")
498- }
510+func importLP () = if ((aK == 0))
511+ then throw(("Daily import limit: 0 of " + toString(aI)))
512+ else {
513+ let ai = toString(V.caller)
514+ let bp = V.payments[0].amount
515+ let bq = V.payments[0].assetId
516+ let br = if ((bp > aK))
517+ then $Tuple3(AttachedPayment(bq, aK), [ScriptTransfer(V.caller, (bp - aK), bq)], 0)
518+ else $Tuple3(V.payments[0], nil, (aK - bp))
519+ let bs = br._1
520+ let bt = br._2
521+ let bu = br._3
522+ let bg = j(invoke(y, "import", nil, [bs]))
523+ if ((bg == bg))
524+ then {
525+ let bv = invoke(H, "accountFor", [ai], [AttachedPayment(fromBase58String(J), bg)])
526+ if ((bv == bv))
527+ then $Tuple2(IntegerEntry(aJ, bu) :: bt, bg)
528+ else throw("Strict value is not equal to itself.")
529+ }
530+ else throw("Strict value is not equal to itself.")
531+ }
499532
500533
501-@Verifier(bh)
502-func bi () = {
503- let bj = 1000
504- let bk = valueOrErrorMessage(getInteger(x, "proposal_quorum_ratio"), "proposalQuorumRatio is not defined")
505- let bl = valueOrErrorMessage(getInteger(x, "proposal_passed_ratio"), "proposalThresholdRatio is not defined")
506- let bm = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(x, "dividends_contract"), "no dividends_contract")), "invalid dividends_contract")
507- let bn = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(x, "voting_contract"), "no voting_contract")), "invalid voting_contract")
508- let bo = toBase58String(bh.id)
509- let bp = valueOrElse(getInteger(bn, ("proposal_yes_" + bo)), 0)
510- let bq = valueOrElse(getInteger(bn, ("proposal_no_" + bo)), 0)
511- let br = valueOrErrorMessage(getInteger(bn, ("proposal_height_" + bo)), "proposal not registered")
512- let bs = valueOrElse(getInteger(bn, ("proposal_applystart_" + bo)), 0)
513- let bt = valueOrElse(getInteger(bn, ("proposal_applyend_" + bo)), 0)
514- let bu = valueOrElse(getInteger(bn, ("proposal_gvires_" + bo)), 0)
515- let bv = valueOrElse(getBoolean(x, "op_governance_apply_tx_paused"), false)
516- let bw = bp
517- let bx = bq
518- let by = (bw + bx)
519- let bz = (((by * bj) / bu) >= bk)
520- let bA = (((bw * bj) / by) >= bl)
521- let bB = (bs >= A)
522- let bC = (A >= bt)
523- let bD = ((((((("proposalHeight = " + toString(br)) + ", applyStart = ") + toString(bs)) + ", applyEnd = ") + toString(bt)) + ", HEIGHT = ") + toString(A))
524- let bE = if (!(bv))
534+@Verifier(bw)
535+func bx () = {
536+ let by = 1000
537+ let bz = valueOrErrorMessage(getInteger(x, "proposal_quorum_ratio"), "proposalQuorumRatio is not defined")
538+ let bA = valueOrErrorMessage(getInteger(x, "proposal_passed_ratio"), "proposalThresholdRatio is not defined")
539+ let bB = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(x, "dividends_contract"), "no dividends_contract")), "invalid dividends_contract")
540+ let bC = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(x, "voting_contract"), "no voting_contract")), "invalid voting_contract")
541+ let bD = toBase58String(bw.id)
542+ let bE = valueOrElse(getInteger(bC, ("proposal_yes_" + bD)), 0)
543+ let bF = valueOrElse(getInteger(bC, ("proposal_no_" + bD)), 0)
544+ let bG = valueOrErrorMessage(getInteger(bC, ("proposal_height_" + bD)), "proposal not registered")
545+ let bH = valueOrElse(getInteger(bC, ("proposal_applystart_" + bD)), 0)
546+ let bI = valueOrElse(getInteger(bC, ("proposal_applyend_" + bD)), 0)
547+ let bJ = valueOrElse(getInteger(bC, ("proposal_gvires_" + bD)), 0)
548+ let bK = valueOrElse(getBoolean(x, "op_governance_apply_tx_paused"), false)
549+ let bL = bE
550+ let bM = bF
551+ let bN = (bL + bM)
552+ let bO = (((bN * by) / bJ) >= bz)
553+ let bP = (((bL * by) / bN) >= bA)
554+ let bQ = (bH >= A)
555+ let bR = (A >= bI)
556+ let bS = ((((((("proposalHeight = " + toString(bG)) + ", applyStart = ") + toString(bH)) + ", applyEnd = ") + toString(bI)) + ", HEIGHT = ") + toString(A))
557+ let bT = if (!(bK))
525558 then throw("tx application throw governance not enabled")
526- else if (bB)
527- then throw(("proposal can't be executed as it's too early: " + bD))
528- else if (bC)
529- then throw(("proposal can't be executed as it's too late:" + bD))
530- else if (!(bz))
531- then throw((((((("no quorum: " + "totalVotes: ") + toString(by)) + ", totalGVires: ") + toString(bu)) + ", quorumRatio: ") + toString(bk)))
532- else if (!(bA))
533- then throw((((((("no threshold achieved: " + "voteYes: ") + toString(bw)) + ", voteNo: ") + toString(bx)) + ", passedRatio: ") + toString(bl)))
559+ else if (bQ)
560+ then throw(("proposal can't be executed as it's too early: " + bS))
561+ else if (bR)
562+ then throw(("proposal can't be executed as it's too late:" + bS))
563+ else if (!(bO))
564+ then throw((((((("no quorum: " + "totalVotes: ") + toString(bN)) + ", totalGVires: ") + toString(bJ)) + ", quorumRatio: ") + toString(bz)))
565+ else if (!(bP))
566+ then throw((((((("no threshold achieved: " + "voteYes: ") + toString(bL)) + ", voteNo: ") + toString(bM)) + ", passedRatio: ") + toString(bA)))
534567 else true
535- if (sigVerify(bh.bodyBytes, bh.proofs[0], bh.senderPublicKey))
568+ if (sigVerify(bw.bodyBytes, bw.proofs[0], bw.senderPublicKey))
536569 then true
537- else bE
570+ else bT
538571 }
539572
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let a = 1000
55
66 func b (c,d) = if (!(isDefined(getString(this, c))))
77 then StringEntry(c, d)
88 else throw(("already initialized: " + c))
99
1010
1111 func e (c,d) = if (!(isDefined(getInteger(this, c))))
1212 then IntegerEntry(c, d)
1313 else throw(("already initialized: " + c))
1414
1515
1616 func f (c,d) = if ((0 > d))
1717 then throw(((("writing negative value " + toString(d)) + " for key ") + c))
1818 else IntegerEntry(c, d)
1919
2020
2121 func g (d) = {
2222 let h = d
2323 if ($isInstanceOf(h, "String"))
2424 then {
2525 let i = h
2626 i
2727 }
2828 else throw("wrong type, expected: String")
2929 }
3030
3131
3232 func j (d) = {
3333 let h = d
3434 if ($isInstanceOf(h, "Int"))
3535 then {
3636 let k = h
3737 k
3838 }
3939 else throw("sm:1")
4040 }
4141
4242
4343 func l (d) = {
4444 let h = d
4545 if ($isInstanceOf(h, "(Int, Int)"))
4646 then {
4747 let m = h
4848 m
4949 }
5050 else {
5151 let n = h
5252 throw("wrong type, expected: Int2")
5353 }
5454 }
5555
5656
5757 func o (d) = {
5858 let h = d
5959 if ($isInstanceOf(h, "(Int, Int, Int, Int, Int, Boolean)"))
6060 then {
6161 let m = h
6262 m
6363 }
6464 else {
6565 let n = h
6666 throw("3")
6767 }
6868 }
6969
7070
7171 func p (q,r) = o(invoke(q, "userBalance", [r], nil))
7272
7373
7474 func s (t,u) = if (t)
7575 then throw(u)
7676 else true
7777
7878
7979 func v (c,d) = f(c, (valueOrElse(getInteger(this, c), 0) + d))
8080
8181
8282 let w = "config"
8383
8484 let x = addressFromStringValue(getStringValue(this, w))
8585
8686 let y = addressFromStringValue("3PJFu8MmVa2rSVGM48wdLm4jhLznEgu6XSe")
8787
8888 let z = {
8989 let h = getString(x, "oracle_address")
9090 if ($isInstanceOf(h, "String"))
9191 then {
9292 let i = h
9393 addressFromString(i)
9494 }
9595 else unit
9696 }
9797
9898 let A = height
9999
100100 let B = addressFromStringValue(valueOrErrorMessage(getString(x, "vires_distributor"), "bad vires distributor"))
101101
102102 let C = addressFromStringValue(getStringValue(x, "protected_reserve"))
103103
104104 let D = addressFromStringValue(getStringValue(this, "main1"))
105105
106106 let E = addressFromStringValue(getStringValue(this, "usdtReserve"))
107107
108108 let F = addressFromStringValue(getStringValue(this, "usdcReserve"))
109109
110110 let G = getStringValue(this, "acc")
111111
112112 let H = addressFromStringValue(getStringValue(this, "usdnVestingAll"))
113113
114114 let I = addressFromStringValue(getStringValue(this, "usdnVesting"))
115115
116116 let J = getStringValue(this, "usdnAssetId")
117117
118118 let K = getIntegerValue(this, "bonus")
119119
120120 func L (q,M,N,O,P) = invoke(B, "move", [q, M, N, O, P], nil)
121121
122122
123123 func Q (R,S) = {
124124 let h = invoke(x, "opAllowed", [S, R], nil)
125125 if ($isInstanceOf(h, "Boolean"))
126126 then {
127127 let T = h
128128 if (T)
129129 then true
130130 else throw("not allowed")
131131 }
132132 else throw("opAllowed: unexpected result type")
133133 }
134134
135135
136136 func U (V) = if (contains(getStringValue(x, "main"), toString(V.caller)))
137137 then true
138138 else throw("only main can do")
139139
140140
141141 func W (G) = {
142142 let X = g(invoke(I, "adviseU", [G], nil))
143143 if ((X == X))
144144 then {
145145 let Y = g(invoke(H, "adviseU", [G], nil))
146146 if ((Y == Y))
147147 then ((X + " | ") + Y)
148148 else throw("Strict value is not equal to itself.")
149149 }
150150 else throw("Strict value is not equal to itself.")
151151 }
152152
153153
154154 let Z = addressFromStringValue("3PG2vMhK5CPqsCDodvLGzQ84QkoHXCJ3oNP")
155155
156156 let aa = addressFromStringValue("3PBiotFpqjRMkkeFBccnQNUXUopy7KFez5C")
157157
158158 let ab = fromBase58String("At8D6NFFpheCbvKVnjVoeLL84Eo8NZn6ovManxfLaFWL")
159159
160160 let ac = Address(base58'3PKkojKdd6BBzTf1RXbQVfUDraNFXXHKzQF')
161161
162162 let ad = getIntegerValue(ac, "%s%s__price__USDN-USDT")
163163
164164 func ae (af,ag,ah) = {
165165 let ai = toString(af)
166166 let aj = if (ah)
167167 then j(invoke(H, "withdrawAllVestedForTo", [ai, toString(this)], nil))
168168 else 0
169169 if ((aj == aj))
170170 then {
171171 let ak = if (ag)
172172 then throw("not implemented")
173173 else 0
174174 if ((ak == ak))
175175 then {
176176 let al = (ak + aj)
177177 let am = invoke(Z, "buySurf", [1000000, 1000000, false], [AttachedPayment(fromBase58String(J), al)])
178178 if ((am == am))
179179 then assetBalance(this, ab)
180180 else throw("Strict value is not equal to itself.")
181181 }
182182 else throw("Strict value is not equal to itself.")
183183 }
184184 else throw("Strict value is not equal to itself.")
185185 }
186186
187187
188188 let an = valueOrErrorMessage(getString(x, "primary_reserves"), "no reserves registered")
189189
190190 func ao (ap) = if (contains(an, ap))
191191 then valueOrErrorMessage(addressFromString(ap), "main: bad rsr")
192192 else throw(("unknown rsr:" + ap))
193193
194194
195195 func aq (ai,q,ar) = {
196196 let ap = ao(q)
197197 if ((ap == ap))
198198 then {
199199 let as = addressFromStringValue(q)
200200 let at = getStringValue(as, "assetId")
201201 let au = invoke(I, "startVestingAllFor", [ai], nil)
202202 if ((au == au))
203203 then {
204204 let av = Q("openCollateral", at)
205205 if ((av == av))
206206 then {
207207 let aw = j(invoke(as, "transferATokensAmountFor", [ai, G, ar], nil))
208208 if ((aw == aw))
209209 then {
210210 let ax = {
211211 let ay = getInteger(x, (q + "_to_vesting_value"))
212212 if (isDefined(ay))
213213 then fraction(aw, value(ay), a)
214214 else {
215215 let az = j(invoke(as, "toUSD", [aw], nil))
216216 fraction(az, 1000000, ad)
217217 }
218218 }
219219 let aA = {
220220 let aB = invoke(C, "withdrawToMain2", [G, J, ax], nil)
221221 if ((aB == aB))
222222 then {
223223 let aA = invoke(H, "accountFor", [ai], [AttachedPayment(fromBase58String(J), ax)])
224224 if ((aA == aA))
225225 then unit
226226 else throw("Strict value is not equal to itself.")
227227 }
228228 else throw("Strict value is not equal to itself.")
229229 }
230230 if ((aA == aA))
231231 then {
232232 let aC = l(invoke(D, "healthOf", [ai], nil))
233233 let aD = aC._1
234234 let aE = aC._2
235235 if ((aD > (100 * (aD - aE))))
236236 then throw("not enough address health after move: < 1%")
237237 else $Tuple2([v(((ai + "_migrated_") + at), aw)], ax)
238238 }
239239 else throw("Strict value is not equal to itself.")
240240 }
241241 else throw("Strict value is not equal to itself.")
242242 }
243243 else throw("Strict value is not equal to itself.")
244244 }
245245 else throw("Strict value is not equal to itself.")
246246 }
247247 else throw("Strict value is not equal to itself.")
248248 }
249249
250250
251+let aF = valueOrElse(getInteger(x, (toString(this) + "_mint_daily_global_limit")), 100000000000)
252+
253+let aG = (toString(fraction(A, 1, (60 * 24))) + "_mint_global_limit")
254+
255+let aH = valueOrElse(getInteger(aG), aF)
256+
257+let aI = valueOrElse(getInteger(x, (toString(this) + "_import_daily_global_limit")), 100000000000)
258+
259+let aJ = (toString(fraction(A, 1, (60 * 24))) + "_import_global_limit")
260+
261+let aK = valueOrElse(getInteger(aJ), aI)
262+
251263 @Callable(V)
252-func init (aF,n,aG,aH,aI,aJ,aK,aL,aM) = if ((V.caller != this))
264+func init (aL,n,aM,aN,aO,aP,aQ,aR,aS) = if ((V.caller != this))
253265 then throw("only self can init")
254- else [b(w, aF), b("usdtReserve", n), b("usdcReserve", aG), b("usdnVestingAll", aH), b("usdnVesting", aM), b("acc", aI), b("main1", aJ), b("usdnAssetId", aK), IntegerEntry("bonus", aL)]
266+ else [b(w, aL), b("usdtReserve", n), b("usdcReserve", aM), b("usdnVestingAll", aN), b("usdnVesting", aS), b("acc", aO), b("main1", aP), b("usdnAssetId", aQ), IntegerEntry("bonus", aR)]
255267
256268
257269
258270 @Callable(V)
259271 func startVestingFor (ai,q,ar) = {
260- let aN = U(V)
261- if ((aN == aN))
272+ let aT = U(V)
273+ if ((aT == aT))
262274 then aq(ai, q, ar)
263275 else throw("Strict value is not equal to itself.")
264276 }
265277
266278
267279
268280 @Callable(V)
269281 func startVesting (q,ar) = aq(toString(V.caller), q, ar)
270282
271283
272284
273285 @Callable(V)
274286 func convertToUSDN () = {
275287 let ai = toString(V.caller)
276- func aO (q) = {
288+ func aU (q) = {
277289 let as = addressFromStringValue(q)
278290 let at = getStringValue(as, "assetId")
279291 let av = Q("openCollateral", at)
280292 if ((av == av))
281293 then if (if ((q != toString(E)))
282294 then (q != toString(F))
283295 else false)
284296 then throw("invalid reserve")
285297 else {
286- let aP = invoke(B, "syncHeight", [q], nil)
287- if ((aP == aP))
298+ let aV = invoke(B, "syncHeight", [q], nil)
299+ if ((aV == aV))
288300 then {
289- let aQ = l(invoke(as, "storedDepositBorrow", nil, nil))
290- let aR = aQ._1
291- let aS = aQ._2
292- let aT = if ((aR > 0))
293- then min([a, fraction(aS, a, aR)])
301+ let aW = l(invoke(as, "storedDepositBorrow", nil, nil))
302+ let aX = aW._1
303+ let aY = aW._2
304+ let aZ = if ((aX > 0))
305+ then min([a, fraction(aY, a, aX)])
294306 else 0
295- let aU = valueOrElse(getInteger(x, (at + "_open_collateral_thresold")), 1000)
296- if ((aU > aT))
307+ let ba = valueOrElse(getInteger(x, (at + "_open_collateral_thresold")), 1000)
308+ if ((ba > aZ))
297309 then throw("not allowed: util < threshold")
298310 else {
299- let aV = j(invoke(as, "userDepositUSD", [ai], nil))
300- if ((aV == aV))
311+ let bb = j(invoke(as, "userDepositUSD", [ai], nil))
312+ if ((bb == bb))
301313 then {
302- let aw = j(invoke(as, "transferATokensFor", [ai, G, aV], nil))
314+ let aw = j(invoke(as, "transferATokensFor", [ai, G, bb], nil))
303315 if ((aw == aw))
304316 then {
305- let aW = L(q, "deposit", ai, G, aw)
306- if ((aW == aW))
317+ let bc = L(q, "deposit", ai, G, aw)
318+ if ((bc == bc))
307319 then aw
308320 else throw("Strict value is not equal to itself.")
309321 }
310322 else throw("Strict value is not equal to itself.")
311323 }
312324 else throw("Strict value is not equal to itself.")
313325 }
314326 }
315327 else throw("Strict value is not equal to itself.")
316328 }
317329 else throw("Strict value is not equal to itself.")
318330 }
319331
320332 let au = invoke(I, "startVestingAllFor", [toString(V.caller)], nil)
321333 if ((au == au))
322334 then {
323- let aX = j(aO(toString(E)))
324- if ((aX == aX))
335+ let bd = j(aU(toString(E)))
336+ if ((bd == bd))
325337 then {
326- let aY = j(aO(toString(F)))
327- if ((aY == aY))
338+ let be = j(aU(toString(F)))
339+ if ((be == be))
328340 then {
329- let aZ = (aX + aY)
341+ let bf = (bd + be)
330342 let aA = {
331- let ba = fraction(aZ, (a + K), a)
332- let aB = invoke(C, "withdrawToMain2", [G, J, ba], nil)
343+ let bg = fraction(bf, (a + K), a)
344+ let aB = invoke(C, "withdrawToMain2", [G, J, bg], nil)
333345 if ((aB == aB))
334346 then {
335- let aA = invoke(H, "accountFor", [ai], [AttachedPayment(fromBase58String(J), ba)])
347+ let aA = invoke(H, "accountFor", [ai], [AttachedPayment(fromBase58String(J), bg)])
336348 if ((aA == aA))
337349 then unit
338350 else throw("Strict value is not equal to itself.")
339351 }
340352 else throw("Strict value is not equal to itself.")
341353 }
342354 if ((aA == aA))
343355 then {
344- let bb = l(invoke(D, "healthOf", [ai], nil))
345- let aD = bb._1
346- let aE = bb._2
356+ let bh = l(invoke(D, "healthOf", [ai], nil))
357+ let aD = bh._1
358+ let aE = bh._2
347359 if ((aD > (100 * (aD - aE))))
348360 then throw("not enough address health after move: < 1%")
349- else [v(((ai + "_migrated_") + getStringValue(E, "assetId")), aX), v(((ai + "_migrated_") + getStringValue(F, "assetId")), aY)]
361+ else [v(((ai + "_migrated_") + getStringValue(E, "assetId")), bd), v(((ai + "_migrated_") + getStringValue(F, "assetId")), be)]
350362 }
351363 else throw("Strict value is not equal to itself.")
352364 }
353365 else throw("Strict value is not equal to itself.")
354366 }
355367 else throw("Strict value is not equal to itself.")
356368 }
357369 else throw("Strict value is not equal to itself.")
358370 }
359371
360372
361373
362374 @Callable(V)
363375 func withdrawVestedAllUSDN (ag,ah) = {
364376 let ai = toString(V.caller)
365377 let aj = if (ah)
366378 then j(invoke(H, "withdrawVestedForTo", [ai, ai], nil))
367379 else 0
368380 if ((aj == aj))
369381 then {
370382 let ak = if (ag)
371383 then j(invoke(I, "withdrawVestedForTo", [ai, ai], nil))
372384 else 0
373385 if ((ak == ak))
374386 then $Tuple2(nil, (ak + aj))
375387 else throw("Strict value is not equal to itself.")
376388 }
377389 else throw("Strict value is not equal to itself.")
378390 }
379391
380392
381393
382394 @Callable(V)
383395 func withdrawVestedAllSURF (ag,ah) = {
384396 let av = Q("liquidao_all_withdrawVestedAsSurf", toBase58String(ab))
385397 if ((av == av))
386398 then {
387- let bc = ae(V.caller, ag, ah)
388- if ((bc == bc))
389- then $Tuple2([ScriptTransfer(V.caller, bc, ab)], bc)
399+ let bi = ae(V.caller, ag, ah)
400+ if ((bi == bi))
401+ then $Tuple2([ScriptTransfer(V.caller, bi, ab)], bi)
390402 else throw("Strict value is not equal to itself.")
391403 }
392404 else throw("Strict value is not equal to itself.")
393405 }
394406
395407
396408
397409 @Callable(V)
398-func withdrawVestedSURF2 (ag,ah,bd) = {
410+func withdrawVestedSURF2 (ag,ah,bj) = {
399411 let ai = toString(V.caller)
400412 let av = Q("liquidao_all_withdrawVestedAsSurf", toBase58String(ab))
401413 if ((av == av))
402414 then {
403415 let aj = if ((ah > 0))
404416 then j(invoke(H, "partialWithdrawVestedForTo", [ai, toString(this), ah], nil))
405417 else 0
406418 if ((aj == aj))
407419 then {
408420 let ak = if ((ag > 0))
409421 then j(invoke(I, "partialWithdrawVestedForTo", [ai, toString(this), ag], nil))
410422 else 0
411423 if ((ak == ak))
412424 then {
413425 let al = (ak + aj)
414426 let am = invoke(Z, "buySurf", [1000000, 1000000, false], [AttachedPayment(fromBase58String(J), al)])
415427 if ((am == am))
416428 then {
417- let bc = assetBalance(this, ab)
418- if ((bc == bc))
419- then if (bd)
429+ let bi = assetBalance(this, ab)
430+ if ((bi == bi))
431+ then if (bj)
420432 then {
421- let be = invoke(aa, "stakeByOriginCaller", nil, [AttachedPayment(ab, bc)])
422- if ((be == be))
423- then $Tuple2(nil, bc)
433+ let bk = invoke(aa, "stakeByOriginCaller", nil, [AttachedPayment(ab, bi)])
434+ if ((bk == bk))
435+ then $Tuple2(nil, bi)
424436 else throw("Strict value is not equal to itself.")
425437 }
426- else $Tuple2([ScriptTransfer(V.caller, bc, ab)], bc)
438+ else $Tuple2([ScriptTransfer(V.caller, bi, ab)], bi)
427439 else throw("Strict value is not equal to itself.")
428440 }
429441 else throw("Strict value is not equal to itself.")
430442 }
431443 else throw("Strict value is not equal to itself.")
432444 }
433445 else throw("Strict value is not equal to itself.")
434446 }
435447 else throw("Strict value is not equal to itself.")
436448 }
437449
438450
439451
440452 @Callable(V)
441453 func withdrawVestedAllSURFAndStake (ag,ah) = {
442454 let av = Q("liquidao_all_withdrawVestedAsSurf", toBase58String(ab))
443455 if ((av == av))
444456 then {
445- let bc = ae(V.caller, ag, ah)
446- if ((bc == bc))
457+ let bi = ae(V.caller, ag, ah)
458+ if ((bi == bi))
447459 then {
448- let be = invoke(aa, "stakeByOriginCaller", nil, [AttachedPayment(ab, bc)])
449- if ((be == be))
450- then $Tuple2(nil, bc)
460+ let bk = invoke(aa, "stakeByOriginCaller", nil, [AttachedPayment(ab, bi)])
461+ if ((bk == bk))
462+ then $Tuple2(nil, bi)
451463 else throw("Strict value is not equal to itself.")
452464 }
453465 else throw("Strict value is not equal to itself.")
454466 }
455467 else throw("Strict value is not equal to itself.")
456468 }
457469
458470
459471
460472 @Callable(V)
461473 func withdrawAsLP (ag,ah) = {
462474 let ai = toString(V.caller)
463- let aj = if ((ah > 0))
464- then j(invoke(H, "partialWithdrawVestedForTo", [ai, toString(this), ah], nil))
465- else 0
466- if ((aj == aj))
467- then {
468- let ak = if ((ag > 0))
469- then j(invoke(I, "partialWithdrawVestedForTo", [ai, toString(this), ag], nil))
475+ if ((aH == 0))
476+ then throw(("Daily export limit: 0 of " + toString(aF)))
477+ else {
478+ let bl = if ((ah > aH))
479+ then $Tuple2(aH, 0)
480+ else if (((ag + ah) > aH))
481+ then $Tuple2(ah, (aH - ah))
482+ else $Tuple2(ah, ag)
483+ let bm = bl._1
484+ let bn = bl._2
485+ let aj = if ((bm > 0))
486+ then j(invoke(H, "partialWithdrawVestedForTo", [ai, toString(this), bm], nil))
470487 else 0
471- if ((ak == ak))
488+ if ((aj == aj))
472489 then {
473- let al = (ak + aj)
474- let bf = invoke(y, "mintTo", [ai], [AttachedPayment(fromBase58String(J), al)])
475- if ((bf == bf))
476- then $Tuple2(nil, al)
490+ let ak = if ((bn > 0))
491+ then j(invoke(I, "partialWithdrawVestedForTo", [ai, toString(this), bn], nil))
492+ else 0
493+ if ((ak == ak))
494+ then {
495+ let al = (ak + aj)
496+ let bo = invoke(y, "mintTo", [ai], [AttachedPayment(fromBase58String(J), al)])
497+ if ((bo == bo))
498+ then $Tuple2([v(aG, -(al))], al)
499+ else throw("Strict value is not equal to itself.")
500+ }
477501 else throw("Strict value is not equal to itself.")
478502 }
479503 else throw("Strict value is not equal to itself.")
480504 }
481- else throw("Strict value is not equal to itself.")
482505 }
483506
484507
485508
486509 @Callable(V)
487-func importLP () = {
488- let ai = toString(V.caller)
489- let ba = j(invoke(y, "import", nil, V.payments))
490- if ((ba == ba))
491- then {
492- let bg = invoke(H, "accountFor", [ai], [AttachedPayment(fromBase58String(J), ba)])
493- if ((bg == bg))
494- then $Tuple2(nil, ba)
495- else throw("Strict value is not equal to itself.")
496- }
497- else throw("Strict value is not equal to itself.")
498- }
510+func importLP () = if ((aK == 0))
511+ then throw(("Daily import limit: 0 of " + toString(aI)))
512+ else {
513+ let ai = toString(V.caller)
514+ let bp = V.payments[0].amount
515+ let bq = V.payments[0].assetId
516+ let br = if ((bp > aK))
517+ then $Tuple3(AttachedPayment(bq, aK), [ScriptTransfer(V.caller, (bp - aK), bq)], 0)
518+ else $Tuple3(V.payments[0], nil, (aK - bp))
519+ let bs = br._1
520+ let bt = br._2
521+ let bu = br._3
522+ let bg = j(invoke(y, "import", nil, [bs]))
523+ if ((bg == bg))
524+ then {
525+ let bv = invoke(H, "accountFor", [ai], [AttachedPayment(fromBase58String(J), bg)])
526+ if ((bv == bv))
527+ then $Tuple2(IntegerEntry(aJ, bu) :: bt, bg)
528+ else throw("Strict value is not equal to itself.")
529+ }
530+ else throw("Strict value is not equal to itself.")
531+ }
499532
500533
501-@Verifier(bh)
502-func bi () = {
503- let bj = 1000
504- let bk = valueOrErrorMessage(getInteger(x, "proposal_quorum_ratio"), "proposalQuorumRatio is not defined")
505- let bl = valueOrErrorMessage(getInteger(x, "proposal_passed_ratio"), "proposalThresholdRatio is not defined")
506- let bm = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(x, "dividends_contract"), "no dividends_contract")), "invalid dividends_contract")
507- let bn = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(x, "voting_contract"), "no voting_contract")), "invalid voting_contract")
508- let bo = toBase58String(bh.id)
509- let bp = valueOrElse(getInteger(bn, ("proposal_yes_" + bo)), 0)
510- let bq = valueOrElse(getInteger(bn, ("proposal_no_" + bo)), 0)
511- let br = valueOrErrorMessage(getInteger(bn, ("proposal_height_" + bo)), "proposal not registered")
512- let bs = valueOrElse(getInteger(bn, ("proposal_applystart_" + bo)), 0)
513- let bt = valueOrElse(getInteger(bn, ("proposal_applyend_" + bo)), 0)
514- let bu = valueOrElse(getInteger(bn, ("proposal_gvires_" + bo)), 0)
515- let bv = valueOrElse(getBoolean(x, "op_governance_apply_tx_paused"), false)
516- let bw = bp
517- let bx = bq
518- let by = (bw + bx)
519- let bz = (((by * bj) / bu) >= bk)
520- let bA = (((bw * bj) / by) >= bl)
521- let bB = (bs >= A)
522- let bC = (A >= bt)
523- let bD = ((((((("proposalHeight = " + toString(br)) + ", applyStart = ") + toString(bs)) + ", applyEnd = ") + toString(bt)) + ", HEIGHT = ") + toString(A))
524- let bE = if (!(bv))
534+@Verifier(bw)
535+func bx () = {
536+ let by = 1000
537+ let bz = valueOrErrorMessage(getInteger(x, "proposal_quorum_ratio"), "proposalQuorumRatio is not defined")
538+ let bA = valueOrErrorMessage(getInteger(x, "proposal_passed_ratio"), "proposalThresholdRatio is not defined")
539+ let bB = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(x, "dividends_contract"), "no dividends_contract")), "invalid dividends_contract")
540+ let bC = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(x, "voting_contract"), "no voting_contract")), "invalid voting_contract")
541+ let bD = toBase58String(bw.id)
542+ let bE = valueOrElse(getInteger(bC, ("proposal_yes_" + bD)), 0)
543+ let bF = valueOrElse(getInteger(bC, ("proposal_no_" + bD)), 0)
544+ let bG = valueOrErrorMessage(getInteger(bC, ("proposal_height_" + bD)), "proposal not registered")
545+ let bH = valueOrElse(getInteger(bC, ("proposal_applystart_" + bD)), 0)
546+ let bI = valueOrElse(getInteger(bC, ("proposal_applyend_" + bD)), 0)
547+ let bJ = valueOrElse(getInteger(bC, ("proposal_gvires_" + bD)), 0)
548+ let bK = valueOrElse(getBoolean(x, "op_governance_apply_tx_paused"), false)
549+ let bL = bE
550+ let bM = bF
551+ let bN = (bL + bM)
552+ let bO = (((bN * by) / bJ) >= bz)
553+ let bP = (((bL * by) / bN) >= bA)
554+ let bQ = (bH >= A)
555+ let bR = (A >= bI)
556+ let bS = ((((((("proposalHeight = " + toString(bG)) + ", applyStart = ") + toString(bH)) + ", applyEnd = ") + toString(bI)) + ", HEIGHT = ") + toString(A))
557+ let bT = if (!(bK))
525558 then throw("tx application throw governance not enabled")
526- else if (bB)
527- then throw(("proposal can't be executed as it's too early: " + bD))
528- else if (bC)
529- then throw(("proposal can't be executed as it's too late:" + bD))
530- else if (!(bz))
531- then throw((((((("no quorum: " + "totalVotes: ") + toString(by)) + ", totalGVires: ") + toString(bu)) + ", quorumRatio: ") + toString(bk)))
532- else if (!(bA))
533- then throw((((((("no threshold achieved: " + "voteYes: ") + toString(bw)) + ", voteNo: ") + toString(bx)) + ", passedRatio: ") + toString(bl)))
559+ else if (bQ)
560+ then throw(("proposal can't be executed as it's too early: " + bS))
561+ else if (bR)
562+ then throw(("proposal can't be executed as it's too late:" + bS))
563+ else if (!(bO))
564+ then throw((((((("no quorum: " + "totalVotes: ") + toString(bN)) + ", totalGVires: ") + toString(bJ)) + ", quorumRatio: ") + toString(bz)))
565+ else if (!(bP))
566+ then throw((((((("no threshold achieved: " + "voteYes: ") + toString(bL)) + ", voteNo: ") + toString(bM)) + ", passedRatio: ") + toString(bA)))
534567 else true
535- if (sigVerify(bh.bodyBytes, bh.proofs[0], bh.senderPublicKey))
568+ if (sigVerify(bw.bodyBytes, bw.proofs[0], bw.senderPublicKey))
536569 then true
537- else bE
570+ else bT
538571 }
539572

github/deemru/w8io/3ef1775 
180.20 ms