2022.11.10 12:42 [3376234] smart account 3P6dkRGSqgsNpQFbSYn9m8n4Dd8KRaj5TUU > SELF 0.00000000 Waves

{ "type": 13, "id": "9xCJjfApbLN8P6U8BMFXmG5TtVQmGxvgDcnQjWh6Jgda", "fee": 2100000, "feeAssetId": null, "timestamp": 1668073330567, "version": 2, "chainId": 87, "sender": "3P6dkRGSqgsNpQFbSYn9m8n4Dd8KRaj5TUU", "senderPublicKey": "CsS3XguS73w7QRYkLSTsL7VwoFdeGsyEnf8nWgqMYGuc", "proofs": [ "2mdHg4mBK8LKH6HE42vweD4ifNptZt7aymP2BphGSomLheD9FWJMHckX36YNWzVjspy69c8q1jjScZjKEb1ekTQW" ], "script": "base64:BgJmCAISAwoBCBIDCgEIEgYKBAgICAgSBAoCCAgSABIECgIIARIECgIIARIAEggKBgQIAQgICBIGCgQECAQIEgMKAQQSBAoCCAQSBAoCCAQSAwoBBBIDCgEEEgMKAQQSAwoBCBIDCgEEGQAGU2NhbGU4AIDC1y8AB1NjYWxlMTAAgMivoCUAB1NjYWxlMTYJAGgCBQZTY2FsZTgFBlNjYWxlOAALcmVzZXJ2ZUZ1bmQAFAAJZGF5QmxvY2tzAKALAQpsaUludFRvU3RyAQJsaQoBAWYCBWFjY3VtBG5leHQJAKwCAgkArAICBQVhY2N1bQkApAMBBQRuZXh0AgEsCgACJGwFAmxpCgACJHMJAJADAQUCJGwKAAUkYWNjMAIACgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQFmAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhNMaXN0IHNpemUgZXhjZWVkcyA2CQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAQ10cnlHZXRJbnRlZ2VyAQNrZXkEByRtYXRjaDAJAJoIAgUEdGhpcwUDa2V5AwkAAQIFByRtYXRjaDACA0ludAQBYgUHJG1hdGNoMAUBYgAAAQ10cnlHZXRCb29sZWFuAQNrZXkEByRtYXRjaDAJAJsIAgUEdGhpcwUDa2V5AwkAAQIFByRtYXRjaDACB0Jvb2xlYW4EAWIFByRtYXRjaDAFAWIHAQx0cnlHZXRTdHJpbmcBA2tleQQHJG1hdGNoMAkAnQgCBQR0aGlzBQNrZXkDCQABAgUHJG1hdGNoMAIGU3RyaW5nBAFiBQckbWF0Y2gwBQFiAgABDHRyeUdldEJpbmFyeQEDa2V5BAckbWF0Y2gwCQCcCAIFBHRoaXMFA2tleQMJAAECBQckbWF0Y2gwAgpCeXRlVmVjdG9yBAFiBQckbWF0Y2gwBQFiAQABDmdldEFzc2V0U3RyaW5nAQdhc3NldElkBAckbWF0Y2gwBQdhc3NldElkAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEAWIFByRtYXRjaDAJANgEAQUBYgIFV0FWRVMBDWdldEFzc2V0Qnl0ZXMBCmFzc2V0SWRTdHIDCQAAAgUKYXNzZXRJZFN0cgIFV0FWRVMFBHVuaXQJANkEAQUKYXNzZXRJZFN0cgEKZ2V0QmFsYW5jZQEKYXNzZXRJZFN0cgMJAAACBQphc3NldElkU3RyAgVXQVZFUwgJAO8HAQUEdGhpcwlhdmFpbGFibGUJAPAHAgUEdGhpcwkA2QQBBQphc3NldElkU3RyAQ9nZXRNYXJrZXRBc3NldHMACQC1CQIJAQx0cnlHZXRTdHJpbmcBAgxzZXR1cF90b2tlbnMCASwBEmdldEFzc2V0c01heFN1cHBseQAEAXMJAQx0cnlHZXRTdHJpbmcBAg9zZXR1cF9tYXhzdXBwbHkDCQAAAgUBcwIACQDMCAIA////////////AQkAzAgCAP///////////wEJAMwIAgD///////////8BCQDMCAIA////////////AQkAzAgCAP///////////wEJAMwIAgD///////////8BCQDMCAIA////////////AQUDbmlsCQC1CQIFAXMCASwBDWdldE91dGRhdGVkVXIBCmFzc2V0SWRTdHIEBGRvd24JAGsDCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgIPdG90YWxfc3VwcGxpZWRfBQphc3NldElkU3RyCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgUKYXNzZXRJZFN0cgIGX3NSYXRlBQdTY2FsZTE2AwkAAAIFBGRvd24AAAAACQBrAwUGU2NhbGU4CQBrAwkBDXRyeUdldEludGVnZXIBCQCsAgICD3RvdGFsX2JvcnJvd2VkXwUKYXNzZXRJZFN0cgkBDXRyeUdldEludGVnZXIBCQCsAgIFCmFzc2V0SWRTdHICBl9iUmF0ZQUHU2NhbGUxNgUEZG93bgEMZ2V0UmF0ZUN1cnZlAQphc3NldElkU3RyBAckbWF0Y2gwBQphc3NldElkU3RyAwkAAAICLDM0TjlZY0VFVExXbjkzcVlRNjRFc1AxeDg5dFNydUpVNDRSckVNU1hYRVBKBQckbWF0Y2gwCQCWCgQAgIl6AMDw9QsAgOiSJgCAwtcvAwkAAAICLERHMnhGa1BkRHdLVW9Ca3pHQWhRdExwU0d6ZlhMaUNZUEV6ZUtIMkFkMjRwBQckbWF0Y2gwCQCWCgQAgIl6AMDw9QsAgOiSJgCAwtcvAwkAAAICLEFqc282blRUanB0dTJVSEx4NmhmU1hWdEhGdFJCSkNrS1lkNVNBeWo3emY1BQckbWF0Y2gwCQCWCgQAgIl6AIC0iRMAgOiSJgCAo8NHAwkAAAICLEhFQjhRYXc5eHJXcFdzOHRIc2lBVFlHQldEQnRQMlM3a2NQQUxyTXU0M0FTBQckbWF0Y2gwCQCWCgQAAACA2sQJAIDokiYAgLSJEwMJAAACAgVXQVZFUwUHJG1hdGNoMAkAlgoEAICJegCAh6cOAIDokiYAgOHrFwMJAAACAixBdHF2NTlFWXpqRkd1aXRLVm5NUms2SDhGdWtqb1Yza3RQb3JiRXlzMjVvbgUHJG1hdGNoMAkAlgoEAAAAgNrECQCA6JImAIC0iRMDCQAAAgIsRFNiYmhMc1NUZURnNUxzaXVmazJBbmVoM0RqVnFKdVByMk05dVUxZ3d5NXAFByRtYXRjaDAJAJYKBAAAAIDaxAkAgOiSJgCAwtcvAwkAAAICLDh0NERQV1R3UHpwYXRIQTlBa1R4V0FCNDdUSG5ZekJzRG5vWTdmUXFiRzkxBQckbWF0Y2gwCQCWCgQAAACAh6cOAIDokiYAgLSJEwMJAAACAixBdDhENk5GRnBoZUNidktWbmpWb2VMTDg0RW84TlpuNm92TWFueGZMYUZXTAUHJG1hdGNoMAkAlgoEAAAAwPD1CwCA6JImAIC0iRMJAJYKBAAAAIDaxAkAgOiSJgCA6JImAQtnZXRJbnRlcmVzdAEKYXNzZXRJZFN0cgQCdXIJAQ1nZXRPdXRkYXRlZFVyAQUKYXNzZXRJZFN0cgQFY3VydmUJAQxnZXRSYXRlQ3VydmUBBQphc3NldElkU3RyBARyYXRlCQBkAggFBWN1cnZlAl8xAwkAZwIIBQVjdXJ2ZQJfMwUCdXIJAGsDBQJ1cggFBWN1cnZlAl8yCAUFY3VydmUCXzMJAGQCCAUFY3VydmUCXzIJAGsDCQBlAgUCdXIIBQVjdXJ2ZQJfMwkAZQIIBQVjdXJ2ZQJfNAgFBWN1cnZlAl8yCQBlAgCAwtcvCAUFY3VydmUCXzMJAJYDAQkAzAgCCQBrAwUEcmF0ZQUGU2NhbGU4CQBoAgUJZGF5QmxvY2tzAO0CCQDMCAIAAQUDbmlsARB0b2tlblJhdGVzUmVjYWxjAQphc3NldElkU3RyBAhpbnRlcmVzdAkBC2dldEludGVyZXN0AQUKYXNzZXRJZFN0cgQCdXIJAQ1nZXRPdXRkYXRlZFVyAQUKYXNzZXRJZFN0cgQQbGFzdFJlY2FsY0hlaWdodAkBDXRyeUdldEludGVnZXIBAg5sYXN0UmF0ZUhlaWdodAQJbGFzdEJSYXRlCQCWAwEJAMwIAgkBDXRyeUdldEludGVnZXIBCQCsAgIFCmFzc2V0SWRTdHICBl9iUmF0ZQkAzAgCBQdTY2FsZTE2BQNuaWwECG5ld0JSYXRlCQBkAgUJbGFzdEJSYXRlCQBoAgkAZQIFBmhlaWdodAUQbGFzdFJlY2FsY0hlaWdodAUIaW50ZXJlc3QECWxhc3RTUmF0ZQkAlgMBCQDMCAIJAQ10cnlHZXRJbnRlZ2VyAQkArAICBQphc3NldElkU3RyAgZfc1JhdGUJAMwIAgUHU2NhbGUxNgUDbmlsBAhuZXdTUmF0ZQkAZAIFCWxhc3RTUmF0ZQkAaQIJAGgCCQBoAgkAZQIFBmhlaWdodAUQbGFzdFJlY2FsY0hlaWdodAkAawMFCGludGVyZXN0BQJ1cgUGU2NhbGU4CQBlAgBkBQtyZXNlcnZlRnVuZABkCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFCmFzc2V0SWRTdHICBl9zUmF0ZQUIbmV3U1JhdGUJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUKYXNzZXRJZFN0cgIGX2JSYXRlBQhuZXdCUmF0ZQkAzAgCCQEMSW50ZWdlckVudHJ5AgIObGFzdFJhdGVIZWlnaHQFBmhlaWdodAUDbmlsAQ1nZXRBY3R1YWxSYXRlAgphc3NldElkU3RyCHJhdGVUeXBlCgEBZgIFYWNjdW0FdG9rZW4EBnJlY2FsYwkBEHRva2VuUmF0ZXNSZWNhbGMBBQV0b2tlbgkAlAoCAwkBAiE9AgUFdG9rZW4FCmFzc2V0SWRTdHIIBQVhY2N1bQJfMQMJAAACBQhyYXRlVHlwZQIFc1JhdGUICQCRAwIFBnJlY2FsYwAABXZhbHVlCAkAkQMCBQZyZWNhbGMAAQV2YWx1ZQkAzggCCAUFYWNjdW0CXzIFBnJlY2FsYwoAAiRsCQEPZ2V0TWFya2V0QXNzZXRzAAoAAiRzCQCQAwEFAiRsCgAFJGFjYzAJAJQKAgAABQNuaWwKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBAWYCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECE0xpc3Qgc2l6ZSBleGNlZWRzIDYJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYBBWdldFVyAQphc3NldElkU3RyBAVyYXRlcwkBEHRva2VuUmF0ZXNSZWNhbGMBBQphc3NldElkU3RyBARkb3duCQBrAwkBDXRyeUdldEludGVnZXIBCQCsAgICD3RvdGFsX3N1cHBsaWVkXwUKYXNzZXRJZFN0cggJAJEDAgUFcmF0ZXMAAAV2YWx1ZQUHU2NhbGUxNgkAawMFBlNjYWxlOAkAawMJAQ10cnlHZXRJbnRlZ2VyAQkArAICAg90b3RhbF9ib3Jyb3dlZF8FCmFzc2V0SWRTdHIICQCRAwIFBXJhdGVzAAEFdmFsdWUFB1NjYWxlMTYFBGRvd24BC3JhdGVzUmVjYWxjAAoBAWYCBWFjY3VtBXRva2VuCQDOCAIFBWFjY3VtCQEQdG9rZW5SYXRlc1JlY2FsYwEFBXRva2VuCgACJGwJAQ9nZXRNYXJrZXRBc3NldHMACgACJHMJAJADAQUCJGwKAAUkYWNjMAUDbmlsCgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQFmAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhNMaXN0IHNpemUgZXhjZWVkcyA2CQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAQ1nZXRUb2tlblByaWNlAQphc3NldElkU3RyBARpbnYxCQD8BwQJARFAZXh0ck5hdGl2ZSgxMDYyKQECIzNQNUJUdGRqMzJTZDFEeWgxTWR3MzN4UUFBY2tTZk1mbktmAglnZXRUV0FQNjAJAMwIAgUKYXNzZXRJZFN0cgkAzAgCBwUDbmlsBQNuaWwDCQAAAgUEaW52MQUEaW52MQQEaW52MgkA/AcECQERQGV4dHJOYXRpdmUoMTA2MikBAiMzUDhwdm1jQmk5SmVCcm5QZ1dEVGFQV3JXbUd6eGlEa3BUdQIJZ2V0VFdBUDYwCQDMCAIFCmFzc2V0SWRTdHIJAMwIAgcFA25pbAUDbmlsAwkAAAIFBGludjIFBGludjIEBWRhdGExBAckbWF0Y2gwBQRpbnYxAwkAAQIFByRtYXRjaDACCihJbnQsIEludCkEAXgFByRtYXRjaDAFAXgJAAIBAhVlcnJvciBvZiBwcmljZSBvcmFjbGUDCQAAAgUFZGF0YTEFBWRhdGExBAVkYXRhMgQHJG1hdGNoMAUEaW52MgMJAAECBQckbWF0Y2gwAgooSW50LCBJbnQpBAF4BQckbWF0Y2gwBQF4CQACAQIVZXJyb3Igb2YgcHJpY2Ugb3JhY2xlAwkAAAIFBWRhdGEyBQVkYXRhMgkAlAoCCQCXAwEJAMwIAggFBWRhdGExAl8xCQDMCAIIBQVkYXRhMgJfMQUDbmlsCQCWAwEJAMwIAggFBWRhdGExAl8yCQDMCAIIBQVkYXRhMgJfMgUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQ5jYWxjQXNzZXRTY2FsZQEKYXNzZXRJZFN0cgQIZGVjaW1hbHMDCQAAAgUKYXNzZXRJZFN0cgIFV0FWRVMACAgJAQV2YWx1ZQEJAOwHAQkA2QQBBQphc3NldElkU3RyCGRlY2ltYWxzCQBsBgAKAAAFCGRlY2ltYWxzAAAAAAUERE9XTgESY2FsY1VzZXJDb2xsYXRlcmFsAQdhZGRyZXNzBBR1c2VyQ29sbGF0ZXJhbEludm9rZQkA/AcEBQR0aGlzAhFnZXRVc2VyQ29sbGF0ZXJhbAkAzAgCBwkAzAgCBQdhZGRyZXNzCQDMCAIGCQDMCAICAAUDbmlsBQNuaWwDCQAAAgUUdXNlckNvbGxhdGVyYWxJbnZva2UFFHVzZXJDb2xsYXRlcmFsSW52b2tlBBN1c2VyQ29sbGF0ZXJhbFZhbHVlBAckbWF0Y2gwBRR1c2VyQ29sbGF0ZXJhbEludm9rZQMJAAECBQckbWF0Y2gwAgNJbnQEAXgFByRtYXRjaDAFAXgJAAIBAiRpc3N1ZSB3aGlsZSBkb2luZyBpbi1kYXBwIGludm9jYXRpb24DCQAAAgUTdXNlckNvbGxhdGVyYWxWYWx1ZQUTdXNlckNvbGxhdGVyYWxWYWx1ZQUTdXNlckNvbGxhdGVyYWxWYWx1ZQkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLhIBaQENc3Rha2VUb2tlbkFsbAEKYXNzZXRJZFN0cgMJAQIhPQIIBQFpBmNhbGxlcgUEdGhpcwkAAgECLG9ubHkgZm9yIGludGVybmFsIHNtYXJ0IGNvbnRyYWN0IGludm9jYXRpb25zAwkAAAIFCmFzc2V0SWRTdHICBVdBVkVTBAZhbW91bnQJAGUCCQEKZ2V0QmFsYW5jZQECBVdBVkVTAIDC1y8EBWxlYXNlCQDECAIJAQdBZGRyZXNzAQEaAVd30UrAACYPUG2DJbNadoTl4zn5Xg0McUQFBmFtb3VudAQHbGVhc2VJZAkAuQgBBQVsZWFzZQkAzAgCBQVsZWFzZQkAzAgCCQELQmluYXJ5RW50cnkCAhhhdXRvc3Rha2VfbGFzdFdhdmVzTGVhc2UFB2xlYXNlSWQJAMwIAgkBDEludGVnZXJFbnRyeQICFmF1dG9zdGFrZV9hbW91bnRfV0FWRVMFBmFtb3VudAUDbmlsBQNuaWwBaQEPdW5zdGFrZVRva2VuQWxsAQphc3NldElkU3RyAwkBAiE9AggFAWkGY2FsbGVyBQR0aGlzCQACAQIsb25seSBmb3IgaW50ZXJuYWwgc21hcnQgY29udHJhY3QgaW52b2NhdGlvbnMDCQAAAgUKYXNzZXRJZFN0cgIFV0FWRVMEB2xlYXNlSWQJAQx0cnlHZXRCaW5hcnkBAhhhdXRvc3Rha2VfbGFzdFdhdmVzTGVhc2UJAMwIAgkBC0xlYXNlQ2FuY2VsAQUHbGVhc2VJZAkAzAgCCQELRGVsZXRlRW50cnkBAhhhdXRvc3Rha2VfbGFzdFdhdmVzTGVhc2UJAMwIAgkBC0RlbGV0ZUVudHJ5AQIWYXV0b3N0YWtlX2Ftb3VudF9XQVZFUwUDbmlsBQNuaWwBaQEHcHJlSW5pdAQGdG9rZW5zBGx0dnMDbHRzCXBlbmFsdGllcwoBAWYCBWFjY3VtBXRva2VuCQDOCAIFBWFjY3VtCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFBXRva2VuAgZfYlJhdGUFB1NjYWxlMTYJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUFdG9rZW4CBl9zUmF0ZQUHU2NhbGUxNgUDbmlsAwkBAiE9AggFAWkGY2FsbGVyBQR0aGlzCQACAQIKYWRtaW4gb25seQQFcmF0ZXMKAAIkbAkAtQkCBQZ0b2tlbnMCASwKAAIkcwkAkAMBBQIkbAoABSRhY2MwBQNuaWwKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBAWYCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECE0xpc3Qgc2l6ZSBleGNlZWRzIDYJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYJAM4IAgkAzAgCCQELU3RyaW5nRW50cnkCAgxzZXR1cF90b2tlbnMFBnRva2VucwkAzAgCCQELU3RyaW5nRW50cnkCAgpzZXR1cF9sdHZzBQRsdHZzCQDMCAIJAQtTdHJpbmdFbnRyeQICCXNldHVwX2x0cwUDbHRzCQDMCAIJAQtTdHJpbmdFbnRyeQICD3NldHVwX3BlbmFsdGllcwUJcGVuYWx0aWVzCQDMCAIJAQxCb29sZWFuRW50cnkCAgxzZXR1cF9hY3RpdmUGBQNuaWwFBXJhdGVzAWkBD3VwZGF0ZVBhcmFtZXRlcgIDa2V5A3ZhbAMJAQIhPQIIBQFpBmNhbGxlcgUEdGhpcwkAAgECCmFkbWluIG9ubHkJAMwIAgkBC1N0cmluZ0VudHJ5AgUDa2V5BQN2YWwFA25pbAFpAQZzdXBwbHkAAwkBASEBCQENdHJ5R2V0Qm9vbGVhbgECDHNldHVwX2FjdGl2ZQkAAgECEW1hcmtldCBpcyBzdG9wcGVkAwMJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAQYJAAACCAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAAACQACAQIcMSBwYXltZW50IGhhcyB0byBiZSBhdHRhY2hlZAQKYXNzZXRJZFN0cgkBDmdldEFzc2V0U3RyaW5nAQgJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkBAthc3NldEFtb3VudAgJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQECyR0MDc4NTk3OTI2CQENZ2V0QWN0dWFsUmF0ZQIFCmFzc2V0SWRTdHICBXNSYXRlBAVzUmF0ZQgFCyR0MDc4NTk3OTI2Al8xBBFyYXRlc1JlY2FsY1Jlc3VsdAgFCyR0MDc4NTk3OTI2Al8yBAZhbW91bnQJAG4EBQthc3NldEFtb3VudAUHU2NhbGUxNgUFc1JhdGUFBERPV04EB2FkZHJlc3MJAKUIAQgFAWkGY2FsbGVyBAltYXhTdXBwbHkEByRtYXRjaDAJAKIIAQkArAICAhBzZXR1cF9tYXhTdXBwbHlfBQphc3NldElkU3RyAwkAAQIFByRtYXRjaDACBlN0cmluZwQBeAUHJG1hdGNoMAkBDXBhcnNlSW50VmFsdWUBBQF4AAAECmFzc2V0UHJpY2UJAQ1nZXRUb2tlblByaWNlAQUKYXNzZXRJZFN0cgQQbmV3VG90YWxTdXBwbGllZAkAZAIJAQ10cnlHZXRJbnRlZ2VyAQkArAICCQCsAgIFB2FkZHJlc3MCCl9zdXBwbGllZF8FCmFzc2V0SWRTdHIFBmFtb3VudAQEcmF0ZQgJAQ1nZXRBY3R1YWxSYXRlAgUKYXNzZXRJZFN0cgIFc1JhdGUCXzEECmFzc2V0U2NhbGUJAQ5jYWxjQXNzZXRTY2FsZQEFCmFzc2V0SWRTdHIEE25ld1RvdGFsU3VwcGxpZWRVc2QJAGsDCQBrAwUQbmV3VG90YWxTdXBwbGllZAUEcmF0ZQUHU2NhbGUxNggFCmFzc2V0UHJpY2UCXzEFCmFzc2V0U2NhbGUDCQAAAgkAswkCCQEMdHJ5R2V0U3RyaW5nAQIMc2V0dXBfdG9rZW5zBQphc3NldElkU3RyBQR1bml0CQACAQIpdGhpcyBhc3NldCBpcyBub3Qgc3VwcG9ydGVkIGJ5IHRoZSBtYXJrZXQDAwkBAiE9AgUJbWF4U3VwcGx5AAAJAGYCBRNuZXdUb3RhbFN1cHBsaWVkVXNkBQltYXhTdXBwbHkHCQACAQIzbWF4IHRvdGFsIHN1cHBseSBmb3IgdGhpcyB0b2tlbiByZWFjaGVkIGluIHRoZSBwb29sCQDOCAIJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICBQdhZGRyZXNzAgpfc3VwcGxpZWRfBQphc3NldElkU3RyBRBuZXdUb3RhbFN1cHBsaWVkCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgICD3RvdGFsX3N1cHBsaWVkXwUKYXNzZXRJZFN0cgkAZAIJAQ10cnlHZXRJbnRlZ2VyAQkArAICAg90b3RhbF9zdXBwbGllZF8FCmFzc2V0SWRTdHIFBmFtb3VudAUDbmlsBRFyYXRlc1JlY2FsY1Jlc3VsdAFpAQh3aXRoZHJhdwIKYXNzZXRJZFN0cgthc3NldEFtb3VudAQLJHQwOTEwODkxNzUJAQ1nZXRBY3R1YWxSYXRlAgUKYXNzZXRJZFN0cgIFc1JhdGUEBXNSYXRlCAULJHQwOTEwODkxNzUCXzEEEXJhdGVzUmVjYWxjUmVzdWx0CAULJHQwOTEwODkxNzUCXzIEBmFtb3VudAkAbgQFC2Fzc2V0QW1vdW50BQdTY2FsZTE2BQVzUmF0ZQUHQ0VJTElORwQHYWRkcmVzcwkApQgBCAUBaQZjYWxsZXIEDWFzc2V0U3VwcGxpZWQJAQ10cnlHZXRJbnRlZ2VyAQkArAICAg90b3RhbF9zdXBwbGllZF8FCmFzc2V0SWRTdHIEDWFzc2V0Qm9ycm93ZWQJAQ10cnlHZXRJbnRlZ2VyAQkArAICAg90b3RhbF9ib3Jyb3dlZF8FCmFzc2V0SWRTdHIEEXVzZXJBc3NldFN1cHBsaWVkCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICBQdhZGRyZXNzAgpfc3VwcGxpZWRfBQphc3NldElkU3RyBBF1c2VyQXNzZXRCb3Jyb3dlZAkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgUHYWRkcmVzcwIKX2JvcnJvd2VkXwUKYXNzZXRJZFN0cgQSY29sbGF0ZXJhbFZhbHVlSW52CQD8BwQFBHRoaXMCEWdldFVzZXJDb2xsYXRlcmFsCQDMCAIHCQDMCAIFB2FkZHJlc3MJAMwIAgYJAMwIAgkArAICCQCsAgIFCmFzc2V0SWRTdHICCixzdXBwbGllZCwJAKQDAQkBAS0BBQZhbW91bnQFA25pbAUDbmlsAwkAAAIFEmNvbGxhdGVyYWxWYWx1ZUludgUSY29sbGF0ZXJhbFZhbHVlSW52BA9jb2xsYXRlcmFsVmFsdWUEByRtYXRjaDAFEmNvbGxhdGVyYWxWYWx1ZUludgMJAAECBQckbWF0Y2gwAgNJbnQEAXgFByRtYXRjaDAFAXgJAAIBAh9jYW4ndCBnZXQgdXNlciBjb2xsYXRlcmFsIHZhbHVlAwkBASEBCQENdHJ5R2V0Qm9vbGVhbgECDHNldHVwX2FjdGl2ZQkAAgECEW1hcmtldCBpcyBzdG9wcGVkAwkAZgIAAAUPY29sbGF0ZXJhbFZhbHVlCQACAQIyeW91IGRvbnQgaGF2ZSBlbm91Z2ggY29sbGF0ZXJhbCBmb3IgdGhpcyBvcGVyYXRpb24DCQBmAgUGYW1vdW50CQBlAgUNYXNzZXRTdXBwbGllZAUNYXNzZXRCb3Jyb3dlZAkAAgECKnRoaXMgYW1vdW50IGlzIG5vdCBhdmFpbGFibGUgb24gdGhlIG1hcmtldAMJAGYCBQZhbW91bnQJAGUCBRF1c2VyQXNzZXRTdXBwbGllZAURdXNlckFzc2V0Qm9ycm93ZWQJAAIBAip0aGlzIGFtb3VudCBpcyBub3QgYXZhaWxhYmxlIGZvciB0aGlzIHVzZXIJAM4IAgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgIFB2FkZHJlc3MCCl9zdXBwbGllZF8FCmFzc2V0SWRTdHIJAGUCCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICBQdhZGRyZXNzAgpfc3VwcGxpZWRfBQphc3NldElkU3RyBQZhbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgIPdG90YWxfc3VwcGxpZWRfBQphc3NldElkU3RyCQBlAgkBDXRyeUdldEludGVnZXIBCQCsAgICD3RvdGFsX3N1cHBsaWVkXwUKYXNzZXRJZFN0cgUGYW1vdW50CQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgULYXNzZXRBbW91bnQJAQ1nZXRBc3NldEJ5dGVzAQUKYXNzZXRJZFN0cgUDbmlsBRFyYXRlc1JlY2FsY1Jlc3VsdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQZib3Jyb3cCCmFzc2V0SWRTdHILYXNzZXRBbW91bnQEB2FkZHJlc3MJAKUIAQgFAWkGY2FsbGVyBA0kdDAxMDY2ODEwNzM1CQENZ2V0QWN0dWFsUmF0ZQIFCmFzc2V0SWRTdHICBWJSYXRlBAViUmF0ZQgFDSR0MDEwNjY4MTA3MzUCXzEEEXJhdGVzUmVjYWxjUmVzdWx0CAUNJHQwMTA2NjgxMDczNQJfMgQGYW1vdW50CQBuBAULYXNzZXRBbW91bnQFB1NjYWxlMTYFBWJSYXRlBQdDRUlMSU5HBBJjb2xsYXRlcmFsVmFsdWVJbnYJAPwHBAUEdGhpcwIRZ2V0VXNlckNvbGxhdGVyYWwJAMwIAgcJAMwIAgUHYWRkcmVzcwkAzAgCBgkAzAgCCQCsAgIJAKwCAgUKYXNzZXRJZFN0cgIKLGJvcnJvd2VkLAkApAMBBQZhbW91bnQFA25pbAUDbmlsAwkAAAIFEmNvbGxhdGVyYWxWYWx1ZUludgUSY29sbGF0ZXJhbFZhbHVlSW52BA9jb2xsYXRlcmFsVmFsdWUEByRtYXRjaDAFEmNvbGxhdGVyYWxWYWx1ZUludgMJAAECBQckbWF0Y2gwAgNJbnQEAXgFByRtYXRjaDAFAXgJAAIBAh9jYW4ndCBnZXQgdXNlciBjb2xsYXRlcmFsIHZhbHVlAwkBASEBCQENdHJ5R2V0Qm9vbGVhbgECDHNldHVwX2FjdGl2ZQkAAgECEW1hcmtldCBpcyBzdG9wcGVkAwkAZgIAAAUPY29sbGF0ZXJhbFZhbHVlCQACAQIheW91IGhhdmUgdG8gc3VwcGx5IG1vcmUgdG8gYm9ycm93BA1hc3NldFN1cHBsaWVkCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgIPdG90YWxfc3VwcGxpZWRfBQphc3NldElkU3RyBA1hc3NldEJvcnJvd2VkCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgIPdG90YWxfYm9ycm93ZWRfBQphc3NldElkU3RyBBF1c2VyQXNzZXRCb3Jyb3dlZAkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgUHYWRkcmVzcwIKX2JvcnJvd2VkXwUKYXNzZXRJZFN0cgMJAGYCBQZhbW91bnQJAGUCBQ1hc3NldFN1cHBsaWVkBQ1hc3NldEJvcnJvd2VkCQACAQIcdGhpcyBhbW91bnQgaXMgbm90IGF2YWlsYWJsZQkAzggCCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgUHYWRkcmVzcwIKX2JvcnJvd2VkXwUKYXNzZXRJZFN0cgkAZAIFEXVzZXJBc3NldEJvcnJvd2VkBQZhbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgIPdG90YWxfYm9ycm93ZWRfBQphc3NldElkU3RyCQBkAgUNYXNzZXRCb3Jyb3dlZAUGYW1vdW50CQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgULYXNzZXRBbW91bnQJAQ1nZXRBc3NldEJ5dGVzAQUKYXNzZXRJZFN0cgUDbmlsBRFyYXRlc1JlY2FsY1Jlc3VsdAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQVyZXBheQADCQEBIQEJAQ10cnlHZXRCb29sZWFuAQIMc2V0dXBfYWN0aXZlCQACAQIRbWFya2V0IGlzIHN0b3BwZWQDAwkBAiE9AgkAkAMBCAUBaQhwYXltZW50cwABBgkAAAIICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50AAAJAAIBAhwxIHBheW1lbnQgaGFzIHRvIGJlIGF0dGFjaGVkBAphc3NldElkU3RyCQEOZ2V0QXNzZXRTdHJpbmcBCAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQEC2Fzc2V0QW1vdW50CAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAQNJHQwMTIxNTkxMjIyNgkBDWdldEFjdHVhbFJhdGUCBQphc3NldElkU3RyAgViUmF0ZQQFYlJhdGUIBQ0kdDAxMjE1OTEyMjI2Al8xBBFyYXRlc1JlY2FsY1Jlc3VsdAgFDSR0MDEyMTU5MTIyMjYCXzIEBmFtb3VudAkAbgQFC2Fzc2V0QW1vdW50BQdTY2FsZTE2BQViUmF0ZQUHQ0VJTElORwQHYWRkcmVzcwkApQgBCAUBaQZjYWxsZXIEDWFzc2V0U3VwcGxpZWQJAQ10cnlHZXRJbnRlZ2VyAQkArAICAg90b3RhbF9zdXBwbGllZF8FCmFzc2V0SWRTdHIEDWFzc2V0Qm9ycm93ZWQJAQ10cnlHZXRJbnRlZ2VyAQkArAICAg90b3RhbF9ib3Jyb3dlZF8FCmFzc2V0SWRTdHIEEXVzZXJBc3NldEJvcnJvd2VkCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICBQdhZGRyZXNzAgpfYm9ycm93ZWRfBQphc3NldElkU3RyBAphbW91bnRMZWZ0CQBlAgURdXNlckFzc2V0Qm9ycm93ZWQFBmFtb3VudAQLcmVwYXlBbW91bnQDCQBnAgUKYW1vdW50TGVmdAAABQZhbW91bnQFEXVzZXJBc3NldEJvcnJvd2VkAwkAAAIJALMJAgkBDHRyeUdldFN0cmluZwECDHNldHVwX3Rva2VucwUKYXNzZXRJZFN0cgUEdW5pdAkAAgECKXRoaXMgYXNzZXQgaXMgbm90IHN1cHBvcnRlZCBieSB0aGUgbWFya2V0CQDOCAIJAM4IAgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgIFB2FkZHJlc3MCCl9ib3Jyb3dlZF8FCmFzc2V0SWRTdHIJAGUCBRF1c2VyQXNzZXRCb3Jyb3dlZAULcmVwYXlBbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgIPdG90YWxfYm9ycm93ZWRfBQphc3NldElkU3RyCQBlAgUNYXNzZXRCb3Jyb3dlZAULcmVwYXlBbW91bnQFA25pbAURcmF0ZXNSZWNhbGNSZXN1bHQDCQBnAgUKYW1vdW50TGVmdAAABQNuaWwJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyCQEBLQEFCmFtb3VudExlZnQICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAUDbmlsAWkBCWxpcXVpZGF0ZQYFZGVidWcHYWRkcmVzcwthc3NldEFtb3VudAtzQXNzZXRJZFN0cgtiQXNzZXRJZFN0cghyb3V0ZVN0cgMJAQIhPQIIBQFpBmNhbGxlcgkBB0FkZHJlc3MBARoBV3eqztF4Vuipnl6rle+/6eFxWHVeMppxgQkAAgECJXRlbXBvcmFyaWx5IGxpc3RlZCBmb3Igd2hpdGVsaXN0IG9ubHkDCQEBIQEJAQ10cnlHZXRCb29sZWFuAQIMc2V0dXBfYWN0aXZlCQACAQIRbWFya2V0IGlzIHN0b3BwZWQEDnVzZXJDb2xsYXRlcmFsCQESY2FsY1VzZXJDb2xsYXRlcmFsAQUHYWRkcmVzcwMJAAACBQ51c2VyQ29sbGF0ZXJhbAUOdXNlckNvbGxhdGVyYWwEDSR0MDEzNTk5MTM2NjgJAQ1nZXRBY3R1YWxSYXRlAgULc0Fzc2V0SWRTdHICBXNSYXRlBAVzUmF0ZQgFDSR0MDEzNTk5MTM2NjgCXzEEEnJhdGVzUmVjYWxjUmVzdWx0MQgFDSR0MDEzNTk5MTM2NjgCXzIEDSR0MDEzNjczMTM3NDIJAQ1nZXRBY3R1YWxSYXRlAgULYkFzc2V0SWRTdHICBWJSYXRlBAViUmF0ZQgFDSR0MDEzNjczMTM3NDICXzEEEnJhdGVzUmVjYWxjUmVzdWx0MggFDSR0MDEzNjczMTM3NDICXzIEDHNBc3NldEFtb3VudAkAawMFC2Fzc2V0QW1vdW50BQdTY2FsZTE2BQVzUmF0ZQQQY3VycmVudFNQb3NpdGlvbgkBDXRyeUdldEludGVnZXIBCQCsAgIJAKwCAgUHYWRkcmVzcwIKX3N1cHBsaWVkXwULc0Fzc2V0SWRTdHIEEGN1cnJlbnRCUG9zaXRpb24JAQ10cnlHZXRJbnRlZ2VyAQkArAICCQCsAgIFB2FkZHJlc3MCCl9ib3Jyb3dlZF8FC2JBc3NldElkU3RyAwkAZgIFDnVzZXJDb2xsYXRlcmFsAAAJAAIBAhh1c2VyIGNhbid0IGJlIGxpcXVpZGF0ZWQDCQBmAgUMc0Fzc2V0QW1vdW50BRBjdXJyZW50U1Bvc2l0aW9uCQACAQIycG9zaXRpb24gdG8gbGlxdWlkYXRlIGlzIGJpZ2dlciB0aGFuIHVzZXIncyBzdXBwbHkEEWFnZ3JlZ2F0b3JBZGRyZXNzCQEHQWRkcmVzcwEBGgFXnQyqxhNRqW7LgPdjfcFkeOLvck2oDLrTBA5iYWxhbmNlMEJlZm9yZQkBCmdldEJhbGFuY2UBBQtzQXNzZXRJZFN0cgMJAAACBQ5iYWxhbmNlMEJlZm9yZQUOYmFsYW5jZTBCZWZvcmUEDmJhbGFuY2UxQmVmb3JlCQEKZ2V0QmFsYW5jZQEFC2JBc3NldElkU3RyAwkAAAIFDmJhbGFuY2UxQmVmb3JlBQ5iYWxhbmNlMUJlZm9yZQQOZXhjaGFuZ2VJbnZva2UJAPwHBAURYWdncmVnYXRvckFkZHJlc3MCBHN3YXAJAMwIAgUIcm91dGVTdHIJAMwIAgAABQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJAQ1nZXRBc3NldEJ5dGVzAQULc0Fzc2V0SWRTdHIFC2Fzc2V0QW1vdW50BQNuaWwDCQAAAgUOZXhjaGFuZ2VJbnZva2UFDmV4Y2hhbmdlSW52b2tlBAphc3NldDBTb2xkCQBlAgUOYmFsYW5jZTBCZWZvcmUJAQpnZXRCYWxhbmNlAQULc0Fzc2V0SWRTdHIDCQAAAgUKYXNzZXQwU29sZAUKYXNzZXQwU29sZAQMYXNzZXQxQm91Z2h0CQBlAgkBCmdldEJhbGFuY2UBBQtiQXNzZXRJZFN0cgUOYmFsYW5jZTFCZWZvcmUDCQAAAgUMYXNzZXQxQm91Z2h0BQxhc3NldDFCb3VnaHQEC2Fzc2V0MFByaWNlCAkBDWdldFRva2VuUHJpY2UBBQtzQXNzZXRJZFN0cgJfMgQLYXNzZXQwU2NhbGUJAQ5jYWxjQXNzZXRTY2FsZQEFC3NBc3NldElkU3RyBAlhc3NldDBVc2QJAGsDBQphc3NldDBTb2xkBQthc3NldDBQcmljZQULYXNzZXQwU2NhbGUEC2Fzc2V0MVByaWNlCAkBDWdldFRva2VuUHJpY2UBBQtiQXNzZXRJZFN0cgJfMQQLYXNzZXQxU2NhbGUJAQ5jYWxjQXNzZXRTY2FsZQEFC2JBc3NldElkU3RyBAlhc3NldDFVc2QJAGsDBQxhc3NldDFCb3VnaHQFC2Fzc2V0MVByaWNlBQthc3NldDFTY2FsZQQHcGVuYWx0eQkBDXBhcnNlSW50VmFsdWUBCQCRAwIJALUJAgkBDHRyeUdldFN0cmluZwECD3NldHVwX3BlbmFsdGllcwIBLAkBBXZhbHVlAQkAzwgCCQEPZ2V0TWFya2V0QXNzZXRzAAULYkFzc2V0SWRTdHIEEWxpcXVpZGF0aW9uUHJvZml0CQBlAgUJYXNzZXQxVXNkCQBrAwUJYXNzZXQwVXNkCQBlAgUGU2NhbGU4BQdwZW5hbHR5BQZTY2FsZTgEDHNBc3NldENoYW5nZQkAawMFCmFzc2V0MFNvbGQFB1NjYWxlMTYFBXNSYXRlBAxiQXNzZXRDaGFuZ2UJAGsDBQxhc3NldDFCb3VnaHQFB1NjYWxlMTYFBWJSYXRlAwkAZgIFCmFzc2V0MFNvbGQFC2Fzc2V0QW1vdW50CQACAQIjbW9yZSBhc3NldHMgZXhjaGFuZ2VkIHRoYW4gZXhwZWN0ZWQDCQBmAgAABRFsaXF1aWRhdGlvblByb2ZpdAkAAgECL3ByaWNlIGltcGFjdCBpcyBiaWdnZXIgdGhhbiBsaXF1aWRhdGlvbiBwZW5hbHR5CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgUHYWRkcmVzcwIKX3N1cHBsaWVkXwULc0Fzc2V0SWRTdHIJAGUCBRBjdXJyZW50U1Bvc2l0aW9uBQxzQXNzZXRDaGFuZ2UJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICBQdhZGRyZXNzAgpfYm9ycm93ZWRfBQtiQXNzZXRJZFN0cgkAZQIFEGN1cnJlbnRCUG9zaXRpb24FDGJBc3NldENoYW5nZQkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICAg90b3RhbF9zdXBwbGllZF8FC3NBc3NldElkU3RyCQBlAgkBDXRyeUdldEludGVnZXIBCQCsAgICD3RvdGFsX3N1cHBsaWVkXwULc0Fzc2V0SWRTdHIFDHNBc3NldENoYW5nZQkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICAg90b3RhbF9ib3Jyb3dlZF8FC2JBc3NldElkU3RyCQBlAgkBDXRyeUdldEludGVnZXIBCQCsAgICD3RvdGFsX2JvcnJvd2VkXwULYkFzc2V0SWRTdHIFDGJBc3NldENoYW5nZQkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFEWxpcXVpZGF0aW9uUHJvZml0CQENZ2V0QXNzZXRCeXRlcwEFC2JBc3NldElkU3RyBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQERZ2V0VXNlckNvbGxhdGVyYWwEBWRlYnVnB2FkZHJlc3MNbWludXNCb3Jyb3dlZAthZnRlckNoYW5nZQQGYXNzZXRzCQEPZ2V0TWFya2V0QXNzZXRzAAQEbHR2cwkAtQkCCQEMdHJ5R2V0U3RyaW5nAQIKc2V0dXBfbHR2cwIBLAQDbHRzCQC1CQIJAQx0cnlHZXRTdHJpbmcBAglzZXR1cF9sdHMCASwEBXJhdGVzCAkBDWdldEFjdHVhbFJhdGUCCQCRAwIFBmFzc2V0cwAAAgVzUmF0ZQJfMgQNY2hhbmdlSGFuZGxlcgkAtQkCBQthZnRlckNoYW5nZQIBLAoBAWYCBWFjY3VtBG5leHQDCQBnAgUEbmV4dAkAkAMBBQZhc3NldHMFBWFjY3VtBAhkZWNpbWFscwMJAAACCQCRAwIFBmFzc2V0cwUEbmV4dAIFV0FWRVMACAgJAQV2YWx1ZQEJAOwHAQkA2QQBCQCRAwIFBmFzc2V0cwUEbmV4dAhkZWNpbWFscwQKYXNzZXRTY2FsZQkAbAYACgAABQhkZWNpbWFscwAAAAAFBERPV04ECmFzc2V0UHJpY2UJAQ1nZXRUb2tlblByaWNlAQkAkQMCBQZhc3NldHMFBG5leHQJAGUCCQBkAgUFYWNjdW0JAGsDCQBrAwkAawMJAGQCCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICBQdhZGRyZXNzAgpfc3VwcGxpZWRfCQCRAwIFBmFzc2V0cwUEbmV4dAMDAwkBAiE9AgULYWZ0ZXJDaGFuZ2UCAAkAAAIJAJEDAgUNY2hhbmdlSGFuZGxlcgAACQCRAwIFBmFzc2V0cwUEbmV4dAcJAAACCQCRAwIFDWNoYW5nZUhhbmRsZXIAAQIIc3VwcGxpZWQHCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUNY2hhbmdlSGFuZGxlcgACAAAICQCRAwIFBXJhdGVzCQBoAgUEbmV4dAADBXZhbHVlBQdTY2FsZTE2CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUEbHR2cwUEbmV4dAUGU2NhbGU4CAUKYXNzZXRQcmljZQJfMQUKYXNzZXRTY2FsZQMFDW1pbnVzQm9ycm93ZWQJAGsDCQBrAwkAawMJAGQCCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICBQdhZGRyZXNzAgpfYm9ycm93ZWRfCQCRAwIFBmFzc2V0cwUEbmV4dAMDAwkBAiE9AgULYWZ0ZXJDaGFuZ2UCAAkAAAIJAJEDAgUNY2hhbmdlSGFuZGxlcgAACQCRAwIFBmFzc2V0cwUEbmV4dAcJAAACCQCRAwIFDWNoYW5nZUhhbmRsZXIAAQIIYm9ycm93ZWQHCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUNY2hhbmdlSGFuZGxlcgACAAAICQCRAwIFBXJhdGVzCQBkAgkAaAIFBG5leHQAAwABBXZhbHVlBQdTY2FsZTE2BQZTY2FsZTgJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQNsdHMFBG5leHQIBQphc3NldFByaWNlAl8yBQphc3NldFNjYWxlAAAEBnJlc3VsdAoAAiRsCQDMCAIAAAkAzAgCAAEJAMwIAgACCQDMCAIAAwkAzAgCAAQJAMwIAgAFBQNuaWwKAAIkcwkAkAMBBQIkbAoABSRhY2MwAAAKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBAWYCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECE0xpc3Qgc2l6ZSBleGNlZWRzIDYJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYDBQVkZWJ1ZwkAAgEJAKQDAQUGcmVzdWx0CQCUCgIFBXJhdGVzBQZyZXN1bHQBaQEJZ2V0UHJpY2VzAQVkZWJ1ZwQGYXNzZXRzCQEPZ2V0TWFya2V0QXNzZXRzAAoBAWYCBWFjY3VtBG5leHQDCQBnAgUEbmV4dAkAkAMBBQZhc3NldHMFBWFjY3VtBAphc3NldFByaWNlCQENZ2V0VG9rZW5QcmljZQEJAJEDAgUGYXNzZXRzBQRuZXh0CQCsAgIJAKwCAgkArAICCQCsAgIFBWFjY3VtCQCkAwEIBQphc3NldFByaWNlAl8xAgEsCQCkAwEIBQphc3NldFByaWNlAl8yAgF8BAZyZXN1bHQKAAIkbAkAzAgCAAAJAMwIAgABCQDMCAIAAgkAzAgCAAMJAMwIAgAECQDMCAIABQUDbmlsCgACJHMJAJADAQUCJGwKAAUkYWNjMAIACgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQFmAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhNMaXN0IHNpemUgZXhjZWVkcyA2CQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAwUFZGVidWcJAAIBBQZyZXN1bHQJAJQKAgUDbmlsBQZyZXN1bHQBaQEZY2FsY3VsYXRlVXRpbGl6YXRpb25SYXRpbwIKYXNzZXRJZFN0cgVkZWJ1ZwMFBWRlYnVnCQACAQkApAMBCQEFZ2V0VXIBBQphc3NldElkU3RyCQCUCgIFA25pbAkBBWdldFVyAQUKYXNzZXRJZFN0cgFpARNjYWxjdWxhdGVPdXRkYXRlZFVSAgphc3NldElkU3RyBWRlYnVnAwUFZGVidWcJAAIBCQCkAwEJAQ1nZXRPdXRkYXRlZFVyAQUKYXNzZXRJZFN0cgkAlAoCBQNuaWwJAQ1nZXRPdXRkYXRlZFVyAQUKYXNzZXRJZFN0cgFpARNjYWxjdWxhdGVUb2tlblJhdGVzAQVkZWJ1ZwoBAWYCBWFjY3VtCmFzc2V0SWRTdHIEBXJhdGVzCQEQdG9rZW5SYXRlc1JlY2FsYwEFCmFzc2V0SWRTdHIJAJQKAgkArAICCQCsAgIJAKwCAgkArAICCAUFYWNjdW0CXzEJAKQDAQgJAJEDAgUFcmF0ZXMAAQV2YWx1ZQIBfAkApAMBCAkAkQMCBQVyYXRlcwAABXZhbHVlAgEsCQDOCAIIBQVhY2N1bQJfMgUFcmF0ZXMECXBhcmFtZXRlcgoAAiRsCQEPZ2V0TWFya2V0QXNzZXRzAAoAAiRzCQCQAwEFAiRsCgAFJGFjYzAJAJQKAgIABQNuaWwKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBAWYCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECE0xpc3Qgc2l6ZSBleGNlZWRzIDYJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYDBQVkZWJ1ZwkAAgEIBQlwYXJhbWV0ZXICXzEJAJQKAggFCXBhcmFtZXRlcgJfMggFCXBhcmFtZXRlcgJfMQFpARdjYWxjdWxhdGVUb2tlbnNJbnRlcmVzdAEFZGVidWcKAQFmAgVhY2N1bQphc3NldElkU3RyBARyYXRlCQBrAwkBC2dldEludGVyZXN0AQUKYXNzZXRJZFN0cgUJZGF5QmxvY2tzBQZTY2FsZTgJAKwCAgkArAICBQVhY2N1bQkApAMBBQRyYXRlAgEsBAlwYXJhbWV0ZXIKAAIkbAkBD2dldE1hcmtldEFzc2V0cwAKAAIkcwkAkAMBBQIkbAoABSRhY2MwAgAKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBAWYCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECE0xpc3Qgc2l6ZSBleGNlZWRzIDYJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYDBQVkZWJ1ZwkAAgEFCXBhcmFtZXRlcgkAlAoCBQNuaWwFCXBhcmFtZXRlcgFpARxjYWxjdWxhdGVSZXNlcnZlRmVlVW5jbGFpbWVkAQVkZWJ1ZwQGYXNzZXRzCQEPZ2V0TWFya2V0QXNzZXRzAAQFcmF0ZXMICQENZ2V0QWN0dWFsUmF0ZQIJAJEDAgUGYXNzZXRzAAACBXNSYXRlAl8yBAJsaQkAzAgCAAAJAMwIAgABCQDMCAIAAgkAzAgCAAMJAMwIAgAECQDMCAIABQUDbmlsCgEBZgIFYWNjdW0BbgMJAGcCBQFuCQCQAwEFBmFzc2V0cwUFYWNjdW0ECmFzc2V0SWRTdHIJAJEDAgUGYXNzZXRzBQFuCQDOCAIFBWFjY3VtCQDMCAIJAGUCCQBkAgkBCmdldEJhbGFuY2UBBQphc3NldElkU3RyCQBrAwkBDXRyeUdldEludGVnZXIBCQCsAgICD3RvdGFsX2JvcnJvd2VkXwUKYXNzZXRJZFN0cggJAJEDAgUFcmF0ZXMJAGQCCQBoAgUBbgADAAEFdmFsdWUFB1NjYWxlMTYJAGsDCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgIPdG90YWxfc3VwcGxpZWRfBQphc3NldElkU3RyCAkAkQMCBQVyYXRlcwkAaAIFAW4AAwV2YWx1ZQUHU2NhbGUxNgUDbmlsBAlwYXJhbWV0ZXIKAAIkbAUCbGkKAAIkcwkAkAMBBQIkbAoABSRhY2MwBQNuaWwKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBAWYCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECE0xpc3Qgc2l6ZSBleGNlZWRzIDYJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYDBQVkZWJ1ZwkAAgEJAQpsaUludFRvU3RyAQUJcGFyYW1ldGVyCQCUCgIFA25pbAUJcGFyYW1ldGVyAWkBB3JlU2V0dXABCmFzc2V0SWRTdHIEC2xhc3RSZXNldHVwCQENdHJ5R2V0SW50ZWdlcgECEnJlc2V0dXBfbGFzdFVwZGF0ZQMJAGYCBQlkYXlCbG9ja3MJAGUCBQZoZWlnaHQFC2xhc3RSZXNldHVwCQACAQIgY2FuIGJlIHVwZGF0ZWQgb25seSBvbmNlIHBlciBkYXkEA2x0cwkAtQkCCQEMdHJ5R2V0U3RyaW5nAQIJc2V0dXBfbHRzAgEsBAZhc3NldHMJAQ9nZXRNYXJrZXRBc3NldHMABAJ1cgkBBWdldFVyAQUKYXNzZXRJZFN0cgQGdGVtcExUCQENdHJ5R2V0SW50ZWdlcgEJAKwCAgkArAICAgZzZXR1cF8FCmFzc2V0SWRTdHICB190ZW1wTFQEAmx0CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUGYXNzZXRzCQEFdmFsdWUBCQDPCAIFBmFzc2V0cwUKYXNzZXRJZFN0cgMJAGYCBQJ1cgCAlfUqCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgIGc2V0dXBfBQphc3NldElkU3RyAgdfdGVtcExUCQBrAwUGdGVtcExUAPdNAJBOBQNuaWwDAwkAZgIFAmx0BQZ0ZW1wTFQJAGYCAICV9SoFAnVyBwkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgICBnNldHVwXwUKYXNzZXRJZFN0cgIHX3RlbXBMVAkAawMFBnRlbXBMVACpTgCQTgUDbmlsBQNuaWwBaQEIc2h1dGRvd24BCHNodXRkb3duBAl3aGl0ZWxpc3QJAMwIAgEaAVfX4SNRjnyriFrV1yiXddiIddOPriMFpuEJAMwIAgEaAVdjDQOBpn9bVNIcueQoKvOngDTw2LWN1WUJAMwIAgEaAVez1ZJUSQmaKhD7xvifEHar7z8PcqWJFYwJAMwIAgEaAVf4+voCJsBRi+xqO0YzSdIccbB1i/mkypoJAMwIAgEaAVeh366+RZ25hhHTmGJxiYX0W3lLIIfzR2sJAMwIAgEaAVcwORzRpGYYO35/49jeov24Z5j/V00RJp0FA25pbAMJAAACCQDPCAIFCXdoaXRlbGlzdAgIBQFpBmNhbGxlcgVieXRlcwUEdW5pdAkAAgECF3VzZXIgbm90IGluIGEgd2hpdGVsaXN0CQDMCAIJAQxCb29sZWFuRW50cnkCAgxzZXR1cF9hY3RpdmUJAQEhAQUIc2h1dGRvd24FA25pbAECdHgBBnZlcmlmeQAJAPQDAwgFAnR4CWJvZHlCeXRlcwkAkQMCCAUCdHgGcHJvb2ZzAAAIBQJ0eA9zZW5kZXJQdWJsaWNLZXlyV2Xt", "height": 3376234, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 56ssBUwEhjDeyusHoSbfnqAXNxgv8ohwLdksaJ67czF Next: Z6HQUViccwBYjTGrm5pWYs1DjXAMdxS74fkmdrMcW2v Diff:
OldNewDifferences
259259 else if ((assetIdStr == "WAVES"))
260260 then {
261261 let amount = (getBalance("WAVES") - 100000000)
262- let lease = Lease(Address(base58''), amount)
262+ let lease = Lease(Address(base58'3PCrRrwHEjGXFjYtXDsNv78f3Ch3CH3p6V1'), amount)
263263 let leaseId = calculateLeaseId(lease)
264264 [lease, BinaryEntry("autostake_lastWavesLease", leaseId), IntegerEntry("autostake_amount_WAVES", amount)]
265265 }
323323 else {
324324 let assetIdStr = getAssetString(i.payments[0].assetId)
325325 let assetAmount = i.payments[0].amount
326- let $t078247891 = getActualRate(assetIdStr, "sRate")
327- let sRate = $t078247891._1
328- let ratesRecalcResult = $t078247891._2
326+ let $t078597926 = getActualRate(assetIdStr, "sRate")
327+ let sRate = $t078597926._1
328+ let ratesRecalcResult = $t078597926._2
329329 let amount = fraction(assetAmount, Scale16, sRate, DOWN)
330330 let address = toString(i.caller)
331331 let maxSupply = match getString(("setup_maxSupply_" + assetIdStr)) {
352352
353353 @Callable(i)
354354 func withdraw (assetIdStr,assetAmount) = {
355- let $t090739140 = getActualRate(assetIdStr, "sRate")
356- let sRate = $t090739140._1
357- let ratesRecalcResult = $t090739140._2
355+ let $t091089175 = getActualRate(assetIdStr, "sRate")
356+ let sRate = $t091089175._1
357+ let ratesRecalcResult = $t091089175._2
358358 let amount = fraction(assetAmount, Scale16, sRate, CEILING)
359359 let address = toString(i.caller)
360360 let assetSupplied = tryGetInteger(("total_supplied_" + assetIdStr))
388388 @Callable(i)
389389 func borrow (assetIdStr,assetAmount) = {
390390 let address = toString(i.caller)
391- let $t01063310700 = getActualRate(assetIdStr, "bRate")
392- let bRate = $t01063310700._1
393- let ratesRecalcResult = $t01063310700._2
391+ let $t01066810735 = getActualRate(assetIdStr, "bRate")
392+ let bRate = $t01066810735._1
393+ let ratesRecalcResult = $t01066810735._2
394394 let amount = fraction(assetAmount, Scale16, bRate, CEILING)
395395 let collateralValueInv = invoke(this, "getUserCollateral", [false, address, true, ((assetIdStr + ",borrowed,") + toString(amount))], nil)
396396 if ((collateralValueInv == collateralValueInv))
429429 else {
430430 let assetIdStr = getAssetString(i.payments[0].assetId)
431431 let assetAmount = i.payments[0].amount
432- let $t01212412191 = getActualRate(assetIdStr, "bRate")
433- let bRate = $t01212412191._1
434- let ratesRecalcResult = $t01212412191._2
432+ let $t01215912226 = getActualRate(assetIdStr, "bRate")
433+ let bRate = $t01215912226._1
434+ let ratesRecalcResult = $t01215912226._2
435435 let amount = fraction(assetAmount, Scale16, bRate, CEILING)
436436 let address = toString(i.caller)
437437 let assetSupplied = tryGetInteger(("total_supplied_" + assetIdStr))
459459 let userCollateral = calcUserCollateral(address)
460460 if ((userCollateral == userCollateral))
461461 then {
462- let $t01356413633 = getActualRate(sAssetIdStr, "sRate")
463- let sRate = $t01356413633._1
464- let ratesRecalcResult1 = $t01356413633._2
465- let $t01363813707 = getActualRate(bAssetIdStr, "bRate")
466- let bRate = $t01363813707._1
467- let ratesRecalcResult2 = $t01363813707._2
462+ let $t01359913668 = getActualRate(sAssetIdStr, "sRate")
463+ let sRate = $t01359913668._1
464+ let ratesRecalcResult1 = $t01359913668._2
465+ let $t01367313742 = getActualRate(bAssetIdStr, "bRate")
466+ let bRate = $t01367313742._1
467+ let ratesRecalcResult2 = $t01367313742._2
468468 let sAssetAmount = fraction(assetAmount, Scale16, sRate)
469469 let currentSPosition = tryGetInteger(((address + "_supplied_") + sAssetIdStr))
470470 let currentBPosition = tryGetInteger(((address + "_borrowed_") + bAssetIdStr))
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let Scale8 = 100000000
55
66 let Scale10 = 10000000000
77
88 let Scale16 = (Scale8 * Scale8)
99
1010 let reserveFund = 20
1111
1212 let dayBlocks = 1440
1313
1414 func liIntToStr (li) = {
1515 func f (accum,next) = ((accum + toString(next)) + ",")
1616
1717 let $l = li
1818 let $s = size($l)
1919 let $acc0 = ""
2020 func $f0_1 ($a,$i) = if (($i >= $s))
2121 then $a
2222 else f($a, $l[$i])
2323
2424 func $f0_2 ($a,$i) = if (($i >= $s))
2525 then $a
2626 else throw("List size exceeds 6")
2727
2828 $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6)
2929 }
3030
3131
3232 func tryGetInteger (key) = match getInteger(this, key) {
3333 case b: Int =>
3434 b
3535 case _ =>
3636 0
3737 }
3838
3939
4040 func tryGetBoolean (key) = match getBoolean(this, key) {
4141 case b: Boolean =>
4242 b
4343 case _ =>
4444 false
4545 }
4646
4747
4848 func tryGetString (key) = match getString(this, key) {
4949 case b: String =>
5050 b
5151 case _ =>
5252 ""
5353 }
5454
5555
5656 func tryGetBinary (key) = match getBinary(this, key) {
5757 case b: ByteVector =>
5858 b
5959 case _ =>
6060 base58''
6161 }
6262
6363
6464 func getAssetString (assetId) = match assetId {
6565 case b: ByteVector =>
6666 toBase58String(b)
6767 case _ =>
6868 "WAVES"
6969 }
7070
7171
7272 func getAssetBytes (assetIdStr) = if ((assetIdStr == "WAVES"))
7373 then unit
7474 else fromBase58String(assetIdStr)
7575
7676
7777 func getBalance (assetIdStr) = if ((assetIdStr == "WAVES"))
7878 then wavesBalance(this).available
7979 else assetBalance(this, fromBase58String(assetIdStr))
8080
8181
8282 func getMarketAssets () = split(tryGetString("setup_tokens"), ",")
8383
8484
8585 func getAssetsMaxSupply () = {
8686 let s = tryGetString("setup_maxsupply")
8787 if ((s == ""))
8888 then [-1, -1, -1, -1, -1, -1, -1]
8989 else split(s, ",")
9090 }
9191
9292
9393 func getOutdatedUr (assetIdStr) = {
9494 let down = fraction(tryGetInteger(("total_supplied_" + assetIdStr)), tryGetInteger((assetIdStr + "_sRate")), Scale16)
9595 if ((down == 0))
9696 then 0
9797 else fraction(Scale8, fraction(tryGetInteger(("total_borrowed_" + assetIdStr)), tryGetInteger((assetIdStr + "_bRate")), Scale16), down)
9898 }
9999
100100
101101 func getRateCurve (assetIdStr) = match assetIdStr {
102102 case _ =>
103103 if (("34N9YcEETLWn93qYQ64EsP1x89tSruJU44RrEMSXXEPJ" == $match0))
104104 then $Tuple4(2000000, 25000000, 80000000, 100000000)
105105 else if (("DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p" == $match0))
106106 then $Tuple4(2000000, 25000000, 80000000, 100000000)
107107 else if (("Ajso6nTTjptu2UHLx6hfSXVtHFtRBJCkKYd5SAyj7zf5" == $match0))
108108 then $Tuple4(2000000, 40000000, 80000000, 150000000)
109109 else if (("HEB8Qaw9xrWpWs8tHsiATYGBWDBtP2S7kcPALrMu43AS" == $match0))
110110 then $Tuple4(0, 20000000, 80000000, 40000000)
111111 else if (("WAVES" == $match0))
112112 then $Tuple4(2000000, 30000000, 80000000, 50000000)
113113 else if (("Atqv59EYzjFGuitKVnMRk6H8FukjoV3ktPorbEys25on" == $match0))
114114 then $Tuple4(0, 20000000, 80000000, 40000000)
115115 else if (("DSbbhLsSTeDg5Lsiufk2Aneh3DjVqJuPr2M9uU1gwy5p" == $match0))
116116 then $Tuple4(0, 20000000, 80000000, 100000000)
117117 else if (("8t4DPWTwPzpatHA9AkTxWAB47THnYzBsDnoY7fQqbG91" == $match0))
118118 then $Tuple4(0, 30000000, 80000000, 40000000)
119119 else if (("At8D6NFFpheCbvKVnjVoeLL84Eo8NZn6ovManxfLaFWL" == $match0))
120120 then $Tuple4(0, 25000000, 80000000, 40000000)
121121 else $Tuple4(0, 20000000, 80000000, 80000000)
122122 }
123123
124124
125125 func getInterest (assetIdStr) = {
126126 let ur = getOutdatedUr(assetIdStr)
127127 let curve = getRateCurve(assetIdStr)
128128 let rate = (curve._1 + (if ((curve._3 >= ur))
129129 then fraction(ur, curve._2, curve._3)
130130 else (curve._2 + fraction((ur - curve._3), (curve._4 - curve._2), (100000000 - curve._3)))))
131131 max([fraction(rate, Scale8, (dayBlocks * 365)), 1])
132132 }
133133
134134
135135 func tokenRatesRecalc (assetIdStr) = {
136136 let interest = getInterest(assetIdStr)
137137 let ur = getOutdatedUr(assetIdStr)
138138 let lastRecalcHeight = tryGetInteger("lastRateHeight")
139139 let lastBRate = max([tryGetInteger((assetIdStr + "_bRate")), Scale16])
140140 let newBRate = (lastBRate + ((height - lastRecalcHeight) * interest))
141141 let lastSRate = max([tryGetInteger((assetIdStr + "_sRate")), Scale16])
142142 let newSRate = (lastSRate + ((((height - lastRecalcHeight) * fraction(interest, ur, Scale8)) * (100 - reserveFund)) / 100))
143143 [IntegerEntry((assetIdStr + "_sRate"), newSRate), IntegerEntry((assetIdStr + "_bRate"), newBRate), IntegerEntry("lastRateHeight", height)]
144144 }
145145
146146
147147 func getActualRate (assetIdStr,rateType) = {
148148 func f (accum,token) = {
149149 let recalc = tokenRatesRecalc(token)
150150 $Tuple2(if ((token != assetIdStr))
151151 then accum._1
152152 else if ((rateType == "sRate"))
153153 then recalc[0].value
154154 else recalc[1].value, (accum._2 ++ recalc))
155155 }
156156
157157 let $l = getMarketAssets()
158158 let $s = size($l)
159159 let $acc0 = $Tuple2(0, nil)
160160 func $f0_1 ($a,$i) = if (($i >= $s))
161161 then $a
162162 else f($a, $l[$i])
163163
164164 func $f0_2 ($a,$i) = if (($i >= $s))
165165 then $a
166166 else throw("List size exceeds 6")
167167
168168 $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6)
169169 }
170170
171171
172172 func getUr (assetIdStr) = {
173173 let rates = tokenRatesRecalc(assetIdStr)
174174 let down = fraction(tryGetInteger(("total_supplied_" + assetIdStr)), rates[0].value, Scale16)
175175 fraction(Scale8, fraction(tryGetInteger(("total_borrowed_" + assetIdStr)), rates[1].value, Scale16), down)
176176 }
177177
178178
179179 func ratesRecalc () = {
180180 func f (accum,token) = (accum ++ tokenRatesRecalc(token))
181181
182182 let $l = getMarketAssets()
183183 let $s = size($l)
184184 let $acc0 = nil
185185 func $f0_1 ($a,$i) = if (($i >= $s))
186186 then $a
187187 else f($a, $l[$i])
188188
189189 func $f0_2 ($a,$i) = if (($i >= $s))
190190 then $a
191191 else throw("List size exceeds 6")
192192
193193 $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6)
194194 }
195195
196196
197197 func getTokenPrice (assetIdStr) = {
198198 let inv1 = invoke(addressFromStringValue("3P5BTtdj32Sd1Dyh1Mdw33xQAAckSfMfnKf"), "getTWAP60", [assetIdStr, false], nil)
199199 if ((inv1 == inv1))
200200 then {
201201 let inv2 = invoke(addressFromStringValue("3P8pvmcBi9JeBrnPgWDTaPWrWmGzxiDkpTu"), "getTWAP60", [assetIdStr, false], nil)
202202 if ((inv2 == inv2))
203203 then {
204204 let data1 = match inv1 {
205205 case x: (Int, Int) =>
206206 x
207207 case _ =>
208208 throw("error of price oracle")
209209 }
210210 if ((data1 == data1))
211211 then {
212212 let data2 = match inv2 {
213213 case x: (Int, Int) =>
214214 x
215215 case _ =>
216216 throw("error of price oracle")
217217 }
218218 if ((data2 == data2))
219219 then $Tuple2(min([data1._1, data2._1]), max([data1._2, data2._2]))
220220 else throw("Strict value is not equal to itself.")
221221 }
222222 else throw("Strict value is not equal to itself.")
223223 }
224224 else throw("Strict value is not equal to itself.")
225225 }
226226 else throw("Strict value is not equal to itself.")
227227 }
228228
229229
230230 func calcAssetScale (assetIdStr) = {
231231 let decimals = if ((assetIdStr == "WAVES"))
232232 then 8
233233 else value(assetInfo(fromBase58String(assetIdStr))).decimals
234234 pow(10, 0, decimals, 0, 0, DOWN)
235235 }
236236
237237
238238 func calcUserCollateral (address) = {
239239 let userCollateralInvoke = invoke(this, "getUserCollateral", [false, address, true, ""], nil)
240240 if ((userCollateralInvoke == userCollateralInvoke))
241241 then {
242242 let userCollateralValue = match userCollateralInvoke {
243243 case x: Int =>
244244 x
245245 case _ =>
246246 throw("issue while doing in-dapp invocation")
247247 }
248248 if ((userCollateralValue == userCollateralValue))
249249 then userCollateralValue
250250 else throw("Strict value is not equal to itself.")
251251 }
252252 else throw("Strict value is not equal to itself.")
253253 }
254254
255255
256256 @Callable(i)
257257 func stakeTokenAll (assetIdStr) = if ((i.caller != this))
258258 then throw("only for internal smart contract invocations")
259259 else if ((assetIdStr == "WAVES"))
260260 then {
261261 let amount = (getBalance("WAVES") - 100000000)
262- let lease = Lease(Address(base58''), amount)
262+ let lease = Lease(Address(base58'3PCrRrwHEjGXFjYtXDsNv78f3Ch3CH3p6V1'), amount)
263263 let leaseId = calculateLeaseId(lease)
264264 [lease, BinaryEntry("autostake_lastWavesLease", leaseId), IntegerEntry("autostake_amount_WAVES", amount)]
265265 }
266266 else nil
267267
268268
269269
270270 @Callable(i)
271271 func unstakeTokenAll (assetIdStr) = if ((i.caller != this))
272272 then throw("only for internal smart contract invocations")
273273 else if ((assetIdStr == "WAVES"))
274274 then {
275275 let leaseId = tryGetBinary("autostake_lastWavesLease")
276276 [LeaseCancel(leaseId), DeleteEntry("autostake_lastWavesLease"), DeleteEntry("autostake_amount_WAVES")]
277277 }
278278 else nil
279279
280280
281281
282282 @Callable(i)
283283 func preInit (tokens,ltvs,lts,penalties) = {
284284 func f (accum,token) = (accum ++ [IntegerEntry((token + "_bRate"), Scale16), IntegerEntry((token + "_sRate"), Scale16)])
285285
286286 if ((i.caller != this))
287287 then throw("admin only")
288288 else {
289289 let rates = {
290290 let $l = split(tokens, ",")
291291 let $s = size($l)
292292 let $acc0 = nil
293293 func $f0_1 ($a,$i) = if (($i >= $s))
294294 then $a
295295 else f($a, $l[$i])
296296
297297 func $f0_2 ($a,$i) = if (($i >= $s))
298298 then $a
299299 else throw("List size exceeds 6")
300300
301301 $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6)
302302 }
303303 ([StringEntry("setup_tokens", tokens), StringEntry("setup_ltvs", ltvs), StringEntry("setup_lts", lts), StringEntry("setup_penalties", penalties), BooleanEntry("setup_active", true)] ++ rates)
304304 }
305305 }
306306
307307
308308
309309 @Callable(i)
310310 func updateParameter (key,val) = if ((i.caller != this))
311311 then throw("admin only")
312312 else [StringEntry(key, val)]
313313
314314
315315
316316 @Callable(i)
317317 func supply () = if (!(tryGetBoolean("setup_active")))
318318 then throw("market is stopped")
319319 else if (if ((size(i.payments) != 1))
320320 then true
321321 else (i.payments[0].amount == 0))
322322 then throw("1 payment has to be attached")
323323 else {
324324 let assetIdStr = getAssetString(i.payments[0].assetId)
325325 let assetAmount = i.payments[0].amount
326- let $t078247891 = getActualRate(assetIdStr, "sRate")
327- let sRate = $t078247891._1
328- let ratesRecalcResult = $t078247891._2
326+ let $t078597926 = getActualRate(assetIdStr, "sRate")
327+ let sRate = $t078597926._1
328+ let ratesRecalcResult = $t078597926._2
329329 let amount = fraction(assetAmount, Scale16, sRate, DOWN)
330330 let address = toString(i.caller)
331331 let maxSupply = match getString(("setup_maxSupply_" + assetIdStr)) {
332332 case x: String =>
333333 parseIntValue(x)
334334 case _ =>
335335 0
336336 }
337337 let assetPrice = getTokenPrice(assetIdStr)
338338 let newTotalSupplied = (tryGetInteger(((address + "_supplied_") + assetIdStr)) + amount)
339339 let rate = getActualRate(assetIdStr, "sRate")._1
340340 let assetScale = calcAssetScale(assetIdStr)
341341 let newTotalSuppliedUsd = fraction(fraction(newTotalSupplied, rate, Scale16), assetPrice._1, assetScale)
342342 if ((indexOf(tryGetString("setup_tokens"), assetIdStr) == unit))
343343 then throw("this asset is not supported by the market")
344344 else if (if ((maxSupply != 0))
345345 then (newTotalSuppliedUsd > maxSupply)
346346 else false)
347347 then throw("max total supply for this token reached in the pool")
348348 else ([IntegerEntry(((address + "_supplied_") + assetIdStr), newTotalSupplied), IntegerEntry(("total_supplied_" + assetIdStr), (tryGetInteger(("total_supplied_" + assetIdStr)) + amount))] ++ ratesRecalcResult)
349349 }
350350
351351
352352
353353 @Callable(i)
354354 func withdraw (assetIdStr,assetAmount) = {
355- let $t090739140 = getActualRate(assetIdStr, "sRate")
356- let sRate = $t090739140._1
357- let ratesRecalcResult = $t090739140._2
355+ let $t091089175 = getActualRate(assetIdStr, "sRate")
356+ let sRate = $t091089175._1
357+ let ratesRecalcResult = $t091089175._2
358358 let amount = fraction(assetAmount, Scale16, sRate, CEILING)
359359 let address = toString(i.caller)
360360 let assetSupplied = tryGetInteger(("total_supplied_" + assetIdStr))
361361 let assetBorrowed = tryGetInteger(("total_borrowed_" + assetIdStr))
362362 let userAssetSupplied = tryGetInteger(((address + "_supplied_") + assetIdStr))
363363 let userAssetBorrowed = tryGetInteger(((address + "_borrowed_") + assetIdStr))
364364 let collateralValueInv = invoke(this, "getUserCollateral", [false, address, true, ((assetIdStr + ",supplied,") + toString(-(amount)))], nil)
365365 if ((collateralValueInv == collateralValueInv))
366366 then {
367367 let collateralValue = match collateralValueInv {
368368 case x: Int =>
369369 x
370370 case _ =>
371371 throw("can't get user collateral value")
372372 }
373373 if (!(tryGetBoolean("setup_active")))
374374 then throw("market is stopped")
375375 else if ((0 > collateralValue))
376376 then throw("you dont have enough collateral for this operation")
377377 else if ((amount > (assetSupplied - assetBorrowed)))
378378 then throw("this amount is not available on the market")
379379 else if ((amount > (userAssetSupplied - userAssetBorrowed)))
380380 then throw("this amount is not available for this user")
381381 else ([IntegerEntry(((address + "_supplied_") + assetIdStr), (tryGetInteger(((address + "_supplied_") + assetIdStr)) - amount)), IntegerEntry(("total_supplied_" + assetIdStr), (tryGetInteger(("total_supplied_" + assetIdStr)) - amount)), ScriptTransfer(i.caller, assetAmount, getAssetBytes(assetIdStr))] ++ ratesRecalcResult)
382382 }
383383 else throw("Strict value is not equal to itself.")
384384 }
385385
386386
387387
388388 @Callable(i)
389389 func borrow (assetIdStr,assetAmount) = {
390390 let address = toString(i.caller)
391- let $t01063310700 = getActualRate(assetIdStr, "bRate")
392- let bRate = $t01063310700._1
393- let ratesRecalcResult = $t01063310700._2
391+ let $t01066810735 = getActualRate(assetIdStr, "bRate")
392+ let bRate = $t01066810735._1
393+ let ratesRecalcResult = $t01066810735._2
394394 let amount = fraction(assetAmount, Scale16, bRate, CEILING)
395395 let collateralValueInv = invoke(this, "getUserCollateral", [false, address, true, ((assetIdStr + ",borrowed,") + toString(amount))], nil)
396396 if ((collateralValueInv == collateralValueInv))
397397 then {
398398 let collateralValue = match collateralValueInv {
399399 case x: Int =>
400400 x
401401 case _ =>
402402 throw("can't get user collateral value")
403403 }
404404 if (!(tryGetBoolean("setup_active")))
405405 then throw("market is stopped")
406406 else if ((0 > collateralValue))
407407 then throw("you have to supply more to borrow")
408408 else {
409409 let assetSupplied = tryGetInteger(("total_supplied_" + assetIdStr))
410410 let assetBorrowed = tryGetInteger(("total_borrowed_" + assetIdStr))
411411 let userAssetBorrowed = tryGetInteger(((address + "_borrowed_") + assetIdStr))
412412 if ((amount > (assetSupplied - assetBorrowed)))
413413 then throw("this amount is not available")
414414 else ([IntegerEntry(((address + "_borrowed_") + assetIdStr), (userAssetBorrowed + amount)), IntegerEntry(("total_borrowed_" + assetIdStr), (assetBorrowed + amount)), ScriptTransfer(i.caller, assetAmount, getAssetBytes(assetIdStr))] ++ ratesRecalcResult)
415415 }
416416 }
417417 else throw("Strict value is not equal to itself.")
418418 }
419419
420420
421421
422422 @Callable(i)
423423 func repay () = if (!(tryGetBoolean("setup_active")))
424424 then throw("market is stopped")
425425 else if (if ((size(i.payments) != 1))
426426 then true
427427 else (i.payments[0].amount == 0))
428428 then throw("1 payment has to be attached")
429429 else {
430430 let assetIdStr = getAssetString(i.payments[0].assetId)
431431 let assetAmount = i.payments[0].amount
432- let $t01212412191 = getActualRate(assetIdStr, "bRate")
433- let bRate = $t01212412191._1
434- let ratesRecalcResult = $t01212412191._2
432+ let $t01215912226 = getActualRate(assetIdStr, "bRate")
433+ let bRate = $t01215912226._1
434+ let ratesRecalcResult = $t01215912226._2
435435 let amount = fraction(assetAmount, Scale16, bRate, CEILING)
436436 let address = toString(i.caller)
437437 let assetSupplied = tryGetInteger(("total_supplied_" + assetIdStr))
438438 let assetBorrowed = tryGetInteger(("total_borrowed_" + assetIdStr))
439439 let userAssetBorrowed = tryGetInteger(((address + "_borrowed_") + assetIdStr))
440440 let amountLeft = (userAssetBorrowed - amount)
441441 let repayAmount = if ((amountLeft >= 0))
442442 then amount
443443 else userAssetBorrowed
444444 if ((indexOf(tryGetString("setup_tokens"), assetIdStr) == unit))
445445 then throw("this asset is not supported by the market")
446446 else (([IntegerEntry(((address + "_borrowed_") + assetIdStr), (userAssetBorrowed - repayAmount)), IntegerEntry(("total_borrowed_" + assetIdStr), (assetBorrowed - repayAmount))] ++ ratesRecalcResult) ++ (if ((amountLeft >= 0))
447447 then nil
448448 else [ScriptTransfer(i.caller, -(amountLeft), i.payments[0].assetId)]))
449449 }
450450
451451
452452
453453 @Callable(i)
454454 func liquidate (debug,address,assetAmount,sAssetIdStr,bAssetIdStr,routeStr) = if ((i.caller != Address(base58'3PCqdm1mAoQqR46oZotFanmqb5CLUvrKEo2')))
455455 then throw("temporarily listed for whitelist only")
456456 else if (!(tryGetBoolean("setup_active")))
457457 then throw("market is stopped")
458458 else {
459459 let userCollateral = calcUserCollateral(address)
460460 if ((userCollateral == userCollateral))
461461 then {
462- let $t01356413633 = getActualRate(sAssetIdStr, "sRate")
463- let sRate = $t01356413633._1
464- let ratesRecalcResult1 = $t01356413633._2
465- let $t01363813707 = getActualRate(bAssetIdStr, "bRate")
466- let bRate = $t01363813707._1
467- let ratesRecalcResult2 = $t01363813707._2
462+ let $t01359913668 = getActualRate(sAssetIdStr, "sRate")
463+ let sRate = $t01359913668._1
464+ let ratesRecalcResult1 = $t01359913668._2
465+ let $t01367313742 = getActualRate(bAssetIdStr, "bRate")
466+ let bRate = $t01367313742._1
467+ let ratesRecalcResult2 = $t01367313742._2
468468 let sAssetAmount = fraction(assetAmount, Scale16, sRate)
469469 let currentSPosition = tryGetInteger(((address + "_supplied_") + sAssetIdStr))
470470 let currentBPosition = tryGetInteger(((address + "_borrowed_") + bAssetIdStr))
471471 if ((userCollateral > 0))
472472 then throw("user can't be liquidated")
473473 else if ((sAssetAmount > currentSPosition))
474474 then throw("position to liquidate is bigger than user's supply")
475475 else {
476476 let aggregatorAddress = Address(base58'3PGFHzVGT4NTigwCKP1NcwoXkodVZwvBuuU')
477477 let balance0Before = getBalance(sAssetIdStr)
478478 if ((balance0Before == balance0Before))
479479 then {
480480 let balance1Before = getBalance(bAssetIdStr)
481481 if ((balance1Before == balance1Before))
482482 then {
483483 let exchangeInvoke = invoke(aggregatorAddress, "swap", [routeStr, 0], [AttachedPayment(getAssetBytes(sAssetIdStr), assetAmount)])
484484 if ((exchangeInvoke == exchangeInvoke))
485485 then {
486486 let asset0Sold = (balance0Before - getBalance(sAssetIdStr))
487487 if ((asset0Sold == asset0Sold))
488488 then {
489489 let asset1Bought = (getBalance(bAssetIdStr) - balance1Before)
490490 if ((asset1Bought == asset1Bought))
491491 then {
492492 let asset0Price = getTokenPrice(sAssetIdStr)._2
493493 let asset0Scale = calcAssetScale(sAssetIdStr)
494494 let asset0Usd = fraction(asset0Sold, asset0Price, asset0Scale)
495495 let asset1Price = getTokenPrice(bAssetIdStr)._1
496496 let asset1Scale = calcAssetScale(bAssetIdStr)
497497 let asset1Usd = fraction(asset1Bought, asset1Price, asset1Scale)
498498 let penalty = parseIntValue(split(tryGetString("setup_penalties"), ",")[value(indexOf(getMarketAssets(), bAssetIdStr))])
499499 let liquidationProfit = (asset1Usd - fraction(asset0Usd, (Scale8 - penalty), Scale8))
500500 let sAssetChange = fraction(asset0Sold, Scale16, sRate)
501501 let bAssetChange = fraction(asset1Bought, Scale16, bRate)
502502 if ((asset0Sold > assetAmount))
503503 then throw("more assets exchanged than expected")
504504 else if ((0 > liquidationProfit))
505505 then throw("price impact is bigger than liquidation penalty")
506506 else [IntegerEntry(((address + "_supplied_") + sAssetIdStr), (currentSPosition - sAssetChange)), IntegerEntry(((address + "_borrowed_") + bAssetIdStr), (currentBPosition - bAssetChange)), IntegerEntry(("total_supplied_" + sAssetIdStr), (tryGetInteger(("total_supplied_" + sAssetIdStr)) - sAssetChange)), IntegerEntry(("total_borrowed_" + bAssetIdStr), (tryGetInteger(("total_borrowed_" + bAssetIdStr)) - bAssetChange)), ScriptTransfer(i.caller, liquidationProfit, getAssetBytes(bAssetIdStr))]
507507 }
508508 else throw("Strict value is not equal to itself.")
509509 }
510510 else throw("Strict value is not equal to itself.")
511511 }
512512 else throw("Strict value is not equal to itself.")
513513 }
514514 else throw("Strict value is not equal to itself.")
515515 }
516516 else throw("Strict value is not equal to itself.")
517517 }
518518 }
519519 else throw("Strict value is not equal to itself.")
520520 }
521521
522522
523523
524524 @Callable(i)
525525 func getUserCollateral (debug,address,minusBorrowed,afterChange) = {
526526 let assets = getMarketAssets()
527527 let ltvs = split(tryGetString("setup_ltvs"), ",")
528528 let lts = split(tryGetString("setup_lts"), ",")
529529 let rates = getActualRate(assets[0], "sRate")._2
530530 let changeHandler = split(afterChange, ",")
531531 func f (accum,next) = if ((next >= size(assets)))
532532 then accum
533533 else {
534534 let decimals = if ((assets[next] == "WAVES"))
535535 then 8
536536 else value(assetInfo(fromBase58String(assets[next]))).decimals
537537 let assetScale = pow(10, 0, decimals, 0, 0, DOWN)
538538 let assetPrice = getTokenPrice(assets[next])
539539 ((accum + fraction(fraction(fraction((tryGetInteger(((address + "_supplied_") + assets[next])) + (if (if (if ((afterChange != ""))
540540 then (changeHandler[0] == assets[next])
541541 else false)
542542 then (changeHandler[1] == "supplied")
543543 else false)
544544 then parseIntValue(changeHandler[2])
545545 else 0)), rates[(next * 3)].value, Scale16), parseIntValue(ltvs[next]), Scale8), assetPrice._1, assetScale)) - (if (minusBorrowed)
546546 then fraction(fraction(fraction((tryGetInteger(((address + "_borrowed_") + assets[next])) + (if (if (if ((afterChange != ""))
547547 then (changeHandler[0] == assets[next])
548548 else false)
549549 then (changeHandler[1] == "borrowed")
550550 else false)
551551 then parseIntValue(changeHandler[2])
552552 else 0)), rates[((next * 3) + 1)].value, Scale16), Scale8, parseIntValue(lts[next])), assetPrice._2, assetScale)
553553 else 0))
554554 }
555555
556556 let result = {
557557 let $l = [0, 1, 2, 3, 4, 5]
558558 let $s = size($l)
559559 let $acc0 = 0
560560 func $f0_1 ($a,$i) = if (($i >= $s))
561561 then $a
562562 else f($a, $l[$i])
563563
564564 func $f0_2 ($a,$i) = if (($i >= $s))
565565 then $a
566566 else throw("List size exceeds 6")
567567
568568 $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6)
569569 }
570570 if (debug)
571571 then throw(toString(result))
572572 else $Tuple2(rates, result)
573573 }
574574
575575
576576
577577 @Callable(i)
578578 func getPrices (debug) = {
579579 let assets = getMarketAssets()
580580 func f (accum,next) = if ((next >= size(assets)))
581581 then accum
582582 else {
583583 let assetPrice = getTokenPrice(assets[next])
584584 ((((accum + toString(assetPrice._1)) + ",") + toString(assetPrice._2)) + "|")
585585 }
586586
587587 let result = {
588588 let $l = [0, 1, 2, 3, 4, 5]
589589 let $s = size($l)
590590 let $acc0 = ""
591591 func $f0_1 ($a,$i) = if (($i >= $s))
592592 then $a
593593 else f($a, $l[$i])
594594
595595 func $f0_2 ($a,$i) = if (($i >= $s))
596596 then $a
597597 else throw("List size exceeds 6")
598598
599599 $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6)
600600 }
601601 if (debug)
602602 then throw(result)
603603 else $Tuple2(nil, result)
604604 }
605605
606606
607607
608608 @Callable(i)
609609 func calculateUtilizationRatio (assetIdStr,debug) = if (debug)
610610 then throw(toString(getUr(assetIdStr)))
611611 else $Tuple2(nil, getUr(assetIdStr))
612612
613613
614614
615615 @Callable(i)
616616 func calculateOutdatedUR (assetIdStr,debug) = if (debug)
617617 then throw(toString(getOutdatedUr(assetIdStr)))
618618 else $Tuple2(nil, getOutdatedUr(assetIdStr))
619619
620620
621621
622622 @Callable(i)
623623 func calculateTokenRates (debug) = {
624624 func f (accum,assetIdStr) = {
625625 let rates = tokenRatesRecalc(assetIdStr)
626626 $Tuple2(((((accum._1 + toString(rates[1].value)) + "|") + toString(rates[0].value)) + ","), (accum._2 ++ rates))
627627 }
628628
629629 let parameter = {
630630 let $l = getMarketAssets()
631631 let $s = size($l)
632632 let $acc0 = $Tuple2("", nil)
633633 func $f0_1 ($a,$i) = if (($i >= $s))
634634 then $a
635635 else f($a, $l[$i])
636636
637637 func $f0_2 ($a,$i) = if (($i >= $s))
638638 then $a
639639 else throw("List size exceeds 6")
640640
641641 $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6)
642642 }
643643 if (debug)
644644 then throw(parameter._1)
645645 else $Tuple2(parameter._2, parameter._1)
646646 }
647647
648648
649649
650650 @Callable(i)
651651 func calculateTokensInterest (debug) = {
652652 func f (accum,assetIdStr) = {
653653 let rate = fraction(getInterest(assetIdStr), dayBlocks, Scale8)
654654 ((accum + toString(rate)) + ",")
655655 }
656656
657657 let parameter = {
658658 let $l = getMarketAssets()
659659 let $s = size($l)
660660 let $acc0 = ""
661661 func $f0_1 ($a,$i) = if (($i >= $s))
662662 then $a
663663 else f($a, $l[$i])
664664
665665 func $f0_2 ($a,$i) = if (($i >= $s))
666666 then $a
667667 else throw("List size exceeds 6")
668668
669669 $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6)
670670 }
671671 if (debug)
672672 then throw(parameter)
673673 else $Tuple2(nil, parameter)
674674 }
675675
676676
677677
678678 @Callable(i)
679679 func calculateReserveFeeUnclaimed (debug) = {
680680 let assets = getMarketAssets()
681681 let rates = getActualRate(assets[0], "sRate")._2
682682 let li = [0, 1, 2, 3, 4, 5]
683683 func f (accum,n) = if ((n >= size(assets)))
684684 then accum
685685 else {
686686 let assetIdStr = assets[n]
687687 (accum ++ [((getBalance(assetIdStr) + fraction(tryGetInteger(("total_borrowed_" + assetIdStr)), rates[((n * 3) + 1)].value, Scale16)) - fraction(tryGetInteger(("total_supplied_" + assetIdStr)), rates[(n * 3)].value, Scale16))])
688688 }
689689
690690 let parameter = {
691691 let $l = li
692692 let $s = size($l)
693693 let $acc0 = nil
694694 func $f0_1 ($a,$i) = if (($i >= $s))
695695 then $a
696696 else f($a, $l[$i])
697697
698698 func $f0_2 ($a,$i) = if (($i >= $s))
699699 then $a
700700 else throw("List size exceeds 6")
701701
702702 $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6)
703703 }
704704 if (debug)
705705 then throw(liIntToStr(parameter))
706706 else $Tuple2(nil, parameter)
707707 }
708708
709709
710710
711711 @Callable(i)
712712 func reSetup (assetIdStr) = {
713713 let lastResetup = tryGetInteger("resetup_lastUpdate")
714714 if ((dayBlocks > (height - lastResetup)))
715715 then throw("can be updated only once per day")
716716 else {
717717 let lts = split(tryGetString("setup_lts"), ",")
718718 let assets = getMarketAssets()
719719 let ur = getUr(assetIdStr)
720720 let tempLT = tryGetInteger((("setup_" + assetIdStr) + "_tempLT"))
721721 let lt = parseIntValue(assets[value(indexOf(assets, assetIdStr))])
722722 if ((ur > 90000000))
723723 then [IntegerEntry((("setup_" + assetIdStr) + "_tempLT"), fraction(tempLT, 9975, 10000))]
724724 else if (if ((lt > tempLT))
725725 then (90000000 > ur)
726726 else false)
727727 then [IntegerEntry((("setup_" + assetIdStr) + "_tempLT"), fraction(tempLT, 10025, 10000))]
728728 else nil
729729 }
730730 }
731731
732732
733733
734734 @Callable(i)
735735 func shutdown (shutdown) = {
736736 let whitelist = [base58'3PMcMiMEs6w56NRGacksXtFG5zS7doE9fpL', base58'3PAxdDSmN758L5SHSGRC5apEtQE2aApZotG', base58'3PJKmXoHJvVeQXjSJdhtkUcFDtdiQqMbUTD', base58'3PQdNxynJy5mche2kxMVc5shXWzK8Gstq3o', base58'3PGgoUsQX3a5zGCc4e2nEnDCWAkzJ1jASzv', base58'3P6Ksahs71SiKQgQ4qaZuFAVhqncdi2nvJQ']
737737 if ((indexOf(whitelist, i.caller.bytes) == unit))
738738 then throw("user not in a whitelist")
739739 else [BooleanEntry("setup_active", !(shutdown))]
740740 }
741741
742742
743743 @Verifier(tx)
744744 func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)
745745

github/deemru/w8io/786bc32 
197.20 ms