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
236236
237237 let importTodayGlobalLimit = valueOrElse(getInteger(importTodayGlobalLimitStore), importDailyGlobalLimit)
238238
239+let importExportDailyGlobalLimitEnabled = valueOrElse(getBoolean(configAddress, (toString(this) + "_import_export_daily_global_limit_enabled")), false)
240+
239241 @Callable(i)
240242 func init (conf,t,c,vestnAll,account,main,usdnAsset,bonus,vestn) = if ((i.caller != this))
241243 then throw("only self can init")
274276 let shC = invoke(vd, "syncHeight", [rsr], nil)
275277 if ((shC == shC))
276278 then {
277- let $t081308214 = asInt2(invoke(reserve, "storedDepositBorrow", nil, nil))
278- let totalDeposit = $t081308214._1
279- let totalDebt = $t081308214._2
279+ let $t083028386 = asInt2(invoke(reserve, "storedDepositBorrow", nil, nil))
280+ let totalDeposit = $t083028386._1
281+ let totalDebt = $t083028386._2
280282 let util = if ((totalDeposit > 0))
281283 then min([factorsBase, fraction(totalDebt, factorsBase, totalDeposit)])
282284 else 0
329331 }
330332 if ((rehab == rehab))
331333 then {
332- let $t093689430 = asInt2(invoke(main1, "healthOf", [address], nil))
333- let bp = $t093689430._1
334- let bpu = $t093689430._2
334+ let $t095409602 = asInt2(invoke(main1, "healthOf", [address], nil))
335+ let bp = $t095409602._1
336+ let bpu = $t095409602._2
335337 if ((bp > (100 * (bp - bpu))))
336338 then throw("not enough address health after move: < 1%")
337339 else [changeBy(((address + "_migrated_") + getStringValue(usdtReserve, "assetId")), mt), changeBy(((address + "_migrated_") + getStringValue(usdcReserve, "assetId")), mc)]
448450 @Callable(i)
449451 func withdrawAsLP (whale,regular) = {
450452 let address = toString(i.caller)
451- if ((0 >= mintTodayGlobalLimit))
453+ if (if (importExportDailyGlobalLimitEnabled)
454+ then (0 >= mintTodayGlobalLimit)
455+ else false)
452456 then throw(("Daily export limit: 0 of " + toString(mintDailyGlobalLimit)))
453457 else {
454- let $t01206412318 = if ((regular > mintTodayGlobalLimit))
458+ let $t01227512607 = if (if (importExportDailyGlobalLimitEnabled)
459+ then (regular > mintTodayGlobalLimit)
460+ else false)
455461 then $Tuple2(mintTodayGlobalLimit, 0)
456- else if (((whale + regular) > mintTodayGlobalLimit))
462+ else if (if (importExportDailyGlobalLimitEnabled)
463+ then ((whale + regular) > mintTodayGlobalLimit)
464+ else false)
457465 then $Tuple2(regular, (mintTodayGlobalLimit - regular))
458466 else $Tuple2(regular, whale)
459- let regularAmt = $t01206412318._1
460- let whaleAmt = $t01206412318._2
467+ let regularAmt = $t01227512607._1
468+ let whaleAmt = $t01227512607._2
461469 let regPart = if ((regularAmt > 0))
462470 then asInt(invoke(usdnVestingAll, "partialWithdrawVestedForTo", [address, toString(this), regularAmt], nil))
463471 else 0
470478 then {
471479 let total = (whalePart + regPart)
472480 let newLimit = (mintTodayGlobalLimit - total)
473- if ((0 > newLimit))
481+ if (if (importExportDailyGlobalLimitEnabled)
482+ then (0 > newLimit)
483+ else false)
474484 then throw("negative limit")
475485 else {
476486 let toLp = invoke(viresVestedUsdnLpDapp, "mintTo", [address], [AttachedPayment(fromBase58String(usdnAssetId), total)])
488498
489499
490500 @Callable(i)
491-func importLP () = if ((importTodayGlobalLimit == 0))
501+func importLP () = if (if (importExportDailyGlobalLimitEnabled)
502+ then (0 >= importTodayGlobalLimit)
503+ else false)
492504 then throw(("Daily import limit: 0 of " + toString(importDailyGlobalLimit)))
493505 else {
494506 let address = toString(i.caller)
495507 let paymentAmt = i.payments[0].amount
496508 let lpAssetId = i.payments[0].assetId
497- let $t01326413622 = if ((paymentAmt > importTodayGlobalLimit))
509+ let $t01363114028 = if (if (importExportDailyGlobalLimitEnabled)
510+ then (paymentAmt > importTodayGlobalLimit)
511+ else false)
498512 then $Tuple3(AttachedPayment(lpAssetId, importTodayGlobalLimit), [ScriptTransfer(i.caller, (paymentAmt - importTodayGlobalLimit), lpAssetId)], 0)
499513 else $Tuple3(i.payments[0], nil, (importTodayGlobalLimit - paymentAmt))
500- let payment = $t01326413622._1
501- let change = $t01326413622._2
502- let newLimit = $t01326413622._3
514+ let payment = $t01363114028._1
515+ let change = $t01363114028._2
516+ let newLimit = $t01363114028._3
503517 let usdnAmt = asInt(invoke(viresVestedUsdnLpDapp, "import", nil, [payment]))
504518 if ((usdnAmt == usdnAmt))
505519 then {
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let factorsBase = 1000
55
66 func writeConstString (key,value) = if (!(isDefined(getString(this, key))))
77 then StringEntry(key, value)
88 else throw(("already initialized: " + key))
99
1010
1111 func writeConstInt (key,value) = if (!(isDefined(getInteger(this, key))))
1212 then IntegerEntry(key, value)
1313 else throw(("already initialized: " + key))
1414
1515
1616 func writeInt (key,value) = if ((0 > value))
1717 then throw(((("writing negative value " + toString(value)) + " for key ") + key))
1818 else IntegerEntry(key, value)
1919
2020
2121 func asString (value) = match value {
2222 case s: String =>
2323 s
2424 case _ =>
2525 throw("wrong type, expected: String")
2626 }
2727
2828
2929 func asInt (value) = match value {
3030 case int: Int =>
3131 int
3232 case _ =>
3333 throw("sm:1")
3434 }
3535
3636
3737 func asInt2 (value) = match value {
3838 case x: (Int, Int) =>
3939 x
4040 case t =>
4141 throw("wrong type, expected: Int2")
4242 }
4343
4444
4545 func asUserBalanceData (value) = match value {
4646 case x: (Int, Int, Int, Int, Int, Boolean) =>
4747 x
4848 case t =>
4949 throw("3")
5050 }
5151
5252
5353 func userBalance (rsr,user) = asUserBalanceData(invoke(rsr, "userBalance", [user], nil))
5454
5555
5656 func throwIf (condition,error) = if (condition)
5757 then throw(error)
5858 else true
5959
6060
6161 func changeBy (key,value) = writeInt(key, (valueOrElse(getInteger(this, key), 0) + value))
6262
6363
6464 let configStore = "config"
6565
6666 let configAddress = addressFromStringValue(getStringValue(this, configStore))
6767
6868 let viresVestedUsdnLpDapp = addressFromStringValue("3PJFu8MmVa2rSVGM48wdLm4jhLznEgu6XSe")
6969
7070 let maybeOracleAddress = match getString(configAddress, "oracle_address") {
7171 case s: String =>
7272 addressFromString(s)
7373 case _ =>
7474 unit
7575 }
7676
7777 let HEIGHT = height
7878
7979 let vd = addressFromStringValue(valueOrErrorMessage(getString(configAddress, "vires_distributor"), "bad vires distributor"))
8080
8181 let protectedReserve = addressFromStringValue(getStringValue(configAddress, "protected_reserve"))
8282
8383 let main1 = addressFromStringValue(getStringValue(this, "main1"))
8484
8585 let usdtReserve = addressFromStringValue(getStringValue(this, "usdtReserve"))
8686
8787 let usdcReserve = addressFromStringValue(getStringValue(this, "usdcReserve"))
8888
8989 let acc = getStringValue(this, "acc")
9090
9191 let usdnVestingAll = addressFromStringValue(getStringValue(this, "usdnVestingAll"))
9292
9393 let usdnVesting = addressFromStringValue(getStringValue(this, "usdnVesting"))
9494
9595 let usdnAssetId = getStringValue(this, "usdnAssetId")
9696
9797 let usdnBonus = getIntegerValue(this, "bonus")
9898
9999 func moveStream (rsr,action,from,string,amt) = invoke(vd, "move", [rsr, action, from, string, amt], nil)
100100
101101
102102 func opAllowed (op,assetIdStr) = match invoke(configAddress, "opAllowed", [assetIdStr, op], nil) {
103103 case b: Boolean =>
104104 if (b)
105105 then true
106106 else throw("not allowed")
107107 case _ =>
108108 throw("opAllowed: unexpected result type")
109109 }
110110
111111
112112 func mainOnly (i) = if (contains(getStringValue(configAddress, "main"), toString(i.caller)))
113113 then true
114114 else throw("only main can do")
115115
116116
117117 func adviseUser (acc) = {
118118 let dataWhale = asString(invoke(usdnVesting, "adviseU", [acc], nil))
119119 if ((dataWhale == dataWhale))
120120 then {
121121 let dataAll = asString(invoke(usdnVestingAll, "adviseU", [acc], nil))
122122 if ((dataAll == dataAll))
123123 then ((dataWhale + " | ") + dataAll)
124124 else throw("Strict value is not equal to itself.")
125125 }
126126 else throw("Strict value is not equal to itself.")
127127 }
128128
129129
130130 let surfAddress = addressFromStringValue("3PG2vMhK5CPqsCDodvLGzQ84QkoHXCJ3oNP")
131131
132132 let surfStakeAddress = addressFromStringValue("3PBiotFpqjRMkkeFBccnQNUXUopy7KFez5C")
133133
134134 let surfAssetId = fromBase58String("At8D6NFFpheCbvKVnjVoeLL84Eo8NZn6ovManxfLaFWL")
135135
136136 let oracle = Address(base58'3PKkojKdd6BBzTf1RXbQVfUDraNFXXHKzQF')
137137
138138 let xtnPrice = getIntegerValue(oracle, "%s%s__price__USDN-USDT")
139139
140140 func buySurf (caller,whale,regular) = {
141141 let address = toString(caller)
142142 let regPart = if (regular)
143143 then asInt(invoke(usdnVestingAll, "withdrawAllVestedForTo", [address, toString(this)], nil))
144144 else 0
145145 if ((regPart == regPart))
146146 then {
147147 let whalePart = if (whale)
148148 then throw("not implemented")
149149 else 0
150150 if ((whalePart == whalePart))
151151 then {
152152 let total = (whalePart + regPart)
153153 let buy = invoke(surfAddress, "buySurf", [1000000, 1000000, false], [AttachedPayment(fromBase58String(usdnAssetId), total)])
154154 if ((buy == buy))
155155 then assetBalance(this, surfAssetId)
156156 else throw("Strict value is not equal to itself.")
157157 }
158158 else throw("Strict value is not equal to itself.")
159159 }
160160 else throw("Strict value is not equal to itself.")
161161 }
162162
163163
164164 let reservesStr = valueOrErrorMessage(getString(configAddress, "primary_reserves"), "no reserves registered")
165165
166166 func vlR (r) = if (contains(reservesStr, r))
167167 then valueOrErrorMessage(addressFromString(r), "main: bad rsr")
168168 else throw(("unknown rsr:" + r))
169169
170170
171171 func startVestingForInternal (address,rsr,amount) = {
172172 let r = vlR(rsr)
173173 if ((r == r))
174174 then {
175175 let reserve = addressFromStringValue(rsr)
176176 let assetId = getStringValue(reserve, "assetId")
177177 let mw = invoke(usdnVesting, "startVestingAllFor", [address], nil)
178178 if ((mw == mw))
179179 then {
180180 let checks = opAllowed("openCollateral", assetId)
181181 if ((checks == checks))
182182 then {
183183 let s3 = asInt(invoke(reserve, "transferATokensAmountFor", [address, acc, amount], nil))
184184 if ((s3 == s3))
185185 then {
186186 let xtnAmt = {
187187 let reserveVestingRate = getInteger(configAddress, (rsr + "_to_vesting_value"))
188188 if (isDefined(reserveVestingRate))
189189 then fraction(s3, value(reserveVestingRate), factorsBase)
190190 else {
191191 let usd = asInt(invoke(reserve, "toUSD", [s3], nil))
192192 fraction(usd, 1000000, xtnPrice)
193193 }
194194 }
195195 let rehab = {
196196 let wd = invoke(protectedReserve, "withdrawToMain2", [acc, usdnAssetId, xtnAmt], nil)
197197 if ((wd == wd))
198198 then {
199199 let rehab = invoke(usdnVestingAll, "accountFor", [address], [AttachedPayment(fromBase58String(usdnAssetId), xtnAmt)])
200200 if ((rehab == rehab))
201201 then unit
202202 else throw("Strict value is not equal to itself.")
203203 }
204204 else throw("Strict value is not equal to itself.")
205205 }
206206 if ((rehab == rehab))
207207 then {
208208 let $t058505912 = asInt2(invoke(main1, "healthOf", [address], nil))
209209 let bp = $t058505912._1
210210 let bpu = $t058505912._2
211211 if ((bp > (100 * (bp - bpu))))
212212 then throw("not enough address health after move: < 1%")
213213 else $Tuple2([changeBy(((address + "_migrated_") + assetId), s3)], xtnAmt)
214214 }
215215 else throw("Strict value is not equal to itself.")
216216 }
217217 else throw("Strict value is not equal to itself.")
218218 }
219219 else throw("Strict value is not equal to itself.")
220220 }
221221 else throw("Strict value is not equal to itself.")
222222 }
223223 else throw("Strict value is not equal to itself.")
224224 }
225225
226226
227227 let mintDailyGlobalLimit = valueOrElse(getInteger(configAddress, (toString(this) + "_mint_daily_global_limit")), 100000000000)
228228
229229 let mintTodayGlobalLimitStore = (toString(fraction(HEIGHT, 1, (60 * 24))) + "_mint_global_limit")
230230
231231 let mintTodayGlobalLimit = valueOrElse(getInteger(mintTodayGlobalLimitStore), mintDailyGlobalLimit)
232232
233233 let importDailyGlobalLimit = valueOrElse(getInteger(configAddress, (toString(this) + "_import_daily_global_limit")), 100000000000)
234234
235235 let importTodayGlobalLimitStore = (toString(fraction(HEIGHT, 1, (60 * 24))) + "_import_global_limit")
236236
237237 let importTodayGlobalLimit = valueOrElse(getInteger(importTodayGlobalLimitStore), importDailyGlobalLimit)
238238
239+let importExportDailyGlobalLimitEnabled = valueOrElse(getBoolean(configAddress, (toString(this) + "_import_export_daily_global_limit_enabled")), false)
240+
239241 @Callable(i)
240242 func init (conf,t,c,vestnAll,account,main,usdnAsset,bonus,vestn) = if ((i.caller != this))
241243 then throw("only self can init")
242244 else [writeConstString(configStore, conf), writeConstString("usdtReserve", t), writeConstString("usdcReserve", c), writeConstString("usdnVestingAll", vestnAll), writeConstString("usdnVesting", vestn), writeConstString("acc", account), writeConstString("main1", main), writeConstString("usdnAssetId", usdnAsset), IntegerEntry("bonus", bonus)]
243245
244246
245247
246248 @Callable(i)
247249 func startVestingFor (address,rsr,amount) = {
248250 let m = mainOnly(i)
249251 if ((m == m))
250252 then startVestingForInternal(address, rsr, amount)
251253 else throw("Strict value is not equal to itself.")
252254 }
253255
254256
255257
256258 @Callable(i)
257259 func startVesting (rsr,amount) = startVestingForInternal(toString(i.caller), rsr, amount)
258260
259261
260262
261263 @Callable(i)
262264 func convertToUSDN () = {
263265 let address = toString(i.caller)
264266 func moveRsr (rsr) = {
265267 let reserve = addressFromStringValue(rsr)
266268 let assetId = getStringValue(reserve, "assetId")
267269 let checks = opAllowed("openCollateral", assetId)
268270 if ((checks == checks))
269271 then if (if ((rsr != toString(usdtReserve)))
270272 then (rsr != toString(usdcReserve))
271273 else false)
272274 then throw("invalid reserve")
273275 else {
274276 let shC = invoke(vd, "syncHeight", [rsr], nil)
275277 if ((shC == shC))
276278 then {
277- let $t081308214 = asInt2(invoke(reserve, "storedDepositBorrow", nil, nil))
278- let totalDeposit = $t081308214._1
279- let totalDebt = $t081308214._2
279+ let $t083028386 = asInt2(invoke(reserve, "storedDepositBorrow", nil, nil))
280+ let totalDeposit = $t083028386._1
281+ let totalDebt = $t083028386._2
280282 let util = if ((totalDeposit > 0))
281283 then min([factorsBase, fraction(totalDebt, factorsBase, totalDeposit)])
282284 else 0
283285 let utilThreshold = valueOrElse(getInteger(configAddress, (assetId + "_open_collateral_thresold")), 1000)
284286 if ((utilThreshold > util))
285287 then throw("not allowed: util < threshold")
286288 else {
287289 let dep = asInt(invoke(reserve, "userDepositUSD", [address], nil))
288290 if ((dep == dep))
289291 then {
290292 let s3 = asInt(invoke(reserve, "transferATokensFor", [address, acc, dep], nil))
291293 if ((s3 == s3))
292294 then {
293295 let pRw3 = moveStream(rsr, "deposit", address, acc, s3)
294296 if ((pRw3 == pRw3))
295297 then s3
296298 else throw("Strict value is not equal to itself.")
297299 }
298300 else throw("Strict value is not equal to itself.")
299301 }
300302 else throw("Strict value is not equal to itself.")
301303 }
302304 }
303305 else throw("Strict value is not equal to itself.")
304306 }
305307 else throw("Strict value is not equal to itself.")
306308 }
307309
308310 let mw = invoke(usdnVesting, "startVestingAllFor", [toString(i.caller)], nil)
309311 if ((mw == mw))
310312 then {
311313 let mt = asInt(moveRsr(toString(usdtReserve)))
312314 if ((mt == mt))
313315 then {
314316 let mc = asInt(moveRsr(toString(usdcReserve)))
315317 if ((mc == mc))
316318 then {
317319 let depTotal = (mt + mc)
318320 let rehab = {
319321 let usdnAmt = fraction(depTotal, (factorsBase + usdnBonus), factorsBase)
320322 let wd = invoke(protectedReserve, "withdrawToMain2", [acc, usdnAssetId, usdnAmt], nil)
321323 if ((wd == wd))
322324 then {
323325 let rehab = invoke(usdnVestingAll, "accountFor", [address], [AttachedPayment(fromBase58String(usdnAssetId), usdnAmt)])
324326 if ((rehab == rehab))
325327 then unit
326328 else throw("Strict value is not equal to itself.")
327329 }
328330 else throw("Strict value is not equal to itself.")
329331 }
330332 if ((rehab == rehab))
331333 then {
332- let $t093689430 = asInt2(invoke(main1, "healthOf", [address], nil))
333- let bp = $t093689430._1
334- let bpu = $t093689430._2
334+ let $t095409602 = asInt2(invoke(main1, "healthOf", [address], nil))
335+ let bp = $t095409602._1
336+ let bpu = $t095409602._2
335337 if ((bp > (100 * (bp - bpu))))
336338 then throw("not enough address health after move: < 1%")
337339 else [changeBy(((address + "_migrated_") + getStringValue(usdtReserve, "assetId")), mt), changeBy(((address + "_migrated_") + getStringValue(usdcReserve, "assetId")), mc)]
338340 }
339341 else throw("Strict value is not equal to itself.")
340342 }
341343 else throw("Strict value is not equal to itself.")
342344 }
343345 else throw("Strict value is not equal to itself.")
344346 }
345347 else throw("Strict value is not equal to itself.")
346348 }
347349
348350
349351
350352 @Callable(i)
351353 func withdrawVestedAllUSDN (whale,regular) = {
352354 let address = toString(i.caller)
353355 let regPart = if (regular)
354356 then asInt(invoke(usdnVestingAll, "withdrawVestedForTo", [address, address], nil))
355357 else 0
356358 if ((regPart == regPart))
357359 then {
358360 let whalePart = if (whale)
359361 then asInt(invoke(usdnVesting, "withdrawVestedForTo", [address, address], nil))
360362 else 0
361363 if ((whalePart == whalePart))
362364 then $Tuple2(nil, (whalePart + regPart))
363365 else throw("Strict value is not equal to itself.")
364366 }
365367 else throw("Strict value is not equal to itself.")
366368 }
367369
368370
369371
370372 @Callable(i)
371373 func withdrawVestedAllSURF (whale,regular) = {
372374 let checks = opAllowed("liquidao_all_withdrawVestedAsSurf", toBase58String(surfAssetId))
373375 if ((checks == checks))
374376 then {
375377 let surfBalance = buySurf(i.caller, whale, regular)
376378 if ((surfBalance == surfBalance))
377379 then $Tuple2([ScriptTransfer(i.caller, surfBalance, surfAssetId)], surfBalance)
378380 else throw("Strict value is not equal to itself.")
379381 }
380382 else throw("Strict value is not equal to itself.")
381383 }
382384
383385
384386
385387 @Callable(i)
386388 func withdrawVestedSURF2 (whale,regular,stake) = {
387389 let address = toString(i.caller)
388390 let checks = opAllowed("liquidao_all_withdrawVestedAsSurf", toBase58String(surfAssetId))
389391 if ((checks == checks))
390392 then {
391393 let regPart = if ((regular > 0))
392394 then asInt(invoke(usdnVestingAll, "partialWithdrawVestedForTo", [address, toString(this), regular], nil))
393395 else 0
394396 if ((regPart == regPart))
395397 then {
396398 let whalePart = if ((whale > 0))
397399 then asInt(invoke(usdnVesting, "partialWithdrawVestedForTo", [address, toString(this), whale], nil))
398400 else 0
399401 if ((whalePart == whalePart))
400402 then {
401403 let total = (whalePart + regPart)
402404 let buy = invoke(surfAddress, "buySurf", [1000000, 1000000, false], [AttachedPayment(fromBase58String(usdnAssetId), total)])
403405 if ((buy == buy))
404406 then {
405407 let surfBalance = assetBalance(this, surfAssetId)
406408 if ((surfBalance == surfBalance))
407409 then if (stake)
408410 then {
409411 let stakeSurf = invoke(surfStakeAddress, "stakeByOriginCaller", nil, [AttachedPayment(surfAssetId, surfBalance)])
410412 if ((stakeSurf == stakeSurf))
411413 then $Tuple2(nil, surfBalance)
412414 else throw("Strict value is not equal to itself.")
413415 }
414416 else $Tuple2([ScriptTransfer(i.caller, surfBalance, surfAssetId)], surfBalance)
415417 else throw("Strict value is not equal to itself.")
416418 }
417419 else throw("Strict value is not equal to itself.")
418420 }
419421 else throw("Strict value is not equal to itself.")
420422 }
421423 else throw("Strict value is not equal to itself.")
422424 }
423425 else throw("Strict value is not equal to itself.")
424426 }
425427
426428
427429
428430 @Callable(i)
429431 func withdrawVestedAllSURFAndStake (whale,regular) = {
430432 let checks = opAllowed("liquidao_all_withdrawVestedAsSurf", toBase58String(surfAssetId))
431433 if ((checks == checks))
432434 then {
433435 let surfBalance = buySurf(i.caller, whale, regular)
434436 if ((surfBalance == surfBalance))
435437 then {
436438 let stakeSurf = invoke(surfStakeAddress, "stakeByOriginCaller", nil, [AttachedPayment(surfAssetId, surfBalance)])
437439 if ((stakeSurf == stakeSurf))
438440 then $Tuple2(nil, surfBalance)
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
446448
447449
448450 @Callable(i)
449451 func withdrawAsLP (whale,regular) = {
450452 let address = toString(i.caller)
451- if ((0 >= mintTodayGlobalLimit))
453+ if (if (importExportDailyGlobalLimitEnabled)
454+ then (0 >= mintTodayGlobalLimit)
455+ else false)
452456 then throw(("Daily export limit: 0 of " + toString(mintDailyGlobalLimit)))
453457 else {
454- let $t01206412318 = if ((regular > mintTodayGlobalLimit))
458+ let $t01227512607 = if (if (importExportDailyGlobalLimitEnabled)
459+ then (regular > mintTodayGlobalLimit)
460+ else false)
455461 then $Tuple2(mintTodayGlobalLimit, 0)
456- else if (((whale + regular) > mintTodayGlobalLimit))
462+ else if (if (importExportDailyGlobalLimitEnabled)
463+ then ((whale + regular) > mintTodayGlobalLimit)
464+ else false)
457465 then $Tuple2(regular, (mintTodayGlobalLimit - regular))
458466 else $Tuple2(regular, whale)
459- let regularAmt = $t01206412318._1
460- let whaleAmt = $t01206412318._2
467+ let regularAmt = $t01227512607._1
468+ let whaleAmt = $t01227512607._2
461469 let regPart = if ((regularAmt > 0))
462470 then asInt(invoke(usdnVestingAll, "partialWithdrawVestedForTo", [address, toString(this), regularAmt], nil))
463471 else 0
464472 if ((regPart == regPart))
465473 then {
466474 let whalePart = if ((whaleAmt > 0))
467475 then asInt(invoke(usdnVesting, "partialWithdrawVestedForTo", [address, toString(this), whaleAmt], nil))
468476 else 0
469477 if ((whalePart == whalePart))
470478 then {
471479 let total = (whalePart + regPart)
472480 let newLimit = (mintTodayGlobalLimit - total)
473- if ((0 > newLimit))
481+ if (if (importExportDailyGlobalLimitEnabled)
482+ then (0 > newLimit)
483+ else false)
474484 then throw("negative limit")
475485 else {
476486 let toLp = invoke(viresVestedUsdnLpDapp, "mintTo", [address], [AttachedPayment(fromBase58String(usdnAssetId), total)])
477487 if ((toLp == toLp))
478488 then $Tuple2([IntegerEntry(mintTodayGlobalLimitStore, newLimit)], total)
479489 else throw("Strict value is not equal to itself.")
480490 }
481491 }
482492 else throw("Strict value is not equal to itself.")
483493 }
484494 else throw("Strict value is not equal to itself.")
485495 }
486496 }
487497
488498
489499
490500 @Callable(i)
491-func importLP () = if ((importTodayGlobalLimit == 0))
501+func importLP () = if (if (importExportDailyGlobalLimitEnabled)
502+ then (0 >= importTodayGlobalLimit)
503+ else false)
492504 then throw(("Daily import limit: 0 of " + toString(importDailyGlobalLimit)))
493505 else {
494506 let address = toString(i.caller)
495507 let paymentAmt = i.payments[0].amount
496508 let lpAssetId = i.payments[0].assetId
497- let $t01326413622 = if ((paymentAmt > importTodayGlobalLimit))
509+ let $t01363114028 = if (if (importExportDailyGlobalLimitEnabled)
510+ then (paymentAmt > importTodayGlobalLimit)
511+ else false)
498512 then $Tuple3(AttachedPayment(lpAssetId, importTodayGlobalLimit), [ScriptTransfer(i.caller, (paymentAmt - importTodayGlobalLimit), lpAssetId)], 0)
499513 else $Tuple3(i.payments[0], nil, (importTodayGlobalLimit - paymentAmt))
500- let payment = $t01326413622._1
501- let change = $t01326413622._2
502- let newLimit = $t01326413622._3
514+ let payment = $t01363114028._1
515+ let change = $t01363114028._2
516+ let newLimit = $t01363114028._3
503517 let usdnAmt = asInt(invoke(viresVestedUsdnLpDapp, "import", nil, [payment]))
504518 if ((usdnAmt == usdnAmt))
505519 then {
506520 let accountFor = invoke(usdnVestingAll, "accountFor", [address], [AttachedPayment(fromBase58String(usdnAssetId), usdnAmt)])
507521 if ((accountFor == accountFor))
508522 then $Tuple2(IntegerEntry(importTodayGlobalLimitStore, newLimit) :: change, usdnAmt)
509523 else throw("Strict value is not equal to itself.")
510524 }
511525 else throw("Strict value is not equal to itself.")
512526 }
513527
514528
515529 @Verifier(tx)
516530 func verify () = {
517531 let BASE = 1000
518532 let quorumRatio = valueOrErrorMessage(getInteger(configAddress, "proposal_quorum_ratio"), "proposalQuorumRatio is not defined")
519533 let passedRatio = valueOrErrorMessage(getInteger(configAddress, "proposal_passed_ratio"), "proposalThresholdRatio is not defined")
520534 let gViresContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "dividends_contract"), "no dividends_contract")), "invalid dividends_contract")
521535 let votingContract = valueOrErrorMessage(addressFromString(valueOrErrorMessage(getString(configAddress, "voting_contract"), "no voting_contract")), "invalid voting_contract")
522536 let id = toBase58String(tx.id)
523537 let votesYes = valueOrElse(getInteger(votingContract, ("proposal_yes_" + id)), 0)
524538 let votesNo = valueOrElse(getInteger(votingContract, ("proposal_no_" + id)), 0)
525539 let proposalHeight = valueOrErrorMessage(getInteger(votingContract, ("proposal_height_" + id)), "proposal not registered")
526540 let applyStart = valueOrElse(getInteger(votingContract, ("proposal_applystart_" + id)), 0)
527541 let applyEnd = valueOrElse(getInteger(votingContract, ("proposal_applyend_" + id)), 0)
528542 let totalGVires = valueOrElse(getInteger(votingContract, ("proposal_gvires_" + id)), 0)
529543 let enabled = valueOrElse(getBoolean(configAddress, "op_governance_apply_tx_paused"), false)
530544 let voteYes = votesYes
531545 let voteNo = votesNo
532546 let totalVotes = (voteYes + voteNo)
533547 let hasQuorum = (((totalVotes * BASE) / totalGVires) >= quorumRatio)
534548 let hasPassed = (((voteYes * BASE) / totalVotes) >= passedRatio)
535549 let tooEarly = (applyStart >= HEIGHT)
536550 let tooLate = (HEIGHT >= applyEnd)
537551 let timeDebug = ((((((("proposalHeight = " + toString(proposalHeight)) + ", applyStart = ") + toString(applyStart)) + ", applyEnd = ") + toString(applyEnd)) + ", HEIGHT = ") + toString(HEIGHT))
538552 let byVoting = if (!(enabled))
539553 then throw("tx application throw governance not enabled")
540554 else if (tooEarly)
541555 then throw(("proposal can't be executed as it's too early: " + timeDebug))
542556 else if (tooLate)
543557 then throw(("proposal can't be executed as it's too late:" + timeDebug))
544558 else if (!(hasQuorum))
545559 then throw((((((("no quorum: " + "totalVotes: ") + toString(totalVotes)) + ", totalGVires: ") + toString(totalGVires)) + ", quorumRatio: ") + toString(quorumRatio)))
546560 else if (!(hasPassed))
547561 then throw((((((("no threshold achieved: " + "voteYes: ") + toString(voteYes)) + ", voteNo: ") + toString(voteNo)) + ", passedRatio: ") + toString(passedRatio)))
548562 else true
549563 if (sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey))
550564 then true
551565 else byVoting
552566 }
553567

github/deemru/w8io/6500d08 
60.07 ms