tx · BhPB81Ua2di7JWkyP5Nwxe4tqnDR1hnqkSorKmSdGn17

3PCbvPVQfSvVu88ip8Fm5YjwJhjEYk1Txhk:  -0.02100000 Waves

2024.02.11 12:49 [4037223] smart account 3PCbvPVQfSvVu88ip8Fm5YjwJhjEYk1Txhk > SELF 0.00000000 Waves

{ "type": 13, "id": "BhPB81Ua2di7JWkyP5Nwxe4tqnDR1hnqkSorKmSdGn17", "fee": 2100000, "feeAssetId": null, "timestamp": 1707644950934, "version": 1, "sender": "3PCbvPVQfSvVu88ip8Fm5YjwJhjEYk1Txhk", "senderPublicKey": "FwXAX9xcWiwbCejtdF8q1Nz8NpJqaVxXKnKK6JoR24pZ", "proofs": [ "2L1HphxbQzyFgpX8qB5vb8kU8eV1pmU78Tbdv4Rf8p9QLU6gG8ezo4oJsrPM8HMN9W7WFfGsvJ8R5wsyMmP9XMrq" ], "script": "base64:BgI/CAISCwoJCAgICAgICAEIEgUKAwgIARIECgIIARIAEgQKAgQEEgQKAgQEEgUKAwEBBBIECgIEBBIECgIBARIALgALZmFjdG9yc0Jhc2UA6AcBEHdyaXRlQ29uc3RTdHJpbmcCA2tleQV2YWx1ZQMJAQEhAQkBCWlzRGVmaW5lZAEJAJ0IAgUEdGhpcwUDa2V5CQELU3RyaW5nRW50cnkCBQNrZXkFBXZhbHVlCQACAQkArAICAhVhbHJlYWR5IGluaXRpYWxpemVkOiAFA2tleQENd3JpdGVDb25zdEludAIDa2V5BXZhbHVlAwkBASEBCQEJaXNEZWZpbmVkAQkAmggCBQR0aGlzBQNrZXkJAQxJbnRlZ2VyRW50cnkCBQNrZXkFBXZhbHVlCQACAQkArAICAhVhbHJlYWR5IGluaXRpYWxpemVkOiAFA2tleQEId3JpdGVJbnQCA2tleQV2YWx1ZQMJAGYCAAAFBXZhbHVlCQACAQkArAICCQCsAgIJAKwCAgIXd3JpdGluZyBuZWdhdGl2ZSB2YWx1ZSAJAKQDAQUFdmFsdWUCCSBmb3Iga2V5IAUDa2V5CQEMSW50ZWdlckVudHJ5AgUDa2V5BQV2YWx1ZQEIYXNTdHJpbmcBBXZhbHVlBAckbWF0Y2gwBQV2YWx1ZQMJAAECBQckbWF0Y2gwAgZTdHJpbmcEAXMFByRtYXRjaDAFAXMJAAIBAhx3cm9uZyB0eXBlLCBleHBlY3RlZDogU3RyaW5nAQVhc0ludAEFdmFsdWUEByRtYXRjaDAFBXZhbHVlAwkAAQIFByRtYXRjaDACA0ludAQDaW50BQckbWF0Y2gwBQNpbnQJAAIBAgRzbToxAQZhc0ludDIBBXZhbHVlBAckbWF0Y2gwBQV2YWx1ZQMJAAECBQckbWF0Y2gwAgooSW50LCBJbnQpBAF4BQckbWF0Y2gwBQF4BAF0BQckbWF0Y2gwCQACAQIad3JvbmcgdHlwZSwgZXhwZWN0ZWQ6IEludDIBEWFzVXNlckJhbGFuY2VEYXRhAQV2YWx1ZQQHJG1hdGNoMAUFdmFsdWUDCQABAgUHJG1hdGNoMAIiKEludCwgSW50LCBJbnQsIEludCwgSW50LCBCb29sZWFuKQQBeAUHJG1hdGNoMAUBeAQBdAUHJG1hdGNoMAkAAgECATMBC3VzZXJCYWxhbmNlAgNyc3IEdXNlcgkBEWFzVXNlckJhbGFuY2VEYXRhAQkA/AcEBQNyc3ICC3VzZXJCYWxhbmNlCQDMCAIFBHVzZXIFA25pbAUDbmlsAQd0aHJvd0lmAgljb25kaXRpb24FZXJyb3IDBQljb25kaXRpb24JAAIBBQVlcnJvcgYBCGNoYW5nZUJ5AgNrZXkFdmFsdWUJAQh3cml0ZUludAIFA2tleQkAZAIJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwUDa2V5AAAFBXZhbHVlAAtjb25maWdTdG9yZQIGY29uZmlnAA1jb25maWdBZGRyZXNzCQERQGV4dHJOYXRpdmUoMTA2MikBCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzBQtjb25maWdTdG9yZQAVdmlyZXNWZXN0ZWRVc2RuTHBEYXBwCQERQGV4dHJOYXRpdmUoMTA2MikBAiMzUEpGdThNbVZhMnJTVkdNNDh3ZExtNGpoTHpuRWd1NlhTZQASbWF5YmVPcmFjbGVBZGRyZXNzBAckbWF0Y2gwCQCdCAIFDWNvbmZpZ0FkZHJlc3MCDm9yYWNsZV9hZGRyZXNzAwkAAQIFByRtYXRjaDACBlN0cmluZwQBcwUHJG1hdGNoMAkApggBBQFzBQR1bml0AAZIRUlHSFQFBmhlaWdodAACdmQJARFAZXh0ck5hdGl2ZSgxMDYyKQEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQ1jb25maWdBZGRyZXNzAhF2aXJlc19kaXN0cmlidXRvcgIVYmFkIHZpcmVzIGRpc3RyaWJ1dG9yABBwcm90ZWN0ZWRSZXNlcnZlCQERQGV4dHJOYXRpdmUoMTA2MikBCQERQGV4dHJOYXRpdmUoMTA1MykCBQ1jb25maWdBZGRyZXNzAhFwcm90ZWN0ZWRfcmVzZXJ2ZQAFbWFpbjEJARFAZXh0ck5hdGl2ZSgxMDYyKQEJARFAZXh0ck5hdGl2ZSgxMDUzKQIFBHRoaXMCBW1haW4xAAt1c2R0UmVzZXJ2ZQkBEUBleHRyTmF0aXZlKDEwNjIpAQkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwILdXNkdFJlc2VydmUAC3VzZGNSZXNlcnZlCQERQGV4dHJOYXRpdmUoMTA2MikBCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzAgt1c2RjUmVzZXJ2ZQADYWNjCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzAgNhY2MADnVzZG5WZXN0aW5nQWxsCQERQGV4dHJOYXRpdmUoMTA2MikBCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzAg51c2RuVmVzdGluZ0FsbAALdXNkblZlc3RpbmcJARFAZXh0ck5hdGl2ZSgxMDYyKQEJARFAZXh0ck5hdGl2ZSgxMDUzKQIFBHRoaXMCC3VzZG5WZXN0aW5nAAt1c2RuQXNzZXRJZAkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwILdXNkbkFzc2V0SWQACXVzZG5Cb251cwkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwIFYm9udXMBCm1vdmVTdHJlYW0FA3JzcgZhY3Rpb24EZnJvbQZzdHJpbmcDYW10CQD8BwQFAnZkAgRtb3ZlCQDMCAIFA3JzcgkAzAgCBQZhY3Rpb24JAMwIAgUEZnJvbQkAzAgCBQZzdHJpbmcJAMwIAgUDYW10BQNuaWwFA25pbAEJb3BBbGxvd2VkAgJvcAphc3NldElkU3RyBAckbWF0Y2gwCQD8BwQFDWNvbmZpZ0FkZHJlc3MCCW9wQWxsb3dlZAkAzAgCBQphc3NldElkU3RyCQDMCAIFAm9wBQNuaWwFA25pbAMJAAECBQckbWF0Y2gwAgdCb29sZWFuBAFiBQckbWF0Y2gwAwUBYgYJAAIBAgtub3QgYWxsb3dlZAkAAgECIW9wQWxsb3dlZDogdW5leHBlY3RlZCByZXN1bHQgdHlwZQEIbWFpbk9ubHkBAWkDCQEIY29udGFpbnMCCQERQGV4dHJOYXRpdmUoMTA1MykCBQ1jb25maWdBZGRyZXNzAgRtYWluCQClCAEIBQFpBmNhbGxlcgYJAAIBAhBvbmx5IG1haW4gY2FuIGRvAQphZHZpc2VVc2VyAQNhY2MECWRhdGFXaGFsZQkBCGFzU3RyaW5nAQkA/AcEBQt1c2RuVmVzdGluZwIHYWR2aXNlVQkAzAgCBQNhY2MFA25pbAUDbmlsAwkAAAIFCWRhdGFXaGFsZQUJZGF0YVdoYWxlBAdkYXRhQWxsCQEIYXNTdHJpbmcBCQD8BwQFDnVzZG5WZXN0aW5nQWxsAgdhZHZpc2VVCQDMCAIFA2FjYwUDbmlsBQNuaWwDCQAAAgUHZGF0YUFsbAUHZGF0YUFsbAkArAICCQCsAgIFCWRhdGFXaGFsZQIDIHwgBQdkYXRhQWxsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAAtzdXJmQWRkcmVzcwkBEUBleHRyTmF0aXZlKDEwNjIpAQIjM1BHMnZNaEs1Q1Bxc0NEb2R2TEd6UTg0UWtvSFhDSjNvTlAAEHN1cmZTdGFrZUFkZHJlc3MJARFAZXh0ck5hdGl2ZSgxMDYyKQECIzNQQmlvdEZwcWpSTWtrZUZCY2NuUU5VWFVvcHk3S0ZlejVDAAtzdXJmQXNzZXRJZAkA2QQBAixBdDhENk5GRnBoZUNidktWbmpWb2VMTDg0RW84TlpuNm92TWFueGZMYUZXTAAGb3JhY2xlCQEHQWRkcmVzcwEBGgFXw4nuidFTWhQUZTvI/d/0hIb99hEAq5RYAAh4dG5QcmljZQkBEUBleHRyTmF0aXZlKDEwNTApAgUGb3JhY2xlAhYlcyVzX19wcmljZV9fVVNETi1VU0RUAQdidXlTdXJmAwZjYWxsZXIFd2hhbGUHcmVndWxhcgQHYWRkcmVzcwkApQgBBQZjYWxsZXIEB3JlZ1BhcnQDBQdyZWd1bGFyCQEFYXNJbnQBCQD8BwQFDnVzZG5WZXN0aW5nQWxsAhZ3aXRoZHJhd0FsbFZlc3RlZEZvclRvCQDMCAIFB2FkZHJlc3MJAMwIAgkApQgBBQR0aGlzBQNuaWwFA25pbAAAAwkAAAIFB3JlZ1BhcnQFB3JlZ1BhcnQECXdoYWxlUGFydAMFBXdoYWxlCQACAQIPbm90IGltcGxlbWVudGVkAAADCQAAAgUJd2hhbGVQYXJ0BQl3aGFsZVBhcnQEBXRvdGFsCQBkAgUJd2hhbGVQYXJ0BQdyZWdQYXJ0BANidXkJAPwHBAULc3VyZkFkZHJlc3MCB2J1eVN1cmYJAMwIAgDAhD0JAMwIAgDAhD0JAMwIAgcFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkA2QQBBQt1c2RuQXNzZXRJZAUFdG90YWwFA25pbAMJAAACBQNidXkFA2J1eQkA8AcCBQR0aGlzBQtzdXJmQXNzZXRJZAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgALcmVzZXJ2ZXNTdHIJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQ1jb25maWdBZGRyZXNzAhBwcmltYXJ5X3Jlc2VydmVzAhZubyByZXNlcnZlcyByZWdpc3RlcmVkAQN2bFIBAXIDCQEIY29udGFpbnMCBQtyZXNlcnZlc1N0cgUBcgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEFAXICDW1haW46IGJhZCByc3IJAAIBCQCsAgICDHVua25vd24gcnNyOgUBcgEXc3RhcnRWZXN0aW5nRm9ySW50ZXJuYWwDB2FkZHJlc3MDcnNyBmFtb3VudAQBcgkBA3ZsUgEFA3JzcgMJAAACBQFyBQFyBAdyZXNlcnZlCQERQGV4dHJOYXRpdmUoMTA2MikBBQNyc3IEB2Fzc2V0SWQJARFAZXh0ck5hdGl2ZSgxMDUzKQIFB3Jlc2VydmUCB2Fzc2V0SWQEAm13CQD8BwQFC3VzZG5WZXN0aW5nAhJzdGFydFZlc3RpbmdBbGxGb3IJAMwIAgUHYWRkcmVzcwUDbmlsBQNuaWwDCQAAAgUCbXcFAm13BAZjaGVja3MJAQlvcEFsbG93ZWQCAg5vcGVuQ29sbGF0ZXJhbAUHYXNzZXRJZAMJAAACBQZjaGVja3MFBmNoZWNrcwQCczMJAQVhc0ludAEJAPwHBAUHcmVzZXJ2ZQIYdHJhbnNmZXJBVG9rZW5zQW1vdW50Rm9yCQDMCAIFB2FkZHJlc3MJAMwIAgUDYWNjCQDMCAIFBmFtb3VudAUDbmlsBQNuaWwDCQAAAgUCczMFAnMzBAZ4dG5BbXQEEnJlc2VydmVWZXN0aW5nUmF0ZQkAmggCBQ1jb25maWdBZGRyZXNzCQCsAgIFA3JzcgIRX3RvX3Zlc3RpbmdfdmFsdWUDCQEJaXNEZWZpbmVkAQUScmVzZXJ2ZVZlc3RpbmdSYXRlCQBrAwUCczMJAQV2YWx1ZQEFEnJlc2VydmVWZXN0aW5nUmF0ZQULZmFjdG9yc0Jhc2UEA3VzZAkBBWFzSW50AQkA/AcEBQdyZXNlcnZlAgV0b1VTRAkAzAgCBQJzMwUDbmlsBQNuaWwJAGsDBQN1c2QAwIQ9BQh4dG5QcmljZQQFcmVoYWIEAndkCQD8BwQFEHByb3RlY3RlZFJlc2VydmUCD3dpdGhkcmF3VG9NYWluMgkAzAgCBQNhY2MJAMwIAgULdXNkbkFzc2V0SWQJAMwIAgUGeHRuQW10BQNuaWwFA25pbAMJAAACBQJ3ZAUCd2QEBXJlaGFiCQD8BwQFDnVzZG5WZXN0aW5nQWxsAgphY2NvdW50Rm9yCQDMCAIFB2FkZHJlc3MFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkA2QQBBQt1c2RuQXNzZXRJZAUGeHRuQW10BQNuaWwDCQAAAgUFcmVoYWIFBXJlaGFiBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAwkAAAIFBXJlaGFiBQVyZWhhYgQLJHQwNTg1MDU5MTIJAQZhc0ludDIBCQD8BwQFBW1haW4xAghoZWFsdGhPZgkAzAgCBQdhZGRyZXNzBQNuaWwFA25pbAQCYnAIBQskdDA1ODUwNTkxMgJfMQQDYnB1CAULJHQwNTg1MDU5MTICXzIDCQBmAgUCYnAJAGgCAGQJAGUCBQJicAUDYnB1CQACAQIqbm90IGVub3VnaCBhZGRyZXNzIGhlYWx0aCBhZnRlciBtb3ZlOiA8IDElCQCUCgIJAMwIAgkBCGNoYW5nZUJ5AgkArAICCQCsAgIFB2FkZHJlc3MCCl9taWdyYXRlZF8FB2Fzc2V0SWQFAnMzBQNuaWwFBnh0bkFtdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgAUbWludERhaWx5R2xvYmFsTGltaXQJAQt2YWx1ZU9yRWxzZQIJAJoIAgUNY29uZmlnQWRkcmVzcwkArAICCQClCAEFBHRoaXMCGF9taW50X2RhaWx5X2dsb2JhbF9saW1pdACA0NvD9AIAGW1pbnRUb2RheUdsb2JhbExpbWl0U3RvcmUJAKwCAgkApAMBCQBrAwUGSEVJR0hUAAEJAGgCADwAGAISX21pbnRfZ2xvYmFsX2xpbWl0ABRtaW50VG9kYXlHbG9iYWxMaW1pdAkBC3ZhbHVlT3JFbHNlAgkAnwgBBRltaW50VG9kYXlHbG9iYWxMaW1pdFN0b3JlBRRtaW50RGFpbHlHbG9iYWxMaW1pdAAWaW1wb3J0RGFpbHlHbG9iYWxMaW1pdAkBC3ZhbHVlT3JFbHNlAgkAmggCBQ1jb25maWdBZGRyZXNzCQCsAgIJAKUIAQUEdGhpcwIaX2ltcG9ydF9kYWlseV9nbG9iYWxfbGltaXQAgNDbw/QCABtpbXBvcnRUb2RheUdsb2JhbExpbWl0U3RvcmUJAKwCAgkApAMBCQBrAwUGSEVJR0hUAAEJAGgCADwAGAIUX2ltcG9ydF9nbG9iYWxfbGltaXQAFmltcG9ydFRvZGF5R2xvYmFsTGltaXQJAQt2YWx1ZU9yRWxzZQIJAJ8IAQUbaW1wb3J0VG9kYXlHbG9iYWxMaW1pdFN0b3JlBRZpbXBvcnREYWlseUdsb2JhbExpbWl0ACNpbXBvcnRFeHBvcnREYWlseUdsb2JhbExpbWl0RW5hYmxlZAkBC3ZhbHVlT3JFbHNlAgkAmwgCBQ1jb25maWdBZGRyZXNzCQCsAgIJAKUIAQUEdGhpcwIpX2ltcG9ydF9leHBvcnRfZGFpbHlfZ2xvYmFsX2xpbWl0X2VuYWJsZWQHCgFpAQRpbml0CQRjb25mAXQBYwh2ZXN0bkFsbAdhY2NvdW50BG1haW4JdXNkbkFzc2V0BWJvbnVzBXZlc3RuAwkBAiE9AggFAWkGY2FsbGVyBQR0aGlzCQACAQISb25seSBzZWxmIGNhbiBpbml0CQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgULY29uZmlnU3RvcmUFBGNvbmYJAMwIAgkBEHdyaXRlQ29uc3RTdHJpbmcCAgt1c2R0UmVzZXJ2ZQUBdAkAzAgCCQEQd3JpdGVDb25zdFN0cmluZwICC3VzZGNSZXNlcnZlBQFjCQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgIOdXNkblZlc3RpbmdBbGwFCHZlc3RuQWxsCQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgILdXNkblZlc3RpbmcFBXZlc3RuCQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgIDYWNjBQdhY2NvdW50CQDMCAIJARB3cml0ZUNvbnN0U3RyaW5nAgIFbWFpbjEFBG1haW4JAMwIAgkBEHdyaXRlQ29uc3RTdHJpbmcCAgt1c2RuQXNzZXRJZAUJdXNkbkFzc2V0CQDMCAIJAQxJbnRlZ2VyRW50cnkCAgVib251cwUFYm9udXMFA25pbAFpAQ9zdGFydFZlc3RpbmdGb3IDB2FkZHJlc3MDcnNyBmFtb3VudAQBbQkBCG1haW5Pbmx5AQUBaQMJAAACBQFtBQFtCQEXc3RhcnRWZXN0aW5nRm9ySW50ZXJuYWwDBQdhZGRyZXNzBQNyc3IFBmFtb3VudAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQxzdGFydFZlc3RpbmcCA3JzcgZhbW91bnQJARdzdGFydFZlc3RpbmdGb3JJbnRlcm5hbAMJAKUIAQgFAWkGY2FsbGVyBQNyc3IFBmFtb3VudAFpAQ1jb252ZXJ0VG9VU0ROAAQHYWRkcmVzcwkApQgBCAUBaQZjYWxsZXIKAQdtb3ZlUnNyAQNyc3IEB3Jlc2VydmUJARFAZXh0ck5hdGl2ZSgxMDYyKQEFA3JzcgQHYXNzZXRJZAkBEUBleHRyTmF0aXZlKDEwNTMpAgUHcmVzZXJ2ZQIHYXNzZXRJZAQGY2hlY2tzCQEJb3BBbGxvd2VkAgIOb3BlbkNvbGxhdGVyYWwFB2Fzc2V0SWQDCQAAAgUGY2hlY2tzBQZjaGVja3MDAwkBAiE9AgUDcnNyCQClCAEFC3VzZHRSZXNlcnZlCQECIT0CBQNyc3IJAKUIAQULdXNkY1Jlc2VydmUHCQACAQIPaW52YWxpZCByZXNlcnZlBANzaEMJAPwHBAUCdmQCCnN5bmNIZWlnaHQJAMwIAgUDcnNyBQNuaWwFA25pbAMJAAACBQNzaEMFA3NoQwQLJHQwODMwMjgzODYJAQZhc0ludDIBCQD8BwQFB3Jlc2VydmUCE3N0b3JlZERlcG9zaXRCb3Jyb3cFA25pbAUDbmlsBAx0b3RhbERlcG9zaXQIBQskdDA4MzAyODM4NgJfMQQJdG90YWxEZWJ0CAULJHQwODMwMjgzODYCXzIEBHV0aWwDCQBmAgUMdG90YWxEZXBvc2l0AAAJAJcDAQkAzAgCBQtmYWN0b3JzQmFzZQkAzAgCCQBrAwUJdG90YWxEZWJ0BQtmYWN0b3JzQmFzZQUMdG90YWxEZXBvc2l0BQNuaWwAAAQNdXRpbFRocmVzaG9sZAkBC3ZhbHVlT3JFbHNlAgkAmggCBQ1jb25maWdBZGRyZXNzCQCsAgIFB2Fzc2V0SWQCGV9vcGVuX2NvbGxhdGVyYWxfdGhyZXNvbGQA6AcDCQBmAgUNdXRpbFRocmVzaG9sZAUEdXRpbAkAAgECHW5vdCBhbGxvd2VkOiB1dGlsIDwgdGhyZXNob2xkBANkZXAJAQVhc0ludAEJAPwHBAUHcmVzZXJ2ZQIOdXNlckRlcG9zaXRVU0QJAMwIAgUHYWRkcmVzcwUDbmlsBQNuaWwDCQAAAgUDZGVwBQNkZXAEAnMzCQEFYXNJbnQBCQD8BwQFB3Jlc2VydmUCEnRyYW5zZmVyQVRva2Vuc0ZvcgkAzAgCBQdhZGRyZXNzCQDMCAIFA2FjYwkAzAgCBQNkZXAFA25pbAUDbmlsAwkAAAIFAnMzBQJzMwQEcFJ3MwkBCm1vdmVTdHJlYW0FBQNyc3ICB2RlcG9zaXQFB2FkZHJlc3MFA2FjYwUCczMDCQAAAgUEcFJ3MwUEcFJ3MwUCczMJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4EAm13CQD8BwQFC3VzZG5WZXN0aW5nAhJzdGFydFZlc3RpbmdBbGxGb3IJAMwIAgkApQgBCAUBaQZjYWxsZXIFA25pbAUDbmlsAwkAAAIFAm13BQJtdwQCbXQJAQVhc0ludAEJAQdtb3ZlUnNyAQkApQgBBQt1c2R0UmVzZXJ2ZQMJAAACBQJtdAUCbXQEAm1jCQEFYXNJbnQBCQEHbW92ZVJzcgEJAKUIAQULdXNkY1Jlc2VydmUDCQAAAgUCbWMFAm1jBAhkZXBUb3RhbAkAZAIFAm10BQJtYwQFcmVoYWIEB3VzZG5BbXQJAGsDBQhkZXBUb3RhbAkAZAIFC2ZhY3RvcnNCYXNlBQl1c2RuQm9udXMFC2ZhY3RvcnNCYXNlBAJ3ZAkA/AcEBRBwcm90ZWN0ZWRSZXNlcnZlAg93aXRoZHJhd1RvTWFpbjIJAMwIAgUDYWNjCQDMCAIFC3VzZG5Bc3NldElkCQDMCAIFB3VzZG5BbXQFA25pbAUDbmlsAwkAAAIFAndkBQJ3ZAQFcmVoYWIJAPwHBAUOdXNkblZlc3RpbmdBbGwCCmFjY291bnRGb3IJAMwIAgUHYWRkcmVzcwUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQDZBAEFC3VzZG5Bc3NldElkBQd1c2RuQW10BQNuaWwDCQAAAgUFcmVoYWIFBXJlaGFiBQR1bml0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAwkAAAIFBXJlaGFiBQVyZWhhYgQLJHQwOTU0MDk2MDIJAQZhc0ludDIBCQD8BwQFBW1haW4xAghoZWFsdGhPZgkAzAgCBQdhZGRyZXNzBQNuaWwFA25pbAQCYnAIBQskdDA5NTQwOTYwMgJfMQQDYnB1CAULJHQwOTU0MDk2MDICXzIDCQBmAgUCYnAJAGgCAGQJAGUCBQJicAUDYnB1CQACAQIqbm90IGVub3VnaCBhZGRyZXNzIGhlYWx0aCBhZnRlciBtb3ZlOiA8IDElCQDMCAIJAQhjaGFuZ2VCeQIJAKwCAgkArAICBQdhZGRyZXNzAgpfbWlncmF0ZWRfCQERQGV4dHJOYXRpdmUoMTA1MykCBQt1c2R0UmVzZXJ2ZQIHYXNzZXRJZAUCbXQJAMwIAgkBCGNoYW5nZUJ5AgkArAICCQCsAgIFB2FkZHJlc3MCCl9taWdyYXRlZF8JARFAZXh0ck5hdGl2ZSgxMDUzKQIFC3VzZGNSZXNlcnZlAgdhc3NldElkBQJtYwUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBFXdpdGhkcmF3VmVzdGVkQWxsVVNETgIFd2hhbGUHcmVndWxhcgQHYWRkcmVzcwkApQgBCAUBaQZjYWxsZXIEB3JlZ1BhcnQDBQdyZWd1bGFyCQEFYXNJbnQBCQD8BwQFDnVzZG5WZXN0aW5nQWxsAhN3aXRoZHJhd1Zlc3RlZEZvclRvCQDMCAIFB2FkZHJlc3MJAMwIAgUHYWRkcmVzcwUDbmlsBQNuaWwAAAMJAAACBQdyZWdQYXJ0BQdyZWdQYXJ0BAl3aGFsZVBhcnQDBQV3aGFsZQkBBWFzSW50AQkA/AcEBQt1c2RuVmVzdGluZwITd2l0aGRyYXdWZXN0ZWRGb3JUbwkAzAgCBQdhZGRyZXNzCQDMCAIFB2FkZHJlc3MFA25pbAUDbmlsAAADCQAAAgUJd2hhbGVQYXJ0BQl3aGFsZVBhcnQJAJQKAgUDbmlsCQBkAgUJd2hhbGVQYXJ0BQdyZWdQYXJ0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBFXdpdGhkcmF3VmVzdGVkQWxsU1VSRgIFd2hhbGUHcmVndWxhcgQGY2hlY2tzCQEJb3BBbGxvd2VkAgIhbGlxdWlkYW9fYWxsX3dpdGhkcmF3VmVzdGVkQXNTdXJmCQDYBAEFC3N1cmZBc3NldElkAwkAAAIFBmNoZWNrcwUGY2hlY2tzBAtzdXJmQmFsYW5jZQkBB2J1eVN1cmYDCAUBaQZjYWxsZXIFBXdoYWxlBQdyZWd1bGFyAwkAAAIFC3N1cmZCYWxhbmNlBQtzdXJmQmFsYW5jZQkAlAoCCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgULc3VyZkJhbGFuY2UFC3N1cmZBc3NldElkBQNuaWwFC3N1cmZCYWxhbmNlCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBE3dpdGhkcmF3VmVzdGVkU1VSRjIDBXdoYWxlB3JlZ3VsYXIFc3Rha2UEB2FkZHJlc3MJAKUIAQgFAWkGY2FsbGVyBAZjaGVja3MJAQlvcEFsbG93ZWQCAiFsaXF1aWRhb19hbGxfd2l0aGRyYXdWZXN0ZWRBc1N1cmYJANgEAQULc3VyZkFzc2V0SWQDCQAAAgUGY2hlY2tzBQZjaGVja3MEB3JlZ1BhcnQDCQBmAgUHcmVndWxhcgAACQEFYXNJbnQBCQD8BwQFDnVzZG5WZXN0aW5nQWxsAhpwYXJ0aWFsV2l0aGRyYXdWZXN0ZWRGb3JUbwkAzAgCBQdhZGRyZXNzCQDMCAIJAKUIAQUEdGhpcwkAzAgCBQdyZWd1bGFyBQNuaWwFA25pbAAAAwkAAAIFB3JlZ1BhcnQFB3JlZ1BhcnQECXdoYWxlUGFydAMJAGYCBQV3aGFsZQAACQEFYXNJbnQBCQD8BwQFC3VzZG5WZXN0aW5nAhpwYXJ0aWFsV2l0aGRyYXdWZXN0ZWRGb3JUbwkAzAgCBQdhZGRyZXNzCQDMCAIJAKUIAQUEdGhpcwkAzAgCBQV3aGFsZQUDbmlsBQNuaWwAAAMJAAACBQl3aGFsZVBhcnQFCXdoYWxlUGFydAQFdG90YWwJAGQCBQl3aGFsZVBhcnQFB3JlZ1BhcnQEA2J1eQkA/AcEBQtzdXJmQWRkcmVzcwIHYnV5U3VyZgkAzAgCAMCEPQkAzAgCAMCEPQkAzAgCBwUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQDZBAEFC3VzZG5Bc3NldElkBQV0b3RhbAUDbmlsAwkAAAIFA2J1eQUDYnV5BAtzdXJmQmFsYW5jZQkA8AcCBQR0aGlzBQtzdXJmQXNzZXRJZAMJAAACBQtzdXJmQmFsYW5jZQULc3VyZkJhbGFuY2UDBQVzdGFrZQQJc3Rha2VTdXJmCQD8BwQFEHN1cmZTdGFrZUFkZHJlc3MCE3N0YWtlQnlPcmlnaW5DYWxsZXIFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgULc3VyZkFzc2V0SWQFC3N1cmZCYWxhbmNlBQNuaWwDCQAAAgUJc3Rha2VTdXJmBQlzdGFrZVN1cmYJAJQKAgUDbmlsBQtzdXJmQmFsYW5jZQkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAlAoCCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgULc3VyZkJhbGFuY2UFC3N1cmZBc3NldElkBQNuaWwFC3N1cmZCYWxhbmNlCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBHXdpdGhkcmF3VmVzdGVkQWxsU1VSRkFuZFN0YWtlAgV3aGFsZQdyZWd1bGFyBAZjaGVja3MJAQlvcEFsbG93ZWQCAiFsaXF1aWRhb19hbGxfd2l0aGRyYXdWZXN0ZWRBc1N1cmYJANgEAQULc3VyZkFzc2V0SWQDCQAAAgUGY2hlY2tzBQZjaGVja3MEC3N1cmZCYWxhbmNlCQEHYnV5U3VyZgMIBQFpBmNhbGxlcgUFd2hhbGUFB3JlZ3VsYXIDCQAAAgULc3VyZkJhbGFuY2UFC3N1cmZCYWxhbmNlBAlzdGFrZVN1cmYJAPwHBAUQc3VyZlN0YWtlQWRkcmVzcwITc3Rha2VCeU9yaWdpbkNhbGxlcgUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQtzdXJmQXNzZXRJZAULc3VyZkJhbGFuY2UFA25pbAMJAAACBQlzdGFrZVN1cmYFCXN0YWtlU3VyZgkAlAoCBQNuaWwFC3N1cmZCYWxhbmNlCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBDHdpdGhkcmF3QXNMUAIFd2hhbGUHcmVndWxhcgQHYWRkcmVzcwkApQgBCAUBaQZjYWxsZXIDAwUjaW1wb3J0RXhwb3J0RGFpbHlHbG9iYWxMaW1pdEVuYWJsZWQJAGcCAAAFFG1pbnRUb2RheUdsb2JhbExpbWl0BwkAAgEJAKwCAgIZRGFpbHkgZXhwb3J0IGxpbWl0OiAwIG9mIAkApAMBBRRtaW50RGFpbHlHbG9iYWxMaW1pdAQNJHQwMTIyNzUxMjYwNwMDBSNpbXBvcnRFeHBvcnREYWlseUdsb2JhbExpbWl0RW5hYmxlZAkAZgIFB3JlZ3VsYXIFFG1pbnRUb2RheUdsb2JhbExpbWl0BwkAlAoCBRRtaW50VG9kYXlHbG9iYWxMaW1pdAAAAwMFI2ltcG9ydEV4cG9ydERhaWx5R2xvYmFsTGltaXRFbmFibGVkCQBmAgkAZAIFBXdoYWxlBQdyZWd1bGFyBRRtaW50VG9kYXlHbG9iYWxMaW1pdAcJAJQKAgUHcmVndWxhcgkAZQIFFG1pbnRUb2RheUdsb2JhbExpbWl0BQdyZWd1bGFyCQCUCgIFB3JlZ3VsYXIFBXdoYWxlBApyZWd1bGFyQW10CAUNJHQwMTIyNzUxMjYwNwJfMQQId2hhbGVBbXQIBQ0kdDAxMjI3NTEyNjA3Al8yBAdyZWdQYXJ0AwkAZgIFCnJlZ3VsYXJBbXQAAAkBBWFzSW50AQkA/AcEBQ51c2RuVmVzdGluZ0FsbAIacGFydGlhbFdpdGhkcmF3VmVzdGVkRm9yVG8JAMwIAgUHYWRkcmVzcwkAzAgCCQClCAEFBHRoaXMJAMwIAgUKcmVndWxhckFtdAUDbmlsBQNuaWwAAAMJAAACBQdyZWdQYXJ0BQdyZWdQYXJ0BAl3aGFsZVBhcnQDCQBmAgUId2hhbGVBbXQAAAkBBWFzSW50AQkA/AcEBQt1c2RuVmVzdGluZwIacGFydGlhbFdpdGhkcmF3VmVzdGVkRm9yVG8JAMwIAgUHYWRkcmVzcwkAzAgCCQClCAEFBHRoaXMJAMwIAgUId2hhbGVBbXQFA25pbAUDbmlsAAADCQAAAgUJd2hhbGVQYXJ0BQl3aGFsZVBhcnQEBXRvdGFsCQBkAgUJd2hhbGVQYXJ0BQdyZWdQYXJ0BAhuZXdMaW1pdAkAZQIFFG1pbnRUb2RheUdsb2JhbExpbWl0BQV0b3RhbAMDBSNpbXBvcnRFeHBvcnREYWlseUdsb2JhbExpbWl0RW5hYmxlZAkAZgIAAAUIbmV3TGltaXQHCQACAQIObmVnYXRpdmUgbGltaXQEBHRvTHAJAPwHBAUVdmlyZXNWZXN0ZWRVc2RuTHBEYXBwAgZtaW50VG8JAMwIAgUHYWRkcmVzcwUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQDZBAEFC3VzZG5Bc3NldElkBQV0b3RhbAUDbmlsAwkAAAIFBHRvTHAFBHRvTHAJAJQKAgkAzAgCCQEMSW50ZWdlckVudHJ5AgUZbWludFRvZGF5R2xvYmFsTGltaXRTdG9yZQUIbmV3TGltaXQFA25pbAUFdG90YWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEIaW1wb3J0TFAAAwMFI2ltcG9ydEV4cG9ydERhaWx5R2xvYmFsTGltaXRFbmFibGVkCQBnAgAABRZpbXBvcnRUb2RheUdsb2JhbExpbWl0BwkAAgEJAKwCAgIZRGFpbHkgaW1wb3J0IGxpbWl0OiAwIG9mIAkApAMBBRZpbXBvcnREYWlseUdsb2JhbExpbWl0BAdhZGRyZXNzCQClCAEIBQFpBmNhbGxlcgQKcGF5bWVudEFtdAgJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQECWxwQXNzZXRJZAgJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkBA0kdDAxMzYzMTE0MDI4AwMFI2ltcG9ydEV4cG9ydERhaWx5R2xvYmFsTGltaXRFbmFibGVkCQBmAgUKcGF5bWVudEFtdAUWaW1wb3J0VG9kYXlHbG9iYWxMaW1pdAcJAJUKAwkBD0F0dGFjaGVkUGF5bWVudAIFCWxwQXNzZXRJZAUWaW1wb3J0VG9kYXlHbG9iYWxMaW1pdAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIJAGUCBQpwYXltZW50QW10BRZpbXBvcnRUb2RheUdsb2JhbExpbWl0BQlscEFzc2V0SWQFA25pbAAACQCVCgMJAJEDAggFAWkIcGF5bWVudHMAAAUDbmlsCQBlAgUWaW1wb3J0VG9kYXlHbG9iYWxMaW1pdAUKcGF5bWVudEFtdAQHcGF5bWVudAgFDSR0MDEzNjMxMTQwMjgCXzEEBmNoYW5nZQgFDSR0MDEzNjMxMTQwMjgCXzIECG5ld0xpbWl0CAUNJHQwMTM2MzExNDAyOAJfMwQHdXNkbkFtdAkBBWFzSW50AQkA/AcEBRV2aXJlc1Zlc3RlZFVzZG5McERhcHACBmltcG9ydAUDbmlsCQDMCAIFB3BheW1lbnQFA25pbAMJAAACBQd1c2RuQW10BQd1c2RuQW10BAphY2NvdW50Rm9yCQD8BwQFDnVzZG5WZXN0aW5nQWxsAgphY2NvdW50Rm9yCQDMCAIFB2FkZHJlc3MFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkA2QQBBQt1c2RuQXNzZXRJZAUHdXNkbkFtdAUDbmlsAwkAAAIFCmFjY291bnRGb3IFCmFjY291bnRGb3IJAJQKAgkAzAgCCQEMSW50ZWdlckVudHJ5AgUbaW1wb3J0VG9kYXlHbG9iYWxMaW1pdFN0b3JlBQhuZXdMaW1pdAUGY2hhbmdlBQd1c2RuQW10CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQJ0eAEGdmVyaWZ5AAQEQkFTRQDoBwQLcXVvcnVtUmF0aW8JARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQ1jb25maWdBZGRyZXNzAhVwcm9wb3NhbF9xdW9ydW1fcmF0aW8CInByb3Bvc2FsUXVvcnVtUmF0aW8gaXMgbm90IGRlZmluZWQEC3Bhc3NlZFJhdGlvCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUNY29uZmlnQWRkcmVzcwIVcHJvcG9zYWxfcGFzc2VkX3JhdGlvAiVwcm9wb3NhbFRocmVzaG9sZFJhdGlvIGlzIG5vdCBkZWZpbmVkBA5nVmlyZXNDb250cmFjdAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQ1jb25maWdBZGRyZXNzAhJkaXZpZGVuZHNfY29udHJhY3QCFW5vIGRpdmlkZW5kc19jb250cmFjdAIaaW52YWxpZCBkaXZpZGVuZHNfY29udHJhY3QEDnZvdGluZ0NvbnRyYWN0CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFDWNvbmZpZ0FkZHJlc3MCD3ZvdGluZ19jb250cmFjdAISbm8gdm90aW5nX2NvbnRyYWN0AhdpbnZhbGlkIHZvdGluZ19jb250cmFjdAQCaWQJANgEAQgFAnR4AmlkBAh2b3Rlc1llcwkBC3ZhbHVlT3JFbHNlAgkAmggCBQ52b3RpbmdDb250cmFjdAkArAICAg1wcm9wb3NhbF95ZXNfBQJpZAAABAd2b3Rlc05vCQELdmFsdWVPckVsc2UCCQCaCAIFDnZvdGluZ0NvbnRyYWN0CQCsAgICDHByb3Bvc2FsX25vXwUCaWQAAAQOcHJvcG9zYWxIZWlnaHQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQ52b3RpbmdDb250cmFjdAkArAICAhBwcm9wb3NhbF9oZWlnaHRfBQJpZAIXcHJvcG9zYWwgbm90IHJlZ2lzdGVyZWQECmFwcGx5U3RhcnQJAQt2YWx1ZU9yRWxzZQIJAJoIAgUOdm90aW5nQ29udHJhY3QJAKwCAgIUcHJvcG9zYWxfYXBwbHlzdGFydF8FAmlkAAAECGFwcGx5RW5kCQELdmFsdWVPckVsc2UCCQCaCAIFDnZvdGluZ0NvbnRyYWN0CQCsAgICEnByb3Bvc2FsX2FwcGx5ZW5kXwUCaWQAAAQLdG90YWxHVmlyZXMJAQt2YWx1ZU9yRWxzZQIJAJoIAgUOdm90aW5nQ29udHJhY3QJAKwCAgIQcHJvcG9zYWxfZ3ZpcmVzXwUCaWQAAAQHZW5hYmxlZAkBC3ZhbHVlT3JFbHNlAgkAmwgCBQ1jb25maWdBZGRyZXNzAh1vcF9nb3Zlcm5hbmNlX2FwcGx5X3R4X3BhdXNlZAcEB3ZvdGVZZXMFCHZvdGVzWWVzBAZ2b3RlTm8FB3ZvdGVzTm8ECnRvdGFsVm90ZXMJAGQCBQd2b3RlWWVzBQZ2b3RlTm8ECWhhc1F1b3J1bQkAZwIJAGkCCQBoAgUKdG90YWxWb3RlcwUEQkFTRQULdG90YWxHVmlyZXMFC3F1b3J1bVJhdGlvBAloYXNQYXNzZWQJAGcCCQBpAgkAaAIFB3ZvdGVZZXMFBEJBU0UFCnRvdGFsVm90ZXMFC3Bhc3NlZFJhdGlvBAh0b29FYXJseQkAZwIFCmFwcGx5U3RhcnQFBkhFSUdIVAQHdG9vTGF0ZQkAZwIFBkhFSUdIVAUIYXBwbHlFbmQECXRpbWVEZWJ1ZwkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAhFwcm9wb3NhbEhlaWdodCA9IAkApAMBBQ5wcm9wb3NhbEhlaWdodAIPLCBhcHBseVN0YXJ0ID0gCQCkAwEFCmFwcGx5U3RhcnQCDSwgYXBwbHlFbmQgPSAJAKQDAQUIYXBwbHlFbmQCCywgSEVJR0hUID0gCQCkAwEFBkhFSUdIVAQIYnlWb3RpbmcDCQEBIQEFB2VuYWJsZWQJAAIBAit0eCBhcHBsaWNhdGlvbiB0aHJvdyBnb3Zlcm5hbmNlIG5vdCBlbmFibGVkAwUIdG9vRWFybHkJAAIBCQCsAgICLnByb3Bvc2FsIGNhbid0IGJlIGV4ZWN1dGVkIGFzIGl0J3MgdG9vIGVhcmx5OiAFCXRpbWVEZWJ1ZwMFB3Rvb0xhdGUJAAIBCQCsAgICLHByb3Bvc2FsIGNhbid0IGJlIGV4ZWN1dGVkIGFzIGl0J3MgdG9vIGxhdGU6BQl0aW1lRGVidWcDCQEBIQEFCWhhc1F1b3J1bQkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICC25vIHF1b3J1bTogAgx0b3RhbFZvdGVzOiAJAKQDAQUKdG90YWxWb3RlcwIPLCB0b3RhbEdWaXJlczogCQCkAwEFC3RvdGFsR1ZpcmVzAg8sIHF1b3J1bVJhdGlvOiAJAKQDAQULcXVvcnVtUmF0aW8DCQEBIQEFCWhhc1Bhc3NlZAkAAgEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICF25vIHRocmVzaG9sZCBhY2hpZXZlZDogAgl2b3RlWWVzOiAJAKQDAQUHdm90ZVllcwIKLCB2b3RlTm86IAkApAMBBQZ2b3RlTm8CDywgcGFzc2VkUmF0aW86IAkApAMBBQtwYXNzZWRSYXRpbwYDCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAACAUCdHgPc2VuZGVyUHVibGljS2V5BgUIYnlWb3RpbmddAAU1", "chainId": 87, "height": 4037223, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: Dgza1RW2FAv26mhq6tGA7uwpct91thdQQfAeSYvJ5B2D Next: none Diff:
OldNewDifferences
260260
261261 let aK = valueOrElse(getInteger(aJ), aI)
262262
263+let aL = valueOrElse(getBoolean(x, (toString(this) + "_import_export_daily_global_limit_enabled")), false)
264+
263265 @Callable(V)
264-func init (aL,n,aM,aN,aO,aP,aQ,aR,aS) = if ((V.caller != this))
266+func init (aM,n,aN,aO,aP,aQ,aR,aS,aT) = if ((V.caller != this))
265267 then throw("only self can init")
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)]
268+ else [b(w, aM), b("usdtReserve", n), b("usdcReserve", aN), b("usdnVestingAll", aO), b("usdnVesting", aT), b("acc", aP), b("main1", aQ), b("usdnAssetId", aR), IntegerEntry("bonus", aS)]
267269
268270
269271
270272 @Callable(V)
271273 func startVestingFor (ai,q,ar) = {
272- let aT = U(V)
273- if ((aT == aT))
274+ let aU = U(V)
275+ if ((aU == aU))
274276 then aq(ai, q, ar)
275277 else throw("Strict value is not equal to itself.")
276278 }
285287 @Callable(V)
286288 func convertToUSDN () = {
287289 let ai = toString(V.caller)
288- func aU (q) = {
290+ func aV (q) = {
289291 let as = addressFromStringValue(q)
290292 let at = getStringValue(as, "assetId")
291293 let av = Q("openCollateral", at)
295297 else false)
296298 then throw("invalid reserve")
297299 else {
298- let aV = invoke(B, "syncHeight", [q], nil)
299- if ((aV == aV))
300+ let aW = invoke(B, "syncHeight", [q], nil)
301+ if ((aW == aW))
300302 then {
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)])
303+ let aX = l(invoke(as, "storedDepositBorrow", nil, nil))
304+ let aY = aX._1
305+ let aZ = aX._2
306+ let ba = if ((aY > 0))
307+ then min([a, fraction(aZ, a, aY)])
306308 else 0
307- let ba = valueOrElse(getInteger(x, (at + "_open_collateral_thresold")), 1000)
308- if ((ba > aZ))
309+ let bb = valueOrElse(getInteger(x, (at + "_open_collateral_thresold")), 1000)
310+ if ((bb > ba))
309311 then throw("not allowed: util < threshold")
310312 else {
311- let bb = j(invoke(as, "userDepositUSD", [ai], nil))
312- if ((bb == bb))
313+ let bc = j(invoke(as, "userDepositUSD", [ai], nil))
314+ if ((bc == bc))
313315 then {
314- let aw = j(invoke(as, "transferATokensFor", [ai, G, bb], nil))
316+ let aw = j(invoke(as, "transferATokensFor", [ai, G, bc], nil))
315317 if ((aw == aw))
316318 then {
317- let bc = L(q, "deposit", ai, G, aw)
318- if ((bc == bc))
319+ let bd = L(q, "deposit", ai, G, aw)
320+ if ((bd == bd))
319321 then aw
320322 else throw("Strict value is not equal to itself.")
321323 }
332334 let au = invoke(I, "startVestingAllFor", [toString(V.caller)], nil)
333335 if ((au == au))
334336 then {
335- let bd = j(aU(toString(E)))
336- if ((bd == bd))
337+ let be = j(aV(toString(E)))
338+ if ((be == be))
337339 then {
338- let be = j(aU(toString(F)))
339- if ((be == be))
340+ let bf = j(aV(toString(F)))
341+ if ((bf == bf))
340342 then {
341- let bf = (bd + be)
343+ let bg = (be + bf)
342344 let aA = {
343- let bg = fraction(bf, (a + K), a)
344- let aB = invoke(C, "withdrawToMain2", [G, J, bg], nil)
345+ let bh = fraction(bg, (a + K), a)
346+ let aB = invoke(C, "withdrawToMain2", [G, J, bh], nil)
345347 if ((aB == aB))
346348 then {
347- let aA = invoke(H, "accountFor", [ai], [AttachedPayment(fromBase58String(J), bg)])
349+ let aA = invoke(H, "accountFor", [ai], [AttachedPayment(fromBase58String(J), bh)])
348350 if ((aA == aA))
349351 then unit
350352 else throw("Strict value is not equal to itself.")
353355 }
354356 if ((aA == aA))
355357 then {
356- let bh = l(invoke(D, "healthOf", [ai], nil))
357- let aD = bh._1
358- let aE = bh._2
358+ let bi = l(invoke(D, "healthOf", [ai], nil))
359+ let aD = bi._1
360+ let aE = bi._2
359361 if ((aD > (100 * (aD - aE))))
360362 then throw("not enough address health after move: < 1%")
361- else [v(((ai + "_migrated_") + getStringValue(E, "assetId")), bd), v(((ai + "_migrated_") + getStringValue(F, "assetId")), be)]
363+ else [v(((ai + "_migrated_") + getStringValue(E, "assetId")), be), v(((ai + "_migrated_") + getStringValue(F, "assetId")), bf)]
362364 }
363365 else throw("Strict value is not equal to itself.")
364366 }
396398 let av = Q("liquidao_all_withdrawVestedAsSurf", toBase58String(ab))
397399 if ((av == av))
398400 then {
399- let bi = ae(V.caller, ag, ah)
400- if ((bi == bi))
401- then $Tuple2([ScriptTransfer(V.caller, bi, ab)], bi)
401+ let bj = ae(V.caller, ag, ah)
402+ if ((bj == bj))
403+ then $Tuple2([ScriptTransfer(V.caller, bj, ab)], bj)
402404 else throw("Strict value is not equal to itself.")
403405 }
404406 else throw("Strict value is not equal to itself.")
407409
408410
409411 @Callable(V)
410-func withdrawVestedSURF2 (ag,ah,bj) = {
412+func withdrawVestedSURF2 (ag,ah,bk) = {
411413 let ai = toString(V.caller)
412414 let av = Q("liquidao_all_withdrawVestedAsSurf", toBase58String(ab))
413415 if ((av == av))
426428 let am = invoke(Z, "buySurf", [1000000, 1000000, false], [AttachedPayment(fromBase58String(J), al)])
427429 if ((am == am))
428430 then {
429- let bi = assetBalance(this, ab)
430- if ((bi == bi))
431- then if (bj)
431+ let bj = assetBalance(this, ab)
432+ if ((bj == bj))
433+ then if (bk)
432434 then {
433- let bk = invoke(aa, "stakeByOriginCaller", nil, [AttachedPayment(ab, bi)])
434- if ((bk == bk))
435- then $Tuple2(nil, bi)
435+ let bl = invoke(aa, "stakeByOriginCaller", nil, [AttachedPayment(ab, bj)])
436+ if ((bl == bl))
437+ then $Tuple2(nil, bj)
436438 else throw("Strict value is not equal to itself.")
437439 }
438- else $Tuple2([ScriptTransfer(V.caller, bi, ab)], bi)
440+ else $Tuple2([ScriptTransfer(V.caller, bj, ab)], bj)
439441 else throw("Strict value is not equal to itself.")
440442 }
441443 else throw("Strict value is not equal to itself.")
454456 let av = Q("liquidao_all_withdrawVestedAsSurf", toBase58String(ab))
455457 if ((av == av))
456458 then {
457- let bi = ae(V.caller, ag, ah)
458- if ((bi == bi))
459+ let bj = ae(V.caller, ag, ah)
460+ if ((bj == bj))
459461 then {
460- let bk = invoke(aa, "stakeByOriginCaller", nil, [AttachedPayment(ab, bi)])
461- if ((bk == bk))
462- then $Tuple2(nil, bi)
462+ let bl = invoke(aa, "stakeByOriginCaller", nil, [AttachedPayment(ab, bj)])
463+ if ((bl == bl))
464+ then $Tuple2(nil, bj)
463465 else throw("Strict value is not equal to itself.")
464466 }
465467 else throw("Strict value is not equal to itself.")
472474 @Callable(V)
473475 func withdrawAsLP (ag,ah) = {
474476 let ai = toString(V.caller)
475- if ((0 >= aH))
477+ if (if (aL)
478+ then (0 >= aH)
479+ else false)
476480 then throw(("Daily export limit: 0 of " + toString(aF)))
477481 else {
478- let bl = if ((ah > aH))
482+ let bm = if (if (aL)
483+ then (ah > aH)
484+ else false)
479485 then $Tuple2(aH, 0)
480- else if (((ag + ah) > aH))
486+ else if (if (aL)
487+ then ((ag + ah) > aH)
488+ else false)
481489 then $Tuple2(ah, (aH - ah))
482490 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))
491+ let bn = bm._1
492+ let bo = bm._2
493+ let aj = if ((bn > 0))
494+ then j(invoke(H, "partialWithdrawVestedForTo", [ai, toString(this), bn], nil))
487495 else 0
488496 if ((aj == aj))
489497 then {
490- let ak = if ((bn > 0))
491- then j(invoke(I, "partialWithdrawVestedForTo", [ai, toString(this), bn], nil))
498+ let ak = if ((bo > 0))
499+ then j(invoke(I, "partialWithdrawVestedForTo", [ai, toString(this), bo], nil))
492500 else 0
493501 if ((ak == ak))
494502 then {
495503 let al = (ak + aj)
496- let bo = (aH - al)
497- if ((0 > bo))
504+ let bp = (aH - al)
505+ if (if (aL)
506+ then (0 > bp)
507+ else false)
498508 then throw("negative limit")
499509 else {
500- let bp = invoke(y, "mintTo", [ai], [AttachedPayment(fromBase58String(J), al)])
501- if ((bp == bp))
502- then $Tuple2([IntegerEntry(aG, bo)], al)
510+ let bq = invoke(y, "mintTo", [ai], [AttachedPayment(fromBase58String(J), al)])
511+ if ((bq == bq))
512+ then $Tuple2([IntegerEntry(aG, bp)], al)
503513 else throw("Strict value is not equal to itself.")
504514 }
505515 }
512522
513523
514524 @Callable(V)
515-func importLP () = if ((aK == 0))
525+func importLP () = if (if (aL)
526+ then (0 >= aK)
527+ else false)
516528 then throw(("Daily import limit: 0 of " + toString(aI)))
517529 else {
518530 let ai = toString(V.caller)
519- let bq = V.payments[0].amount
520- let br = V.payments[0].assetId
521- let bs = if ((bq > aK))
522- then $Tuple3(AttachedPayment(br, aK), [ScriptTransfer(V.caller, (bq - aK), br)], 0)
523- else $Tuple3(V.payments[0], nil, (aK - bq))
524- let bt = bs._1
525- let bu = bs._2
526- let bo = bs._3
527- let bg = j(invoke(y, "import", nil, [bt]))
528- if ((bg == bg))
531+ let br = V.payments[0].amount
532+ let bs = V.payments[0].assetId
533+ let bt = if (if (aL)
534+ then (br > aK)
535+ else false)
536+ then $Tuple3(AttachedPayment(bs, aK), [ScriptTransfer(V.caller, (br - aK), bs)], 0)
537+ else $Tuple3(V.payments[0], nil, (aK - br))
538+ let bu = bt._1
539+ let bv = bt._2
540+ let bp = bt._3
541+ let bh = j(invoke(y, "import", nil, [bu]))
542+ if ((bh == bh))
529543 then {
530- let bv = invoke(H, "accountFor", [ai], [AttachedPayment(fromBase58String(J), bg)])
531- if ((bv == bv))
532- then $Tuple2(IntegerEntry(aJ, bo) :: bu, bg)
544+ let bw = invoke(H, "accountFor", [ai], [AttachedPayment(fromBase58String(J), bh)])
545+ if ((bw == bw))
546+ then $Tuple2(IntegerEntry(aJ, bp) :: bv, bh)
533547 else throw("Strict value is not equal to itself.")
534548 }
535549 else throw("Strict value is not equal to itself.")
536550 }
537551
538552
539-@Verifier(bw)
540-func bx () = {
541- let by = 1000
542- let bz = valueOrErrorMessage(getInteger(x, "proposal_quorum_ratio"), "proposalQuorumRatio is not defined")
543- let bA = valueOrErrorMessage(getInteger(x, "proposal_passed_ratio"), "proposalThresholdRatio is not defined")
544- let bB = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(x, "dividends_contract"), "no dividends_contract")), "invalid dividends_contract")
545- let bC = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(x, "voting_contract"), "no voting_contract")), "invalid voting_contract")
546- let bD = toBase58String(bw.id)
547- let bE = valueOrElse(getInteger(bC, ("proposal_yes_" + bD)), 0)
548- let bF = valueOrElse(getInteger(bC, ("proposal_no_" + bD)), 0)
549- let bG = valueOrErrorMessage(getInteger(bC, ("proposal_height_" + bD)), "proposal not registered")
550- let bH = valueOrElse(getInteger(bC, ("proposal_applystart_" + bD)), 0)
551- let bI = valueOrElse(getInteger(bC, ("proposal_applyend_" + bD)), 0)
552- let bJ = valueOrElse(getInteger(bC, ("proposal_gvires_" + bD)), 0)
553- let bK = valueOrElse(getBoolean(x, "op_governance_apply_tx_paused"), false)
554- let bL = bE
553+@Verifier(bx)
554+func by () = {
555+ let bz = 1000
556+ let bA = valueOrErrorMessage(getInteger(x, "proposal_quorum_ratio"), "proposalQuorumRatio is not defined")
557+ let bB = valueOrErrorMessage(getInteger(x, "proposal_passed_ratio"), "proposalThresholdRatio is not defined")
558+ let bC = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(x, "dividends_contract"), "no dividends_contract")), "invalid dividends_contract")
559+ let bD = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(x, "voting_contract"), "no voting_contract")), "invalid voting_contract")
560+ let bE = toBase58String(bx.id)
561+ let bF = valueOrElse(getInteger(bD, ("proposal_yes_" + bE)), 0)
562+ let bG = valueOrElse(getInteger(bD, ("proposal_no_" + bE)), 0)
563+ let bH = valueOrErrorMessage(getInteger(bD, ("proposal_height_" + bE)), "proposal not registered")
564+ let bI = valueOrElse(getInteger(bD, ("proposal_applystart_" + bE)), 0)
565+ let bJ = valueOrElse(getInteger(bD, ("proposal_applyend_" + bE)), 0)
566+ let bK = valueOrElse(getInteger(bD, ("proposal_gvires_" + bE)), 0)
567+ let bL = valueOrElse(getBoolean(x, "op_governance_apply_tx_paused"), false)
555568 let bM = bF
556- let bN = (bL + bM)
557- let bO = (((bN * by) / bJ) >= bz)
558- let bP = (((bL * by) / bN) >= bA)
559- let bQ = (bH >= A)
560- let bR = (A >= bI)
561- let bS = ((((((("proposalHeight = " + toString(bG)) + ", applyStart = ") + toString(bH)) + ", applyEnd = ") + toString(bI)) + ", HEIGHT = ") + toString(A))
562- let bT = if (!(bK))
569+ let bN = bG
570+ let bO = (bM + bN)
571+ let bP = (((bO * bz) / bK) >= bA)
572+ let bQ = (((bM * bz) / bO) >= bB)
573+ let bR = (bI >= A)
574+ let bS = (A >= bJ)
575+ let bT = ((((((("proposalHeight = " + toString(bH)) + ", applyStart = ") + toString(bI)) + ", applyEnd = ") + toString(bJ)) + ", HEIGHT = ") + toString(A))
576+ let bU = if (!(bL))
563577 then throw("tx application throw governance not enabled")
564- else if (bQ)
565- then throw(("proposal can't be executed as it's too early: " + bS))
566- else if (bR)
567- then throw(("proposal can't be executed as it's too late:" + bS))
568- else if (!(bO))
569- then throw((((((("no quorum: " + "totalVotes: ") + toString(bN)) + ", totalGVires: ") + toString(bJ)) + ", quorumRatio: ") + toString(bz)))
570- else if (!(bP))
571- then throw((((((("no threshold achieved: " + "voteYes: ") + toString(bL)) + ", voteNo: ") + toString(bM)) + ", passedRatio: ") + toString(bA)))
578+ else if (bR)
579+ then throw(("proposal can't be executed as it's too early: " + bT))
580+ else if (bS)
581+ then throw(("proposal can't be executed as it's too late:" + bT))
582+ else if (!(bP))
583+ then throw((((((("no quorum: " + "totalVotes: ") + toString(bO)) + ", totalGVires: ") + toString(bK)) + ", quorumRatio: ") + toString(bA)))
584+ else if (!(bQ))
585+ then throw((((((("no threshold achieved: " + "voteYes: ") + toString(bM)) + ", voteNo: ") + toString(bN)) + ", passedRatio: ") + toString(bB)))
572586 else true
573- if (sigVerify(bw.bodyBytes, bw.proofs[0], bw.senderPublicKey))
587+ if (sigVerify(bx.bodyBytes, bx.proofs[0], bx.senderPublicKey))
574588 then true
575- else bT
589+ else bU
576590 }
577591
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
251251 let aF = valueOrElse(getInteger(x, (toString(this) + "_mint_daily_global_limit")), 100000000000)
252252
253253 let aG = (toString(fraction(A, 1, (60 * 24))) + "_mint_global_limit")
254254
255255 let aH = valueOrElse(getInteger(aG), aF)
256256
257257 let aI = valueOrElse(getInteger(x, (toString(this) + "_import_daily_global_limit")), 100000000000)
258258
259259 let aJ = (toString(fraction(A, 1, (60 * 24))) + "_import_global_limit")
260260
261261 let aK = valueOrElse(getInteger(aJ), aI)
262262
263+let aL = valueOrElse(getBoolean(x, (toString(this) + "_import_export_daily_global_limit_enabled")), false)
264+
263265 @Callable(V)
264-func init (aL,n,aM,aN,aO,aP,aQ,aR,aS) = if ((V.caller != this))
266+func init (aM,n,aN,aO,aP,aQ,aR,aS,aT) = if ((V.caller != this))
265267 then throw("only self can init")
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)]
268+ else [b(w, aM), b("usdtReserve", n), b("usdcReserve", aN), b("usdnVestingAll", aO), b("usdnVesting", aT), b("acc", aP), b("main1", aQ), b("usdnAssetId", aR), IntegerEntry("bonus", aS)]
267269
268270
269271
270272 @Callable(V)
271273 func startVestingFor (ai,q,ar) = {
272- let aT = U(V)
273- if ((aT == aT))
274+ let aU = U(V)
275+ if ((aU == aU))
274276 then aq(ai, q, ar)
275277 else throw("Strict value is not equal to itself.")
276278 }
277279
278280
279281
280282 @Callable(V)
281283 func startVesting (q,ar) = aq(toString(V.caller), q, ar)
282284
283285
284286
285287 @Callable(V)
286288 func convertToUSDN () = {
287289 let ai = toString(V.caller)
288- func aU (q) = {
290+ func aV (q) = {
289291 let as = addressFromStringValue(q)
290292 let at = getStringValue(as, "assetId")
291293 let av = Q("openCollateral", at)
292294 if ((av == av))
293295 then if (if ((q != toString(E)))
294296 then (q != toString(F))
295297 else false)
296298 then throw("invalid reserve")
297299 else {
298- let aV = invoke(B, "syncHeight", [q], nil)
299- if ((aV == aV))
300+ let aW = invoke(B, "syncHeight", [q], nil)
301+ if ((aW == aW))
300302 then {
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)])
303+ let aX = l(invoke(as, "storedDepositBorrow", nil, nil))
304+ let aY = aX._1
305+ let aZ = aX._2
306+ let ba = if ((aY > 0))
307+ then min([a, fraction(aZ, a, aY)])
306308 else 0
307- let ba = valueOrElse(getInteger(x, (at + "_open_collateral_thresold")), 1000)
308- if ((ba > aZ))
309+ let bb = valueOrElse(getInteger(x, (at + "_open_collateral_thresold")), 1000)
310+ if ((bb > ba))
309311 then throw("not allowed: util < threshold")
310312 else {
311- let bb = j(invoke(as, "userDepositUSD", [ai], nil))
312- if ((bb == bb))
313+ let bc = j(invoke(as, "userDepositUSD", [ai], nil))
314+ if ((bc == bc))
313315 then {
314- let aw = j(invoke(as, "transferATokensFor", [ai, G, bb], nil))
316+ let aw = j(invoke(as, "transferATokensFor", [ai, G, bc], nil))
315317 if ((aw == aw))
316318 then {
317- let bc = L(q, "deposit", ai, G, aw)
318- if ((bc == bc))
319+ let bd = L(q, "deposit", ai, G, aw)
320+ if ((bd == bd))
319321 then aw
320322 else throw("Strict value is not equal to itself.")
321323 }
322324 else throw("Strict value is not equal to itself.")
323325 }
324326 else throw("Strict value is not equal to itself.")
325327 }
326328 }
327329 else throw("Strict value is not equal to itself.")
328330 }
329331 else throw("Strict value is not equal to itself.")
330332 }
331333
332334 let au = invoke(I, "startVestingAllFor", [toString(V.caller)], nil)
333335 if ((au == au))
334336 then {
335- let bd = j(aU(toString(E)))
336- if ((bd == bd))
337+ let be = j(aV(toString(E)))
338+ if ((be == be))
337339 then {
338- let be = j(aU(toString(F)))
339- if ((be == be))
340+ let bf = j(aV(toString(F)))
341+ if ((bf == bf))
340342 then {
341- let bf = (bd + be)
343+ let bg = (be + bf)
342344 let aA = {
343- let bg = fraction(bf, (a + K), a)
344- let aB = invoke(C, "withdrawToMain2", [G, J, bg], nil)
345+ let bh = fraction(bg, (a + K), a)
346+ let aB = invoke(C, "withdrawToMain2", [G, J, bh], nil)
345347 if ((aB == aB))
346348 then {
347- let aA = invoke(H, "accountFor", [ai], [AttachedPayment(fromBase58String(J), bg)])
349+ let aA = invoke(H, "accountFor", [ai], [AttachedPayment(fromBase58String(J), bh)])
348350 if ((aA == aA))
349351 then unit
350352 else throw("Strict value is not equal to itself.")
351353 }
352354 else throw("Strict value is not equal to itself.")
353355 }
354356 if ((aA == aA))
355357 then {
356- let bh = l(invoke(D, "healthOf", [ai], nil))
357- let aD = bh._1
358- let aE = bh._2
358+ let bi = l(invoke(D, "healthOf", [ai], nil))
359+ let aD = bi._1
360+ let aE = bi._2
359361 if ((aD > (100 * (aD - aE))))
360362 then throw("not enough address health after move: < 1%")
361- else [v(((ai + "_migrated_") + getStringValue(E, "assetId")), bd), v(((ai + "_migrated_") + getStringValue(F, "assetId")), be)]
363+ else [v(((ai + "_migrated_") + getStringValue(E, "assetId")), be), v(((ai + "_migrated_") + getStringValue(F, "assetId")), bf)]
362364 }
363365 else throw("Strict value is not equal to itself.")
364366 }
365367 else throw("Strict value is not equal to itself.")
366368 }
367369 else throw("Strict value is not equal to itself.")
368370 }
369371 else throw("Strict value is not equal to itself.")
370372 }
371373
372374
373375
374376 @Callable(V)
375377 func withdrawVestedAllUSDN (ag,ah) = {
376378 let ai = toString(V.caller)
377379 let aj = if (ah)
378380 then j(invoke(H, "withdrawVestedForTo", [ai, ai], nil))
379381 else 0
380382 if ((aj == aj))
381383 then {
382384 let ak = if (ag)
383385 then j(invoke(I, "withdrawVestedForTo", [ai, ai], nil))
384386 else 0
385387 if ((ak == ak))
386388 then $Tuple2(nil, (ak + aj))
387389 else throw("Strict value is not equal to itself.")
388390 }
389391 else throw("Strict value is not equal to itself.")
390392 }
391393
392394
393395
394396 @Callable(V)
395397 func withdrawVestedAllSURF (ag,ah) = {
396398 let av = Q("liquidao_all_withdrawVestedAsSurf", toBase58String(ab))
397399 if ((av == av))
398400 then {
399- let bi = ae(V.caller, ag, ah)
400- if ((bi == bi))
401- then $Tuple2([ScriptTransfer(V.caller, bi, ab)], bi)
401+ let bj = ae(V.caller, ag, ah)
402+ if ((bj == bj))
403+ then $Tuple2([ScriptTransfer(V.caller, bj, ab)], bj)
402404 else throw("Strict value is not equal to itself.")
403405 }
404406 else throw("Strict value is not equal to itself.")
405407 }
406408
407409
408410
409411 @Callable(V)
410-func withdrawVestedSURF2 (ag,ah,bj) = {
412+func withdrawVestedSURF2 (ag,ah,bk) = {
411413 let ai = toString(V.caller)
412414 let av = Q("liquidao_all_withdrawVestedAsSurf", toBase58String(ab))
413415 if ((av == av))
414416 then {
415417 let aj = if ((ah > 0))
416418 then j(invoke(H, "partialWithdrawVestedForTo", [ai, toString(this), ah], nil))
417419 else 0
418420 if ((aj == aj))
419421 then {
420422 let ak = if ((ag > 0))
421423 then j(invoke(I, "partialWithdrawVestedForTo", [ai, toString(this), ag], nil))
422424 else 0
423425 if ((ak == ak))
424426 then {
425427 let al = (ak + aj)
426428 let am = invoke(Z, "buySurf", [1000000, 1000000, false], [AttachedPayment(fromBase58String(J), al)])
427429 if ((am == am))
428430 then {
429- let bi = assetBalance(this, ab)
430- if ((bi == bi))
431- then if (bj)
431+ let bj = assetBalance(this, ab)
432+ if ((bj == bj))
433+ then if (bk)
432434 then {
433- let bk = invoke(aa, "stakeByOriginCaller", nil, [AttachedPayment(ab, bi)])
434- if ((bk == bk))
435- then $Tuple2(nil, bi)
435+ let bl = invoke(aa, "stakeByOriginCaller", nil, [AttachedPayment(ab, bj)])
436+ if ((bl == bl))
437+ then $Tuple2(nil, bj)
436438 else throw("Strict value is not equal to itself.")
437439 }
438- else $Tuple2([ScriptTransfer(V.caller, bi, ab)], bi)
440+ else $Tuple2([ScriptTransfer(V.caller, bj, ab)], bj)
439441 else throw("Strict value is not equal to itself.")
440442 }
441443 else throw("Strict value is not equal to itself.")
442444 }
443445 else throw("Strict value is not equal to itself.")
444446 }
445447 else throw("Strict value is not equal to itself.")
446448 }
447449 else throw("Strict value is not equal to itself.")
448450 }
449451
450452
451453
452454 @Callable(V)
453455 func withdrawVestedAllSURFAndStake (ag,ah) = {
454456 let av = Q("liquidao_all_withdrawVestedAsSurf", toBase58String(ab))
455457 if ((av == av))
456458 then {
457- let bi = ae(V.caller, ag, ah)
458- if ((bi == bi))
459+ let bj = ae(V.caller, ag, ah)
460+ if ((bj == bj))
459461 then {
460- let bk = invoke(aa, "stakeByOriginCaller", nil, [AttachedPayment(ab, bi)])
461- if ((bk == bk))
462- then $Tuple2(nil, bi)
462+ let bl = invoke(aa, "stakeByOriginCaller", nil, [AttachedPayment(ab, bj)])
463+ if ((bl == bl))
464+ then $Tuple2(nil, bj)
463465 else throw("Strict value is not equal to itself.")
464466 }
465467 else throw("Strict value is not equal to itself.")
466468 }
467469 else throw("Strict value is not equal to itself.")
468470 }
469471
470472
471473
472474 @Callable(V)
473475 func withdrawAsLP (ag,ah) = {
474476 let ai = toString(V.caller)
475- if ((0 >= aH))
477+ if (if (aL)
478+ then (0 >= aH)
479+ else false)
476480 then throw(("Daily export limit: 0 of " + toString(aF)))
477481 else {
478- let bl = if ((ah > aH))
482+ let bm = if (if (aL)
483+ then (ah > aH)
484+ else false)
479485 then $Tuple2(aH, 0)
480- else if (((ag + ah) > aH))
486+ else if (if (aL)
487+ then ((ag + ah) > aH)
488+ else false)
481489 then $Tuple2(ah, (aH - ah))
482490 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))
491+ let bn = bm._1
492+ let bo = bm._2
493+ let aj = if ((bn > 0))
494+ then j(invoke(H, "partialWithdrawVestedForTo", [ai, toString(this), bn], nil))
487495 else 0
488496 if ((aj == aj))
489497 then {
490- let ak = if ((bn > 0))
491- then j(invoke(I, "partialWithdrawVestedForTo", [ai, toString(this), bn], nil))
498+ let ak = if ((bo > 0))
499+ then j(invoke(I, "partialWithdrawVestedForTo", [ai, toString(this), bo], nil))
492500 else 0
493501 if ((ak == ak))
494502 then {
495503 let al = (ak + aj)
496- let bo = (aH - al)
497- if ((0 > bo))
504+ let bp = (aH - al)
505+ if (if (aL)
506+ then (0 > bp)
507+ else false)
498508 then throw("negative limit")
499509 else {
500- let bp = invoke(y, "mintTo", [ai], [AttachedPayment(fromBase58String(J), al)])
501- if ((bp == bp))
502- then $Tuple2([IntegerEntry(aG, bo)], al)
510+ let bq = invoke(y, "mintTo", [ai], [AttachedPayment(fromBase58String(J), al)])
511+ if ((bq == bq))
512+ then $Tuple2([IntegerEntry(aG, bp)], al)
503513 else throw("Strict value is not equal to itself.")
504514 }
505515 }
506516 else throw("Strict value is not equal to itself.")
507517 }
508518 else throw("Strict value is not equal to itself.")
509519 }
510520 }
511521
512522
513523
514524 @Callable(V)
515-func importLP () = if ((aK == 0))
525+func importLP () = if (if (aL)
526+ then (0 >= aK)
527+ else false)
516528 then throw(("Daily import limit: 0 of " + toString(aI)))
517529 else {
518530 let ai = toString(V.caller)
519- let bq = V.payments[0].amount
520- let br = V.payments[0].assetId
521- let bs = if ((bq > aK))
522- then $Tuple3(AttachedPayment(br, aK), [ScriptTransfer(V.caller, (bq - aK), br)], 0)
523- else $Tuple3(V.payments[0], nil, (aK - bq))
524- let bt = bs._1
525- let bu = bs._2
526- let bo = bs._3
527- let bg = j(invoke(y, "import", nil, [bt]))
528- if ((bg == bg))
531+ let br = V.payments[0].amount
532+ let bs = V.payments[0].assetId
533+ let bt = if (if (aL)
534+ then (br > aK)
535+ else false)
536+ then $Tuple3(AttachedPayment(bs, aK), [ScriptTransfer(V.caller, (br - aK), bs)], 0)
537+ else $Tuple3(V.payments[0], nil, (aK - br))
538+ let bu = bt._1
539+ let bv = bt._2
540+ let bp = bt._3
541+ let bh = j(invoke(y, "import", nil, [bu]))
542+ if ((bh == bh))
529543 then {
530- let bv = invoke(H, "accountFor", [ai], [AttachedPayment(fromBase58String(J), bg)])
531- if ((bv == bv))
532- then $Tuple2(IntegerEntry(aJ, bo) :: bu, bg)
544+ let bw = invoke(H, "accountFor", [ai], [AttachedPayment(fromBase58String(J), bh)])
545+ if ((bw == bw))
546+ then $Tuple2(IntegerEntry(aJ, bp) :: bv, bh)
533547 else throw("Strict value is not equal to itself.")
534548 }
535549 else throw("Strict value is not equal to itself.")
536550 }
537551
538552
539-@Verifier(bw)
540-func bx () = {
541- let by = 1000
542- let bz = valueOrErrorMessage(getInteger(x, "proposal_quorum_ratio"), "proposalQuorumRatio is not defined")
543- let bA = valueOrErrorMessage(getInteger(x, "proposal_passed_ratio"), "proposalThresholdRatio is not defined")
544- let bB = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(x, "dividends_contract"), "no dividends_contract")), "invalid dividends_contract")
545- let bC = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(x, "voting_contract"), "no voting_contract")), "invalid voting_contract")
546- let bD = toBase58String(bw.id)
547- let bE = valueOrElse(getInteger(bC, ("proposal_yes_" + bD)), 0)
548- let bF = valueOrElse(getInteger(bC, ("proposal_no_" + bD)), 0)
549- let bG = valueOrErrorMessage(getInteger(bC, ("proposal_height_" + bD)), "proposal not registered")
550- let bH = valueOrElse(getInteger(bC, ("proposal_applystart_" + bD)), 0)
551- let bI = valueOrElse(getInteger(bC, ("proposal_applyend_" + bD)), 0)
552- let bJ = valueOrElse(getInteger(bC, ("proposal_gvires_" + bD)), 0)
553- let bK = valueOrElse(getBoolean(x, "op_governance_apply_tx_paused"), false)
554- let bL = bE
553+@Verifier(bx)
554+func by () = {
555+ let bz = 1000
556+ let bA = valueOrErrorMessage(getInteger(x, "proposal_quorum_ratio"), "proposalQuorumRatio is not defined")
557+ let bB = valueOrErrorMessage(getInteger(x, "proposal_passed_ratio"), "proposalThresholdRatio is not defined")
558+ let bC = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(x, "dividends_contract"), "no dividends_contract")), "invalid dividends_contract")
559+ let bD = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(x, "voting_contract"), "no voting_contract")), "invalid voting_contract")
560+ let bE = toBase58String(bx.id)
561+ let bF = valueOrElse(getInteger(bD, ("proposal_yes_" + bE)), 0)
562+ let bG = valueOrElse(getInteger(bD, ("proposal_no_" + bE)), 0)
563+ let bH = valueOrErrorMessage(getInteger(bD, ("proposal_height_" + bE)), "proposal not registered")
564+ let bI = valueOrElse(getInteger(bD, ("proposal_applystart_" + bE)), 0)
565+ let bJ = valueOrElse(getInteger(bD, ("proposal_applyend_" + bE)), 0)
566+ let bK = valueOrElse(getInteger(bD, ("proposal_gvires_" + bE)), 0)
567+ let bL = valueOrElse(getBoolean(x, "op_governance_apply_tx_paused"), false)
555568 let bM = bF
556- let bN = (bL + bM)
557- let bO = (((bN * by) / bJ) >= bz)
558- let bP = (((bL * by) / bN) >= bA)
559- let bQ = (bH >= A)
560- let bR = (A >= bI)
561- let bS = ((((((("proposalHeight = " + toString(bG)) + ", applyStart = ") + toString(bH)) + ", applyEnd = ") + toString(bI)) + ", HEIGHT = ") + toString(A))
562- let bT = if (!(bK))
569+ let bN = bG
570+ let bO = (bM + bN)
571+ let bP = (((bO * bz) / bK) >= bA)
572+ let bQ = (((bM * bz) / bO) >= bB)
573+ let bR = (bI >= A)
574+ let bS = (A >= bJ)
575+ let bT = ((((((("proposalHeight = " + toString(bH)) + ", applyStart = ") + toString(bI)) + ", applyEnd = ") + toString(bJ)) + ", HEIGHT = ") + toString(A))
576+ let bU = if (!(bL))
563577 then throw("tx application throw governance not enabled")
564- else if (bQ)
565- then throw(("proposal can't be executed as it's too early: " + bS))
566- else if (bR)
567- then throw(("proposal can't be executed as it's too late:" + bS))
568- else if (!(bO))
569- then throw((((((("no quorum: " + "totalVotes: ") + toString(bN)) + ", totalGVires: ") + toString(bJ)) + ", quorumRatio: ") + toString(bz)))
570- else if (!(bP))
571- then throw((((((("no threshold achieved: " + "voteYes: ") + toString(bL)) + ", voteNo: ") + toString(bM)) + ", passedRatio: ") + toString(bA)))
578+ else if (bR)
579+ then throw(("proposal can't be executed as it's too early: " + bT))
580+ else if (bS)
581+ then throw(("proposal can't be executed as it's too late:" + bT))
582+ else if (!(bP))
583+ then throw((((((("no quorum: " + "totalVotes: ") + toString(bO)) + ", totalGVires: ") + toString(bK)) + ", quorumRatio: ") + toString(bA)))
584+ else if (!(bQ))
585+ then throw((((((("no threshold achieved: " + "voteYes: ") + toString(bM)) + ", voteNo: ") + toString(bN)) + ", passedRatio: ") + toString(bB)))
572586 else true
573- if (sigVerify(bw.bodyBytes, bw.proofs[0], bw.senderPublicKey))
587+ if (sigVerify(bx.bodyBytes, bx.proofs[0], bx.senderPublicKey))
574588 then true
575- else bT
589+ else bU
576590 }
577591

github/deemru/w8io/3ef1775 
101.56 ms