tx · HjN54TVya4jBZ7Gzy6f7nPeWba4tn28dRUWwEmLX84cp 3MvRWw2FPEimFCTGtK7qY9uAJbM7XJ4ZfJS: -0.04400000 Waves 2023.06.28 13:27 [2642390] smart account 3MvRWw2FPEimFCTGtK7qY9uAJbM7XJ4ZfJS > SELF 0.00000000 Waves
{ "type": 13, "id": "HjN54TVya4jBZ7Gzy6f7nPeWba4tn28dRUWwEmLX84cp", "fee": 4400000, "feeAssetId": null, "timestamp": 1687948092057, "version": 2, "chainId": 84, "sender": "3MvRWw2FPEimFCTGtK7qY9uAJbM7XJ4ZfJS", "senderPublicKey": "HP8sssVq1866F7CaPQJwgFrt6fsqhQjKwM84cL1wjD2a", "proofs": [ "Ebr97C7W9ovcM47Dxatki2H2NKRke7MfpvEMzWbaqzMzqHaCbTBuinHKwxCgEcmLH85TjHe4E47535aSWqvMmWL" ], "script": "base64:BgKYAQgCEgcKBQgBCAEBEgMKAQgSBAoCCAgSBQoDCBgYEgUKAwgBCBIECgIIARIGCgQBCAgBEgUKAwEICBILCgkICAgICAgICAgSAwoBCBIDCgEIEgUKAwgIARIGCgQIAQgIEg4KDAgICAEEERgYEQEBGBIKCggICAgBBAgBGBIOCgwICAgBBBgYGBgYARgSCwoJCAgBAQEBAQEEaQAHU0ZfUE9PTAICU0YAB1dYX1BPT0wCAldYAA9DQVBfRkVFX05PX0xPQU4CCWNhcE5vTG9hbgAMQ0FQX0ZFRV9MT0FOAgdjYXBMb2FuABRTVE9QTE9TU19GRUVfTk9fTE9BTgIOc3RvcExvc3NOb0xvYW4ADVNUT1BMT1NTX0xPQU4CDHN0b3BMb3NzTG9hbgAITE9BTl9GRUUCBGxvYW4AC05PX0xPQU5fRkVFAgZub0xvYW4ABk5PX0ZFRQIFbm9GZWUABlNDQUxFOACAwtcvAAdTQ0FMRTEwAIDIr6AlAAdTQ0FMRTE2CQC2AgEAgICE/qbe4REACkZFRV9TQ0FMRTYAwIQ9ABRrU0ZQb29sQUFzc2V0QmFsYW5jZQIPQV9hc3NldF9iYWxhbmNlABRrU0ZQb29sQkFzc2V0QmFsYW5jZQIPQl9hc3NldF9iYWxhbmNlAA9rU0ZQb29sQUFzc2V0SWQCCkFfYXNzZXRfaWQAD2tTRlBvb2xCQXNzZXRJZAIKQl9hc3NldF9pZAAOa1NGUG9vbFNoYXJlSWQCDnNoYXJlX2Fzc2V0X2lkABJrU0ZQb29sU2hhcmVTdXBwbHkCEnNoYXJlX2Fzc2V0X3N1cHBseQAKa1NGUG9vbEZlZQIKY29tbWlzc2lvbgANa1VzZXJQb3NpdGlvbgIOX3VzZXJfcG9zaXRpb24AEWtVc2VyUG9zaXRpb25Qb29sAhNfdXNlcl9wb3NpdGlvbl9wb29sABFrVXNlckJvcnJvd0Ftb3VudAIcX3VzZXJfcG9zaXRpb25fYm9ycm93X2Ftb3VudAASa1VzZXJCb3Jyb3dBc3NldElkAh5fdXNlcl9wb3NpdGlvbl9ib3Jyb3dfYXNzZXRfaWQAEGtVc2VyUG9zaXRpb25OdW0CFV91c2VyX3Bvc2l0aW9uX251bWJlcgAVa1VzZXJQb3NpdGlvbkludGVyZXN0AhdfdXNlcl9wb3NpdGlvbl9pbnRlcmVzdAAKa1Bvb2xUb3RhbAILX3Bvb2xfdG90YWwADmtQb29sVG90YWxMb2FuAhBfcG9vbF90b3RhbF9sb2FuABFrUG9vbEludGVyZXN0TG9hbgITX3Bvb2xfaW50ZXJlc3RfbG9hbgATa1Bvb2xJbnRlcmVzdE5vTG9hbgIWX3Bvb2xfaW50ZXJlc3Rfbm9fbG9hbgAOa1Bvb2xDYW5Cb3Jyb3cCEF9wb29sX2Nhbl9ib3Jyb3cAFWtBeGx5SW5GZWVXaXRob3V0TG9hbgIWX2F4bHlfZmVlX3dpdGhvdXRfbG9hbgASa0F4bHlJbkZlZVdpdGhMb2FuAhNfYXhseV9mZWVfd2l0aF9sb2FuABFrQXhseU5vTG9hbkNhcEZlZQIXX2F4bHlfZmVlX2NhcF93aXRoX2xvYW4AE2tBeGx5V2l0aExvYW5DYXBGZWUCFV9heGx5X2ZlZV9jYXBfbm9fbG9hbgAWa0F4bHlTdG9wTG9zc05vTG9hbkZlZQIcX2F4bHlfZmVlX3N0b3Bsb3NzX3dpdGhfbG9hbgAUa0F4bHlTdG9wTG9zc0xvYW5GZWUCGl9heGx5X2ZlZV9zdG9wbG9zc19ub19sb2FuAAprUmVxdWVzdElkAgtfcmVxdWVzdF9pZAAMa1JlcXVlc3RJdGVyAg1yZXF1ZXN0c19pdGVyAAVrUG9vbAIFcG9vbF8ACmtTaGFyZVBvb2wCDl9wb29sX3NoYXJlX2lkAA5rUG9vbENhcENoYW5nZQIQX3Bvb2xfY2FwX2NoYW5nZQAPa1Rva2VuTGFzdFByaWNlAgpsYXN0X3ByaWNlAA1rVXNlclN0b3BMb3NzAgpfc3RvcF9sb3NzAAlrTW9uZXlCb3gCDmF4bHlfbW9uZXlfYm94AA5rU0ZGYXJtaW5nQWRkcgITc3dvcGZpX2Zhcm1pbmdfYWRkcgAMa0xlbmRTZXJ2aWNlAhFsZW5kX3NlcnZpY2VfYWRkcgAMa0FkbWluQ2FsbFBLAhJhZG1pbl9jYWxsX3B1Yl9rZXkADGtQcmljZU9yYWNsZQIMcHJpY2Vfb3JhY2xlAAtrRXhDb250cmFjdAIRZXhjaGFuZ2VfY29udHJhY3QAD2tXeFN3YXBDb250cmFjdAIQd3hfc3dhcF9jb250cmFjdAAHa1N3b3BJZAIHc3dvcF9pZAAFa1d4SWQCBXd4X2lkAAhtb25leUJveAkBB0FkZHJlc3MBCQDZBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzBQlrTW9uZXlCb3gCGE5vIGF4bHkgbW9uZXlCb3ggYWRkcmVzcwAKZXhDb250cmFjdAkBB0FkZHJlc3MBCQDZBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzBQtrRXhDb250cmFjdAIcTm8gZXhjaGFuZ2UgY29udHJhY3QgYWRkcmVzcwAPcHJpY2VPcmFjbGVBZGRyCQEHQWRkcmVzcwEJANkEAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMFDGtQcmljZU9yYWNsZQIXTm8gcHJpY2Ugb3JhY2xlIGFkZHJlc3MADnd4U3dhcENvbnRyYWN0CQEHQWRkcmVzcwEJANkEAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMFD2tXeFN3YXBDb250cmFjdAISTm8gd3ggc3dhcCBhZGRyZXNzAAZTV09QSUQJANkEAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMFB2tTd29wSWQCCk5vIHN3b3AgaWQABFdYSUQJANkEAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMFBWtXeElkAghObyB3eCBpZAEOZ2V0TGVuZFNydkFkZHIACQEHQWRkcmVzcwEJANkEAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMFDGtMZW5kU2VydmljZQIbQ2FuJ3QgZ2V0IGxlbmQgc2VydmljZSBhZGRyARBnZXRBZG1pbkNhbGxBZGRyAAkApwgBCQDZBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzBQxrQWRtaW5DYWxsUEsCFENhbid0IGdldCBhZG1pbiBhZGRyAQtpc0FkbWluQ2FsbAEBaQMJAAACCAUBaQZjYWxsZXIJARBnZXRBZG1pbkNhbGxBZGRyAAUEdW5pdAkAAgECIU9ubHkgYWRtaW4gY2FuIGNhbGwgdGhpcyBmdW5jdGlvbgEKaXNTZWxmQ2FsbAEBaQMJAAACCAUBaQZjYWxsZXIFBHRoaXMFBHVuaXQJAAIBAitPbmx5IGNvbnRyYWN0IGl0c2VsZiBjYW4gY2FsbCB0aGlzIGZ1bmN0aW9uAQppc0xhbmRDYWxsAQFpAwkAAAIIBQFpBmNhbGxlcgkBDmdldExlbmRTcnZBZGRyAAUEdW5pdAkAAgECKU9ubHkgbGFuZCBjb250cmFjdCBjYW4gY2FsbCB0aGlzIGZ1bmN0aW9uAQ5hY2NvdW50QmFsYW5jZQEHYXNzZXRJZAQHJG1hdGNoMAUHYXNzZXRJZAMJAAECBQckbWF0Y2gwAgpCeXRlVmVjdG9yBAJpZAUHJG1hdGNoMAkA8AcCBQR0aGlzBQJpZAMJAAECBQckbWF0Y2gwAgRVbml0BAV3YXZlcwUHJG1hdGNoMAgJAO8HAQUEdGhpcwlhdmFpbGFibGUJAAIBAgtNYXRjaCBlcnJvcgENZ2V0U0ZQb29sRGF0YQEIcG9vbEFkZHIJAJcKBQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFCHBvb2xBZGRyBQ9rU0ZQb29sQUFzc2V0SWQCGUNhbid0IGdldCBwb29sIEEgYXNzZXQgaWQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQhwb29sQWRkcgUPa1NGUG9vbEJBc3NldElkAhlDYW4ndCBnZXQgcG9vbCBCIGFzc2V0IGlkCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUIcG9vbEFkZHIFFGtTRlBvb2xBQXNzZXRCYWxhbmNlAh5DYW4ndCBnZXQgcG9vbCBBIGFzc2V0IGJhbGFuY2UJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQhwb29sQWRkcgUUa1NGUG9vbEJBc3NldEJhbGFuY2UCHkNhbid0IGdldCBwb29sIEIgYXNzZXQgYmFsYW5jZQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFCHBvb2xBZGRyBQ5rU0ZQb29sU2hhcmVJZAIYQ2FuJ3QgZ2V0IHNoYXJlIGFzc2V0IGlkAQ1nZXRXWFBvb2xEYXRhAQhwb29sQWRkcgQDY2ZnCgABQAkA/AcEBQhwb29sQWRkcgIcZ2V0UG9vbENvbmZpZ1dyYXBwZXJSRUFET05MWQUDbmlsBQNuaWwDCQABAgUBQAIJTGlzdFtBbnldBQFACQACAQkArAICCQADAQUBQAIeIGNvdWxkbid0IGJlIGNhc3QgdG8gTGlzdFtBbnldAwkAAAIFA2NmZwUDY2ZnBANhSWQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgoAAUAJAJEDAgUDY2ZnAAQDCQABAgUBQAIGU3RyaW5nBQFABQR1bml0AhlDYW4ndCBnZXQgcG9vbCBBIGFzc2V0IGlkBANiSWQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgoAAUAJAJEDAgUDY2ZnAAUDCQABAgUBQAIGU3RyaW5nBQFABQR1bml0AhlDYW4ndCBnZXQgcG9vbCBCIGFzc2V0IGlkBAdzaGFyZUlkCQETdmFsdWVPckVycm9yTWVzc2FnZQIKAAFACQCRAwIFA2NmZwADAwkAAQIFAUACBlN0cmluZwUBQAUEdW5pdAIaQ2FuJ3QgZ2V0IHBvb2wgTFAgYXNzZXQgaWQEBGJhbEEKAAFACQD8BwQFCHBvb2xBZGRyAhxnZXRBY2NCYWxhbmNlV3JhcHBlclJFQURPTkxZCQDMCAIFA2FJZAUDbmlsBQNuaWwDCQABAgUBQAIDSW50BQFACQACAQkArAICCQADAQUBQAIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50AwkAAAIFBGJhbEEFBGJhbEEEBGJhbEIKAAFACQD8BwQFCHBvb2xBZGRyAhxnZXRBY2NCYWxhbmNlV3JhcHBlclJFQURPTkxZCQDMCAIFA2JJZAUDbmlsBQNuaWwDCQABAgUBQAIDSW50BQFACQACAQkArAICCQADAQUBQAIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50AwkAAAIFBGJhbEIFBGJhbEIJAJcKBQUDYUlkBQNiSWQFBGJhbEEFBGJhbEIFB3NoYXJlSWQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BC2dldFBvb2xEYXRhAghwb29sQWRkcgR0eXBlAwkAAAIFBHR5cGUFB1NGX1BPT0wJAQ1nZXRTRlBvb2xEYXRhAQUIcG9vbEFkZHIDCQAAAgUEdHlwZQUHV1hfUE9PTAkBDWdldFdYUG9vbERhdGEBBQhwb29sQWRkcgkAAgECD1dyb25nIHBvb2wgdHlwZQEOZ2V0U2hhcmVTdXBwbHkDCHBvb2xBZGRyBHR5cGUHc2hhcmVJZAMJAAACBQR0eXBlBQdTRl9QT09MCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUIcG9vbEFkZHIFEmtTRlBvb2xTaGFyZVN1cHBseQIcQ2FuJ3QgZ2V0IHNoYXJlIGFzc2V0IHN1cHBseQMJAAACBQR0eXBlBQdXWF9QT09MCAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQDsBwEJANkEAQUHc2hhcmVJZAINV3JvbmcgU2hhcmVJZAhxdWFudGl0eQkAAgECD1dyb25nIHBvb2wgdHlwZQERZ2V0UG9vbFRvdGFsU2hhcmUBBHBvb2wJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkArAICBQRwb29sBQprUG9vbFRvdGFsAAABGWdldFBvb2xUb3RhbFNoYXJlV2l0aExvYW4BBHBvb2wJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkArAICBQRwb29sBQ5rUG9vbFRvdGFsTG9hbgAAARhnZXROZXdVc2VyUG9zaXRpb25OdW1iZXIBBHVzZXIJAGQCCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAKwCAgUEdXNlcgUQa1VzZXJQb3NpdGlvbk51bQAAAAEBCmdldEF4bHlGZWUCBHBvb2wHZmVlVHlwZQMJAAACBQdmZWVUeXBlBQxDQVBfRkVFX0xPQU4JARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAKwCAgUEcG9vbAUTa0F4bHlXaXRoTG9hbkNhcEZlZQMJAAACBQdmZWVUeXBlBQ9DQVBfRkVFX05PX0xPQU4JARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAKwCAgUEcG9vbAURa0F4bHlOb0xvYW5DYXBGZWUDCQAAAgUHZmVlVHlwZQUITE9BTl9GRUUJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAKwCAgUEcG9vbAUSa0F4bHlJbkZlZVdpdGhMb2FuAwkAAAIFB2ZlZVR5cGUFC05PX0xPQU5fRkVFCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzCQCsAgIFBHBvb2wFFWtBeGx5SW5GZWVXaXRob3V0TG9hbgMJAAACBQdmZWVUeXBlBQZOT19GRUUAAAkAAgECDldyb25nIGZlZSB0eXBlARBnZXRTRkZhcm1pbmdBZGRyAAkBB0FkZHJlc3MBCQDZBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzBQ5rU0ZGYXJtaW5nQWRkcgIdQ2FuJ3QgZ2V0IHN3b3BmaSBmYXJtaW5nIGFkZHIBEGdldFdYRmFybWluZ0FkZHIBCHBvb2xBZGRyBAlmQ29udHJhY3QJAQdBZGRyZXNzAQkA2QQBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUIcG9vbEFkZHICEyVzX19mYWN0b3J5Q29udHJhY3QCIkNhbid0IGdldCBXWCBmYWN0b3J5IGNvbnRyYWN0IGFkZHIECmZhY3Ryb3lDZmcJALUJAgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFCWZDb250cmFjdAIRJXNfX2ZhY3RvcnlDb25maWcCGENhbid0IGdldCBXWCBmYWN0b3J5IGNmZwICX18JAQdBZGRyZXNzAQkA2QQBCQCRAwIFCmZhY3Ryb3lDZmcAAQEMYXNzZXRJZFRvU3RyAQdhc3NldElkBAckbWF0Y2gwBQdhc3NldElkAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEAmlkBQckbWF0Y2gwCQDYBAEFAmlkAwkAAQIFByRtYXRjaDACBFVuaXQEBXdhdmVzBQckbWF0Y2gwAgVXQVZFUwkAAgECDE5vdCBBc3NldCBpZAEOYXNzZXRJZEZyb21TdHIBB2Fzc2V0SWQDCQAAAgUHYXNzZXRJZAIFV0FWRVMFBHVuaXQJANkEAQUHYXNzZXRJZAEQZ2V0QXNzZXREZWNpbWFscwEHYXNzZXRJZAMJAAACBQdhc3NldElkAgVXQVZFUwAIBAckbWF0Y2gwCQDsBwEJANkEAQUHYXNzZXRJZAMJAAECBQckbWF0Y2gwAgVBc3NldAQFYXNzZXQFByRtYXRjaDAIBQVhc3NldAhkZWNpbWFscwkAAgECEENhbid0IGZpbmQgYXNzZXQBEWdldEFzc2V0UHJlY2l0aW9uAQdhc3NldElkCQBsBgAKAAAJARBnZXRBc3NldERlY2ltYWxzAQUHYXNzZXRJZAAAAAAFBERPV04BDmdldEFzc2V0c1ByaWNlAQhhc3NldElkcwoBCWdldFByaWNlcwIBYQdhc3NldElkBAphc3NldFByaWNlCAoAAUAJAPwHBAUPcHJpY2VPcmFjbGVBZGRyAglnZXRUV0FQNjAJAMwIAgUHYXNzZXRJZAkAzAgCBwUDbmlsBQNuaWwDCQABAgUBQAIKKEludCwgSW50KQUBQAkAAgEJAKwCAgkAAwEFAUACHyBjb3VsZG4ndCBiZSBjYXN0IHRvIChJbnQsIEludCkCXzIJAM0IAgUBYQUKYXNzZXRQcmljZQoAAiRsBQhhc3NldElkcwoAAiRzCQCQAwEFAiRsCgAFJGFjYzAFA25pbAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEJZ2V0UHJpY2VzAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyA1MAkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKAAsADAANAA4ADwAQABEAEgATABQAFQAWABcAGAAZABoAGwAcAB0AHgAfACAAIQAiACMAJAAlACYAJwAoACkAKgArACwALQAuAC8AMAAxADIBDWdldFNoYXJlUHJpY2UBB3NoYXJlSWQEBHBvb2wJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzCQCsAgIFB3NoYXJlSWQFCmtTaGFyZVBvb2wCIENhbid0IGZpbmQgcG9vbCBhZGRyIGJ5IHNoYXJlIGlkBAhwb29sQWRkcgkBB0FkZHJlc3MBCQDZBAEFBHBvb2wEBXBUeXBlCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwkArAICBQVrUG9vbAUEcG9vbAISUG9vbCBpcyBub3QgaW5pdGVkBAskdDA5MDE3OTA4MgkBC2dldFBvb2xEYXRhAgUIcG9vbEFkZHIFBXBUeXBlBANhSWQIBQskdDA5MDE3OTA4MgJfMQQDYklkCAULJHQwOTAxNzkwODICXzIECGFCYWxhbmNlCAULJHQwOTAxNzkwODICXzMECGJCYWxhbmNlCAULJHQwOTAxNzkwODICXzQEB2RQcmljZUEICgABQAkA/AcEBQ9wcmljZU9yYWNsZUFkZHICCWdldFRXQVA2MAkAzAgCBQNhSWQJAMwIAgcFA25pbAUDbmlsAwkAAQIFAUACCihJbnQsIEludCkFAUAJAAIBCQCsAgIJAAMBBQFAAh8gY291bGRuJ3QgYmUgY2FzdCB0byAoSW50LCBJbnQpAl8yBAdkUHJpY2VCCAoAAUAJAPwHBAUPcHJpY2VPcmFjbGVBZGRyAglnZXRUV0FQNjAJAMwIAgUDYklkCQDMCAIHBQNuaWwFA25pbAMJAAECBQFAAgooSW50LCBJbnQpBQFACQACAQkArAICCQADAQUBQAIfIGNvdWxkbid0IGJlIGNhc3QgdG8gKEludCwgSW50KQJfMgQLc2hhcmVTdXBwbHkJAQ5nZXRTaGFyZVN1cHBseQMFCHBvb2xBZGRyBQVwVHlwZQUHc2hhcmVJZAQKQVByZWNpc2lvbgkAbAYACgAACQEQZ2V0QXNzZXREZWNpbWFscwEFA2FJZAAAAAAFBERPV04ECkJQcmVjaXNpb24JAGwGAAoAAAkBEGdldEFzc2V0RGVjaW1hbHMBBQNiSWQAAAAABQRET1dOBA5zaGFyZVByZWNpc2lvbgkAbAYACgAACQEQZ2V0QXNzZXREZWNpbWFscwEFB3NoYXJlSWQAAAAABQRET1dOBANzdW0JAGQCCQBrAwUIYUJhbGFuY2UFB2RQcmljZUEFCkFQcmVjaXNpb24JAGsDBQhiQmFsYW5jZQUHZFByaWNlQgUKQlByZWNpc2lvbgkAawMFA3N1bQUOc2hhcmVQcmVjaXNpb24FC3NoYXJlU3VwcGx5AQ5nZXRTaGFyZVByaWNlcwEIc2hhcmVJZHMKAQlnZXRQcmljZXMCAWEHc2hhcmVJZAkAzQgCBQFhCQENZ2V0U2hhcmVQcmljZQEFB3NoYXJlSWQKAAIkbAUIc2hhcmVJZHMKAAIkcwkAkAMBBQIkbAoABSRhY2MwBQNuaWwKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBCWdldFByaWNlcwIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMjAJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgALAAwADQAOAA8AEAARABIAEwAUAQ5nZXRDdXJzRW50cmllcwMDYUlkA2JJZAdzaGFyZUlkBAxhc3NldHNQcmljZXMJAQ5nZXRBc3NldHNQcmljZQEJAMwIAgUDYUlkCQDMCAIFA2JJZAUDbmlsBApzaGFyZVByaWNlCQENZ2V0U2hhcmVQcmljZQEFB3NoYXJlSWQEBnByaWNlcwkAzAgCCQCkAwEJAJEDAgUMYXNzZXRzUHJpY2VzAAAJAMwIAgkApAMBCQCRAwIFDGFzc2V0c1ByaWNlcwABCQDMCAIJAKQDAQUKc2hhcmVQcmljZQUDbmlsCQDMCAIJAQtTdHJpbmdFbnRyeQIFD2tUb2tlbkxhc3RQcmljZQkAuQkCBQZwcmljZXMCASwFA25pbAEYY2FsY1JlcGxlbmlzaEJ5VHdvVG9rZW5zCAVwVHlwZQhwb29sQWRkcgRwbXRBA2FJZARwbXRCA2JJZARiYWxBBGJhbEIDCQAAAgUFcFR5cGUFB1NGX1BPT0wEBHJlcGwKAAFACQD8BwQFCHBvb2xBZGRyAgxjYWxsRnVuY3Rpb24JAMwIAgIgY2FsY0xQUmVwbGVuaXNoVHdvVG9rZW5zUkVBRE9OTFkJAMwIAgkAzAgCCQCkAwEFBHBtdEEJAMwIAgkApAMBBQRwbXRCBQNuaWwFA25pbAUDbmlsAwkAAQIFAUACCUxpc3RbQW55XQUBQAkAAgEJAKwCAgkAAwEFAUACHiBjb3VsZG4ndCBiZSBjYXN0IHRvIExpc3RbQW55XQMJAAACBQRyZXBsBQRyZXBsCQCXCgUKAAFACQCRAwIFBHJlcGwAAwMJAAECBQFAAgNJbnQFAUAJAAIBCQCsAgIJAAMBBQFAAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQKAAFACQCRAwIFBHJlcGwABAMJAAECBQFAAgNJbnQFAUAJAAIBCQCsAgIJAAMBBQFAAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQKAAFACQCRAwIFBHJlcGwAAQMJAAECBQFAAgNJbnQFAUAJAAIBCQCsAgIJAAMBBQFAAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQJAQxhc3NldElkVG9TdHIBCQCRAwIFBHJlcGwAAgoAAUAJAJEDAgUEcmVwbAAAAwkAAQIFAUACA0ludAUBQAkAAgEJAKwCAgkAAwEFAUACGCBjb3VsZG4ndCBiZSBjYXN0IHRvIEludAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgQNJHQwMTA2MTIxMDg2MgkAlAoCCQC1CQIKAAFACQD8BwQFCHBvb2xBZGRyAiBldmFsdWF0ZVB1dEJ5QW1vdW50QXNzZXRSRUFET05MWQkAzAgCBQRwbXRBBQNuaWwFA25pbAMJAAECBQFAAgZTdHJpbmcFAUAJAAIBCQCsAgIJAAMBBQFAAhsgY291bGRuJ3QgYmUgY2FzdCB0byBTdHJpbmcCAl9fCQC1CQIKAAFACQD8BwQFCHBvb2xBZGRyAh9ldmFsdWF0ZVB1dEJ5UHJpY2VBc3NldFJFQURPTkxZCQDMCAIFBHBtdEIFA25pbAUDbmlsAwkAAQIFAUACBlN0cmluZwUBQAkAAgEJAKwCAgkAAwEFAUACGyBjb3VsZG4ndCBiZSBjYXN0IHRvIFN0cmluZwICX18DCQAAAgUNJHQwMTA2MTIxMDg2MgUNJHQwMTA2MTIxMDg2MgQKZXZhbFB1dEluQggFDSR0MDEwNjEyMTA4NjICXzIECmV2YWxQdXRJbkEIBQ0kdDAxMDYxMjEwODYyAl8xBAVscEluQQkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCmV2YWxQdXRJbkEAAQQFbHBJbkIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQpldmFsUHV0SW5CAAEDCQBmAgUFbHBJbkIFBWxwSW5BBANwbXQJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQpldmFsUHV0SW5BAAgJAJcKBQUEcG10QQUDcG10CQBlAgUEcG10QgUDcG10BQNiSWQFBWxwSW5CBANwbXQJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQpldmFsUHV0SW5BAAgJAJcKBQUDcG10BQRwbXRCCQBlAgUEcG10QQUDcG10BQNhSWQFBWxwSW5BCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuARhyZXBsZW5pc2hUd29Ub2tlbnNCeVR5cGUGCHBvb2xBZGRyBXBUeXBlBHBtdEEDYUlkBHBtdEIDYklkBAhwYXltZW50cwkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkBDmFzc2V0SWRGcm9tU3RyAQUDYUlkBQRwbXRBCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQEOYXNzZXRJZEZyb21TdHIBBQNiSWQFBHBtdEIFA25pbAMJAAACBQVwVHlwZQUHU0ZfUE9PTAkA/AcEBQhwb29sQWRkcgIMY2FsbEZ1bmN0aW9uCQDMCAICFnJlcGxlbmlzaFdpdGhUd29Ub2tlbnMJAMwIAgkAzAgCAgVmYWxzZQkAzAgCAgEwBQNuaWwFA25pbAUIcGF5bWVudHMJAPwHBAUIcG9vbEFkZHICA3B1dAkAzAgCAMCEPQkAzAgCBwUDbmlsBQhwYXltZW50cwEXcmVwbGVuaXNoT25lVG9rZW5CeVR5cGUECHBvb2xBZGRyBXBUeXBlA3BtdAVwbXRJZAQIcGF5bWVudHMJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJAQ5hc3NldElkRnJvbVN0cgEFBXBtdElkBQNwbXQFA25pbAMJAAACBQVwVHlwZQUHU0ZfUE9PTAkA/AcEBQhwb29sQWRkcgIMY2FsbEZ1bmN0aW9uCQDMCAICFXJlcGxlbmlzaFdpdGhPbmVUb2tlbgkAzAgCCQDMCAICATAJAMwIAgIFZmFsc2UJAMwIAgIBMAUDbmlsBQNuaWwFCHBheW1lbnRzCQD8BwQFCHBvb2xBZGRyAglwdXRPbmVUa24JAMwIAgAACQDMCAIHBQNuaWwFCHBheW1lbnRzAQdzdGFrZUxQBARwb29sBXBUeXBlB3NoYXJlSWQGYW1vdW50BAhwYXltZW50cwkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkA2QQBBQdzaGFyZUlkBQZhbW91bnQFA25pbAMJAAACBQVwVHlwZQUHU0ZfUE9PTAkA/AcECQEQZ2V0U0ZGYXJtaW5nQWRkcgACD2xvY2tTaGFyZVRva2VucwkAzAgCBQRwb29sCQDMCAIAAAUDbmlsBQhwYXltZW50cwkA/AcECQEQZ2V0V1hGYXJtaW5nQWRkcgEJARFAZXh0ck5hdGl2ZSgxMDYyKQEFBHBvb2wCBXN0YWtlBQNuaWwFCHBheW1lbnRzAQl1bnN0YWtlTFAEBHBvb2wFcFR5cGUHc2hhcmVJZAZhbW91bnQEDSR0MDEyMzQ3MTI3MDQDCQAAAgUFcFR5cGUFB1NGX1BPT0wJAJUKAwkBEGdldFNGRmFybWluZ0FkZHIAAhN3aXRoZHJhd1NoYXJlVG9rZW5zCQDMCAIFBHBvb2wJAMwIAgUGYW1vdW50BQNuaWwDCQAAAgUFcFR5cGUFB1dYX1BPT0wJAJUKAwkBEGdldFdYRmFybWluZ0FkZHIBCQEHQWRkcmVzcwEJANkEAQUEcG9vbAIHdW5zdGFrZQkAzAgCBQdzaGFyZUlkCQDMCAIFBmFtb3VudAUDbmlsCQACAQIPV3JvbmcgcG9vbCB0eXBlBAhmYXJtQWRkcggFDSR0MDEyMzQ3MTI3MDQCXzEEBWZOYW1lCAUNJHQwMTIzNDcxMjcwNAJfMgQGcGFyYW1zCAUNJHQwMTIzNDcxMjcwNAJfMwQDaW52CQD8BwQFCGZhcm1BZGRyBQVmTmFtZQUGcGFyYW1zBQNuaWwDCQAAAgUDaW52BQNpbnYFBmFtb3VudAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgERY2FsY0Ftb3VudFRvUGF5U0YHBHBvb2wIYXNzZXRJZEEIYXNzZXRJZEIEYmFsQQRiYWxCEGFtb3VudFRva2VuVG9HZXQPYXNzZXRUb2tlblRvR2V0BAhwb29sQWRkcgkBB0FkZHJlc3MBCQDZBAEFBHBvb2wECWZlZVNjYWxlNgDAhD0EA2ZlZQkBEUBleHRyTmF0aXZlKDEwNTApAgUIcG9vbEFkZHIFCmtTRlBvb2xGZWUEDGFtbnRHZXROb0ZlZQkAawMFEGFtb3VudFRva2VuVG9HZXQFCWZlZVNjYWxlNgkAZQIFCWZlZVNjYWxlNgUDZmVlBA0kdDAxMzExNzEzNDA1AwkAAAIFD2Fzc2V0VG9rZW5Ub0dldAUIYXNzZXRJZEEEC2Ftb3VudFRvUGF5CQBrAwUMYW1udEdldE5vRmVlBQRiYWxCCQBlAgUEYmFsQQUMYW1udEdldE5vRmVlCQCUCgIFC2Ftb3VudFRvUGF5BQhhc3NldElkQgQLYW1vdW50VG9QYXkJAGsDBQxhbW50R2V0Tm9GZWUFBGJhbEEJAGUCBQRiYWxCBQxhbW50R2V0Tm9GZWUJAJQKAgULYW1vdW50VG9QYXkFCGFzc2V0SWRBBAthbW91bnRUb1BheQgFDSR0MDEzMTE3MTM0MDUCXzEECmFzc2V0VG9QYXkIBQ0kdDAxMzExNzEzNDA1Al8yCQCUCgIFCmFzc2V0VG9QYXkFC2Ftb3VudFRvUGF5ARFjYWxjQW1vdW50VG9QYXlXWAcEcG9vbAhhc3NldElkQQhhc3NldElkQgRiYWxBBGJhbEIQYW1vdW50VG9rZW5Ub0dldA9hc3NldFRva2VuVG9HZXQEBXByRmVlCQERQGV4dHJOYXRpdmUoMTA1MCkCBQ53eFN3YXBDb250cmFjdAIPJXNfX3Byb3RvY29sRmVlBARwRmVlCQERQGV4dHJOYXRpdmUoMTA1MCkCBQ53eFN3YXBDb250cmFjdAILJXNfX3Bvb2xGZWUECGZlZVNjYWxlCQC2AgEAgMLXLwQNJHQwMTM3NDQxNDA1MgMJAAACBQ9hc3NldFRva2VuVG9HZXQFCGFzc2V0SWRBBAthbW91bnRUb1BheQkAawMFEGFtb3VudFRva2VuVG9HZXQFBGJhbEIJAGUCBQRiYWxBBRBhbW91bnRUb2tlblRvR2V0CQCUCgIFC2Ftb3VudFRvUGF5BQhhc3NldElkQgQLYW1vdW50VG9QYXkJAGsDBRBhbW91bnRUb2tlblRvR2V0BQRiYWxBCQBlAgUEYmFsQgUQYW1vdW50VG9rZW5Ub0dldAkAlAoCBQthbW91bnRUb1BheQUIYXNzZXRJZEEEC2Ftb3VudFRvUGF5CAUNJHQwMTM3NDQxNDA1MgJfMQQKYXNzZXRUb1BheQgFDSR0MDEzNzQ0MTQwNTICXzIEEmFtb3VudFRvUGF5V2l0aEZlZQkAoAMBCQC9AgQJALYCAQULYW1vdW50VG9QYXkFCGZlZVNjYWxlCQC4AgIFCGZlZVNjYWxlCQC2AgEJAGQCBQVwckZlZQUEcEZlZQUHQ0VJTElORwkAlAoCBQphc3NldFRvUGF5CQBrAwUSYW1vdW50VG9QYXlXaXRoRmVlAGYAZAEQZXhjaGFuZ2VEaXJlY3RseQgEdHlwZQRwb29sCGFzc2V0SWRBCGFzc2V0SWRCBGJhbEEEYmFsQhBhbW91bnRUb2tlblRvR2V0D2Fzc2V0VG9rZW5Ub0dldAMJAAACBQR0eXBlBQdTRl9QT09MBA0kdDAxNDQxNTE0NTM3CQERY2FsY0Ftb3VudFRvUGF5U0YHBQRwb29sBQhhc3NldElkQQUIYXNzZXRJZEIFBGJhbEEFBGJhbEIFEGFtb3VudFRva2VuVG9HZXQFD2Fzc2V0VG9rZW5Ub0dldAQKYXNzZXRUb1BheQgFDSR0MDE0NDE1MTQ1MzcCXzEEC2Ftb3VudFRvUGF5CAUNJHQwMTQ0MTUxNDUzNwJfMgkA/AcECQERQGV4dHJOYXRpdmUoMTA2MikBBQRwb29sAgxjYWxsRnVuY3Rpb24JAMwIAgIIZXhjaGFuZ2UJAMwIAgkAzAgCCQCkAwEFEGFtb3VudFRva2VuVG9HZXQFA25pbAUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQEOYXNzZXRJZEZyb21TdHIBBQphc3NldFRvUGF5BQthbW91bnRUb1BheQUDbmlsBA0kdDAxNDcxMjE0ODM0CQERY2FsY0Ftb3VudFRvUGF5V1gHBQRwb29sBQhhc3NldElkQQUIYXNzZXRJZEIFBGJhbEEFBGJhbEIFEGFtb3VudFRva2VuVG9HZXQFD2Fzc2V0VG9rZW5Ub0dldAQKYXNzZXRUb1BheQgFDSR0MDE0NzEyMTQ4MzQCXzEEC2Ftb3VudFRvUGF5CAUNJHQwMTQ3MTIxNDgzNAJfMgkA/AcEBQ53eFN3YXBDb250cmFjdAIEc3dhcAkAzAgCBRBhbW91bnRUb2tlblRvR2V0CQDMCAIFD2Fzc2V0VG9rZW5Ub0dldAkAzAgCCQClCAEFBHRoaXMFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkBDmFzc2V0SWRGcm9tU3RyAQUKYXNzZXRUb1BheQULYW1vdW50VG9QYXkFA25pbAETY2FsY1JlcGxlbmlzaExQVmlydAgFcFR5cGUEcG9vbARwbXRBA2FJZARwbXRCA2JJZARiYWxBBGJhbEIECHBvb2xBZGRyCQERQGV4dHJOYXRpdmUoMTA2MikBBQRwb29sAwkAAAIFBXBUeXBlBQdTRl9QT09MBANpbnYKAAFACQD8BwQFCHBvb2xBZGRyAgxjYWxsRnVuY3Rpb24JAMwIAgIfY2FsY0xQUmVwbGVuaXNoRGlmZlByb3BSRUFET05MWQkAzAgCCQDMCAIJAKQDAQUEcG10QQkAzAgCCQCkAwEFBHBtdEIJAMwIAgIBMAUDbmlsBQNuaWwFA25pbAMJAAECBQFAAglMaXN0W0FueV0FAUAJAAIBCQCsAgIJAAMBBQFAAh4gY291bGRuJ3QgYmUgY2FzdCB0byBMaXN0W0FueV0DCQAAAgUDaW52BQNpbnYJAJQKAgoAAUAJAJEDAgUDaW52AAADCQABAgUBQAIDSW50BQFACQACAQkArAICCQADAQUBQAIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50CgABQAkAkQMCBQNpbnYAAQMJAAECBQFAAgNJbnQFAUAJAAIBCQCsAgIJAAMBBQFAAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4DCQAAAgUFcFR5cGUFB1dYX1BPT0wEDSR0MDE1NDM3MTU3NzgDAwkAZgIFBHBtdEEAAAkAZgIFBHBtdEIAAAcEDSR0MDE1NTE4MTU2NDQJARhjYWxjUmVwbGVuaXNoQnlUd29Ub2tlbnMIBQVwVHlwZQUIcG9vbEFkZHIFBHBtdEEFA2FJZAUEcG10QgUDYklkBQRiYWxBBQRiYWxCBAZwbXRJbkEIBQ0kdDAxNTUxODE1NjQ0Al8xBAZwbXRJbkIIBQ0kdDAxNTUxODE1NjQ0Al8yBAZjaGFuZ2UIBQ0kdDAxNTUxODE1NjQ0Al8zBAhjaGFuZ2VJZAgFDSR0MDE1NTE4MTU2NDQCXzQECGxwQW1vdW50CAUNJHQwMTU1MTgxNTY0NAJfNQkAlQoDBQZjaGFuZ2UFCGNoYW5nZUlkBQhscEFtb3VudAMJAGYCBQRwbXRBAAAJAJUKAwUEcG10QQUDYUlkAAAJAJUKAwUEcG10QgUDYklkAAAEBmNoYW5nZQgFDSR0MDE1NDM3MTU3NzgCXzEECGNoYW5nZUlkCAUNJHQwMTU0MzcxNTc3OAJfMgQFbHBUd28IBQ0kdDAxNTQzNzE1Nzc4Al8zBA0kdDAxNTc4NTE2MDAxAwkAZgIFBmNoYW5nZQAABANpbnYKAAFACQD8BwQFCHBvb2xBZGRyAhFwdXRPbmVUa25SRUFET05MWQkAzAgCBQhjaGFuZ2VJZAkAzAgCBQZjaGFuZ2UFA25pbAUDbmlsAwkAAQIFAUACDyhJbnQsIEludCwgSW50KQUBQAkAAgEJAKwCAgkAAwEFAUACJCBjb3VsZG4ndCBiZSBjYXN0IHRvIChJbnQsIEludCwgSW50KQMJAAACBQNpbnYFA2ludgkAlAoCCAUDaW52Al8xCAUDaW52Al8zCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQCUCgIAAAAABAVscE9uZQgFDSR0MDE1Nzg1MTYwMDECXzEEBGxvc3MIBQ0kdDAxNTc4NTE2MDAxAl8yCQCUCgIJAGQCBQVscFR3bwUFbHBPbmUFBGxvc3MJAAIBAg9Xcm9uZyBwb29sIHR5cGUBEmNhbGNXaXRoZHJhd0xQVmlydAoFcFR5cGUEcG9vbAhscEFtb3VudAdzaGFyZUlkA2FJZANiSWQEYmFsQQRiYWxCDGJvcnJvd0Ftb3VudA1ib3Jyb3dBc3NldElkBAhwb29sQWRkcgkBEUBleHRyTmF0aXZlKDEwNjIpAQUEcG9vbAQNJHQwMTYyOTUxNjc5NQMJAAACBQVwVHlwZQUHU0ZfUE9PTAQDaW52CgABQAkA/AcEBQhwb29sQWRkcgIMY2FsbEZ1bmN0aW9uCQDMCAICEHdpdGhkcmF3UkVBRE9OTFkJAMwIAgkAzAgCCQCkAwEFCGxwQW1vdW50CQDMCAIJAKQDAQUEYmFsQQkAzAgCCQCkAwEFBGJhbEIFA25pbAUDbmlsBQNuaWwDCQABAgUBQAIJTGlzdFtBbnldBQFACQACAQkArAICCQADAQUBQAIeIGNvdWxkbid0IGJlIGNhc3QgdG8gTGlzdFtBbnldAwkAAAIFA2ludgUDaW52CQCUCgIKAAFACQCRAwIFA2ludgAAAwkAAQIFAUACA0ludAUBQAkAAgEJAKwCAgkAAwEFAUACGCBjb3VsZG4ndCBiZSBjYXN0IHRvIEludAoAAUAJAJEDAgUDaW52AAEDCQABAgUBQAIDSW50BQFACQACAQkArAICCQADAQUBQAIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAwkAAAIFBXBUeXBlBQdXWF9QT09MBANnZXQJALUJAgoAAUAJAPwHBAUIcG9vbEFkZHICE2V2YWx1YXRlR2V0UkVBRE9OTFkJAMwIAgUHc2hhcmVJZAkAzAgCBQhscEFtb3VudAUDbmlsBQNuaWwDCQABAgUBQAIGU3RyaW5nBQFACQACAQkArAICCQADAQUBQAIbIGNvdWxkbid0IGJlIGNhc3QgdG8gU3RyaW5nAgJfXwMJAAACBQNnZXQFA2dldAkAlAoCCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUDZ2V0AAEJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQNnZXQAAgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECD1dyb25nIHBvb2wgdHlwZQQKZ2V0QW1vdW50QQgFDSR0MDE2Mjk1MTY3OTUCXzEECmdldEFtb3VudEIIBQ0kdDAxNjI5NTE2Nzk1Al8yAwkAZgIFDGJvcnJvd0Ftb3VudAAABA1hbW91bnRUb0dldEV4AwMJAAACBQ1ib3Jyb3dBc3NldElkBQNhSWQJAGYCBQxib3Jyb3dBbW91bnQFCmdldEFtb3VudEEHCQBlAgUMYm9ycm93QW1vdW50BQpnZXRBbW91bnRBAwMJAAACBQ1ib3Jyb3dBc3NldElkBQNiSWQJAGYCBQxib3Jyb3dBbW91bnQFCmdldEFtb3VudEIHCQBlAgUMYm9ycm93QW1vdW50BQpnZXRBbW91bnRCAAAEDSR0MDE3MDczMTczNzYDCQBmAgUNYW1vdW50VG9HZXRFeAAAAwkAAAIFBXBUeXBlBQdTRl9QT09MCQERY2FsY0Ftb3VudFRvUGF5U0YHBQRwb29sBQNhSWQFA2JJZAUEYmFsQQUEYmFsQgUNYW1vdW50VG9HZXRFeAUNYm9ycm93QXNzZXRJZAkBEWNhbGNBbW91bnRUb1BheVdYBwUEcG9vbAUDYUlkBQNiSWQFBGJhbEEFBGJhbEIFDWFtb3VudFRvR2V0RXgFDWJvcnJvd0Fzc2V0SWQJAJQKAgIAAAAECmFzc2V0VG9QYXkIBQ0kdDAxNzA3MzE3Mzc2Al8xBAthbW91bnRUb1BheQgFDSR0MDE3MDczMTczNzYCXzIDCQAAAgUNYm9ycm93QXNzZXRJZAUDYUlkCQCUCgIJAGUCCQBkAgUKZ2V0QW1vdW50QQUNYW1vdW50VG9HZXRFeAUMYm9ycm93QW1vdW50CQBlAgUKZ2V0QW1vdW50QgULYW1vdW50VG9QYXkJAJQKAgkAZQIFCmdldEFtb3VudEEFC2Ftb3VudFRvUGF5CQBlAgkAZAIFCmdldEFtb3VudEIFDWFtb3VudFRvR2V0RXgFDGJvcnJvd0Ftb3VudAkAlAoCBQpnZXRBbW91bnRBBQpnZXRBbW91bnRCAQtjbGFpbUZhcm1lZAIEdHlwZQRwb29sAwkAAAIFBHR5cGUFB1NGX1BPT0wECWJhbEJlZm9yZQkBDmFjY291bnRCYWxhbmNlAQUGU1dPUElEAwkAAAIFCWJhbEJlZm9yZQUJYmFsQmVmb3JlBANpbnYJAPwHBAkBEGdldFNGRmFybWluZ0FkZHIAAgVjbGFpbQkAzAgCBQRwb29sBQNuaWwFA25pbAMJAAACBQNpbnYFA2ludgQIYmFsQWZ0ZXIJAQ5hY2NvdW50QmFsYW5jZQEFBlNXT1BJRAkAlAoCCQBlAgUIYmFsQWZ0ZXIFCWJhbEJlZm9yZQUGU1dPUElECQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAwkAAAIFBHR5cGUFB1dYX1BPT0wECWJhbEJlZm9yZQkBDmFjY291bnRCYWxhbmNlAQUEV1hJRAMJAAACBQliYWxCZWZvcmUFCWJhbEJlZm9yZQQDaW52CQD8BwQJARBnZXRXWEZhcm1pbmdBZGRyAQkBB0FkZHJlc3MBCQDZBAEFBHBvb2wCB2NsYWltV1gJAMwIAgUEcG9vbAUDbmlsBQNuaWwDCQAAAgUDaW52BQNpbnYECGJhbEFmdGVyCQEOYWNjb3VudEJhbGFuY2UBBQRXWElECQCUCgIJAGUCBQhiYWxBZnRlcgUJYmFsQmVmb3JlBQRXWElECQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIPV3JvbmcgcG9vbCB0eXBlAQ9yZXBsZW5pc2hCeVR5cGUKBXBUeXBlBHBvb2wHZmVlVHlwZQRwbXRBA2FJZARwbXRCA2JJZARiYWxBBGJhbEIETFBJZAQPbHBCYWxhbmNlQmVmb3JlCQEOYWNjb3VudEJhbGFuY2UBCQDZBAEFBExQSWQDCQAAAgUPbHBCYWxhbmNlQmVmb3JlBQ9scEJhbGFuY2VCZWZvcmUECHBvb2xBZGRyCQERQGV4dHJOYXRpdmUoMTA2MikBBQRwb29sBA0kdDAxODU3MzE4OTg5AwMJAGYCBQRwbXRBAAAJAGYCBQRwbXRCAAAHBA0kdDAxODYzOTE4NzU1CQEYY2FsY1JlcGxlbmlzaEJ5VHdvVG9rZW5zCAUFcFR5cGUFCHBvb2xBZGRyBQRwbXRBBQNhSWQFBHBtdEIFA2JJZAUEYmFsQQUEYmFsQgQGcG10SW5BCAUNJHQwMTg2MzkxODc1NQJfMQQGcG10SW5CCAUNJHQwMTg2MzkxODc1NQJfMgQGY2hhbmdlCAUNJHQwMTg2MzkxODc1NQJfMwQIY2hhbmdlSWQIBQ0kdDAxODYzOTE4NzU1Al80BANpbnYJARhyZXBsZW5pc2hUd29Ub2tlbnNCeVR5cGUGBQhwb29sQWRkcgUFcFR5cGUFBnBtdEluQQUDYUlkBQZwbXRJbkIFA2JJZAMJAAACBQNpbnYFA2ludgkAlAoCBQZjaGFuZ2UFCGNoYW5nZUlkCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAwkAZgIFBHBtdEEAAAkAlAoCBQRwbXRBBQNhSWQDCQBmAgUEcG10QgAACQCUCgIFBHBtdEIFA2JJZAkAAgECEHBtdHMgbXVzdCBiZSA+IDAEBmNoYW5nZQgFDSR0MDE4NTczMTg5ODkCXzEECGNoYW5nZUlkCAUNJHQwMTg1NzMxODk4OQJfMgQDaW52AwkAZgIFBmNoYW5nZQAACQEXcmVwbGVuaXNoT25lVG9rZW5CeVR5cGUEBQhwb29sQWRkcgUFcFR5cGUFBmNoYW5nZQUIY2hhbmdlSWQFA25pbAMJAAACBQNpbnYFA2ludgQObHBCYWxhbmNlQWZ0ZXIJAQ5hY2NvdW50QmFsYW5jZQEJANkEAQUETFBJZAQLdG90YWxTdGFrZWQJAGUCBQ5scEJhbGFuY2VBZnRlcgUPbHBCYWxhbmNlQmVmb3JlBA1heGx5RmVlQW1vdW50CQBrAwULdG90YWxTdGFrZWQJAQpnZXRBeGx5RmVlAgUEcG9vbAUHZmVlVHlwZQUKRkVFX1NDQUxFNgQRdXNlclNoYXJlRm9yU3Rha2UJAGUCBQt0b3RhbFN0YWtlZAUNYXhseUZlZUFtb3VudAMJAGcCAAAFEXVzZXJTaGFyZUZvclN0YWtlCQACAQIoYW1vdW50IG9mIHN0YWtlZCBzaGFyZXRva2VucyBtdXN0IGJlID4gMAQFaW52TFAJAQdzdGFrZUxQBAUEcG9vbAUFcFR5cGUFBExQSWQFEXVzZXJTaGFyZUZvclN0YWtlAwkAAAIFBWludkxQBQVpbnZMUAkAlAoCBRF1c2VyU2hhcmVGb3JTdGFrZQUNYXhseUZlZUFtb3VudAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgEQcmVwbGVuaXNoRW50cmllcwgEcG9vbAR1c2VyDHN0YWtlZEFtb3VudA1heGx5RmVlQW1vdW50BnBvc051bQdzaGFyZUlkBHR5cGUId2l0aExvYW4EC3RvdGFsQW1vdW50CQERZ2V0UG9vbFRvdGFsU2hhcmUBBQRwb29sBA90b3RhbEFtb3VudExvYW4JARlnZXRQb29sVG90YWxTaGFyZVdpdGhMb2FuAQUEcG9vbAQNJHQwMTk4NDcyMDA4NQMFCHdpdGhMb2FuCQCUCgIJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAKwCAgUEcG9vbAURa1Bvb2xJbnRlcmVzdExvYW4JAGQCBQ90b3RhbEFtb3VudExvYW4FDHN0YWtlZEFtb3VudAkAlAoCCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzCQCsAgIFBHBvb2wFE2tQb29sSW50ZXJlc3ROb0xvYW4FD3RvdGFsQW1vdW50TG9hbgQPY3VyUG9vbEludGVyZXN0CAUNJHQwMTk4NDcyMDA4NQJfMQQTdG90YWxTdGFrZWRXaXRoTG9hbggFDSR0MDE5ODQ3MjAwODUCXzIJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUEcG9vbAUKa1Bvb2xUb3RhbAkAZAIFC3RvdGFsQW1vdW50BQxzdGFrZWRBbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUEcG9vbAUOa1Bvb2xUb3RhbExvYW4FE3RvdGFsU3Rha2VkV2l0aExvYW4JAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfCQCkAwEFBnBvc051bQUNa1VzZXJQb3NpdGlvbgUMc3Rha2VkQW1vdW50CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUEcG9vbAIBXwUEdXNlcgIBXwkApAMBBQZwb3NOdW0FFWtVc2VyUG9zaXRpb25JbnRlcmVzdAUPY3VyUG9vbEludGVyZXN0CQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICCQCsAgIFBHVzZXICAV8JAKQDAQUGcG9zTnVtBRFrVXNlclBvc2l0aW9uUG9vbAUEcG9vbAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQR1c2VyBRBrVXNlclBvc2l0aW9uTnVtBQZwb3NOdW0JAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUIbW9uZXlCb3gFDWF4bHlGZWVBbW91bnQJANkEAQUHc2hhcmVJZAUDbmlsAQ5leGNoYW5nZUtlZXBlcgoHdG9Ub2tlbglwbXRBbW91bnQIcG10QXNzZXQJYW1vdW50c0luCWFkZHJlc3Nlcw9hc3NldHNUb1JlY2VpdmULZXN0UmVjZWl2ZWQRc2xpcHBhZ2VUb2xlcmFuY2ULbWluUmVjZWl2ZWQHb3B0aW9ucwQSdG9rZW5CYWxhbmNlQmVmb3JlCQEOYWNjb3VudEJhbGFuY2UBCQEOYXNzZXRJZEZyb21TdHIBBQd0b1Rva2VuAwkAAAIFEnRva2VuQmFsYW5jZUJlZm9yZQUSdG9rZW5CYWxhbmNlQmVmb3JlBANpbnYJAPwHBAUKZXhDb250cmFjdAIEc3dhcAkAzAgCBQlhbW91bnRzSW4JAMwIAgUJYWRkcmVzc2VzCQDMCAIFD2Fzc2V0c1RvUmVjZWl2ZQkAzAgCBQtlc3RSZWNlaXZlZAkAzAgCBRFzbGlwcGFnZVRvbGVyYW5jZQkAzAgCBQttaW5SZWNlaXZlZAkAzAgCBQdvcHRpb25zBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFCHBtdEFzc2V0BQlwbXRBbW91bnQFA25pbAMJAAACBQNpbnYFA2ludgkAZQIJAQ5hY2NvdW50QmFsYW5jZQEJAQ5hc3NldElkRnJvbVN0cgEFB3RvVG9rZW4FEnRva2VuQmFsYW5jZUJlZm9yZQkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgEOZXhjaGFuZ2VQdXp6bGUGB3RvVG9rZW4JcG10QW1vdW50CHBtdEFzc2V0CXJvdXRlc1N0cgxtaW5Ub1JlY2VpdmUHb3B0aW9ucwQSdG9rZW5CYWxhbmNlQmVmb3JlCQEOYWNjb3VudEJhbGFuY2UBCQEOYXNzZXRJZEZyb21TdHIBBQd0b1Rva2VuAwkAAAIFEnRva2VuQmFsYW5jZUJlZm9yZQUSdG9rZW5CYWxhbmNlQmVmb3JlBANpbnYJAPwHBAUKZXhDb250cmFjdAIKcHV6emxlU3dhcAkAzAgCBQlyb3V0ZXNTdHIJAMwIAgUMbWluVG9SZWNlaXZlCQDMCAIFB29wdGlvbnMFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUIcG10QXNzZXQFCXBtdEFtb3VudAUDbmlsAwkAAAIFA2ludgUDaW52CQBlAgkBDmFjY291bnRCYWxhbmNlAQkBDmFzc2V0SWRGcm9tU3RyAQUHdG9Ub2tlbgUSdG9rZW5CYWxhbmNlQmVmb3JlCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQ5leGNoYW5nZVN3b3BGaQoHdG9Ub2tlbglwbXRBbW91bnQIcG10QXNzZXQKZXhjaGFuZ2Vycw5leGNoYW5nZXJzVHlwZQVhcmdzMQVhcmdzMhFyb3V0aW5nQXNzZXRzS2V5cxJtaW5BbW91bnRUb1JlY2VpdmUHb3B0aW9ucwQSdG9rZW5CYWxhbmNlQmVmb3JlCQEOYWNjb3VudEJhbGFuY2UBCQEOYXNzZXRJZEZyb21TdHIBBQd0b1Rva2VuAwkAAAIFEnRva2VuQmFsYW5jZUJlZm9yZQUSdG9rZW5CYWxhbmNlQmVmb3JlBANpbnYJAPwHBAUKZXhDb250cmFjdAIKc3dvcGZpU3dhcAkAzAgCBQpleGNoYW5nZXJzCQDMCAIFDmV4Y2hhbmdlcnNUeXBlCQDMCAIFBWFyZ3MxCQDMCAIFBWFyZ3MyCQDMCAIFEXJvdXRpbmdBc3NldHNLZXlzCQDMCAIFEm1pbkFtb3VudFRvUmVjZWl2ZQkAzAgCBQdvcHRpb25zBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFCHBtdEFzc2V0BQlwbXRBbW91bnQFA25pbAMJAAACBQNpbnYFA2ludgkAZQIJAQ5hY2NvdW50QmFsYW5jZQEJAQ5hc3NldElkRnJvbVN0cgEFB3RvVG9rZW4FEnRva2VuQmFsYW5jZUJlZm9yZQkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgEKY2FwaXRhbGl6ZQQEcG9vbAVwVHlwZQd0b2tlbklkC3Rva2VuQW1vdW50BAhwb29sQWRkcgkBB0FkZHJlc3MBCQDZBAEFBHBvb2wEDSR0MDIyNDM2MjI1MDIJAQtnZXRQb29sRGF0YQIFCHBvb2xBZGRyBQVwVHlwZQQDQUlkCAUNJHQwMjI0MzYyMjUwMgJfMQQDQklkCAUNJHQwMjI0MzYyMjUwMgJfMgQEYmFsQQgFDSR0MDIyNDM2MjI1MDICXzMEBGJhbEIIBQ0kdDAyMjQzNjIyNTAyAl80BAdzaGFyZUlkCAUNJHQwMjI0MzYyMjUwMgJfNQMDCQECIT0CBQd0b2tlbklkBQNBSWQJAQIhPQIFB3Rva2VuSWQFA0JJZAcJAAIBAgtXcm9uZyBhc3NldAQNJHQwMjI1ODcyMjY2NwMJAAACBQd0b2tlbklkBQNBSWQJAJQKAgULdG9rZW5BbW91bnQAAAkAlAoCAAAFC3Rva2VuQW1vdW50BARwbXRBCAUNJHQwMjI1ODcyMjY2NwJfMQQEcG10QggFDSR0MDIyNTg3MjI2NjcCXzIEDSR0MDIyNjcwMjI3NzQJAQ9yZXBsZW5pc2hCeVR5cGUKBQVwVHlwZQUEcG9vbAUGTk9fRkVFBQRwbXRBBQNBSWQFBHBtdEIFA0JJZAUEYmFsQQUEYmFsQgUHc2hhcmVJZAQMc3Rha2VkQW1vdW50CAUNJHQwMjI2NzAyMjc3NAJfMQQCbmYIBQ0kdDAyMjY3MDIyNzc0Al8yBBNjdXJQb29sSW50ZXJlc3RMb2FuCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAKwCAgUEcG9vbAURa1Bvb2xJbnRlcmVzdExvYW4AAAQVY3VyUG9vbEludGVyZXN0Tm9Mb2FuCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAKwCAgUEcG9vbAUTa1Bvb2xJbnRlcmVzdE5vTG9hbgAABBB0b3RhbFNoYXJlQW1vdW50CQERZ2V0UG9vbFRvdGFsU2hhcmUBBQRwb29sBBh0b3RhbFNoYXJlQW1vdW50V2l0aExvYW4JARlnZXRQb29sVG90YWxTaGFyZVdpdGhMb2FuAQUEcG9vbAQLbG9hblBlcmNlbnQJAGsDBRh0b3RhbFNoYXJlQW1vdW50V2l0aExvYW4FBlNDQUxFOAUQdG90YWxTaGFyZUFtb3VudAQKc3Rha2VkTG9hbgkAawMFDHN0YWtlZEFtb3VudAULbG9hblBlcmNlbnQFBlNDQUxFOAQMc3Rha2VkTm9Mb2FuCQBlAgUMc3Rha2VkQW1vdW50BQpzdGFrZWRMb2FuBA9uZXdJbnRlcmVzdExvYW4DCQBmAgUYdG90YWxTaGFyZUFtb3VudFdpdGhMb2FuAAAJAGQCBRNjdXJQb29sSW50ZXJlc3RMb2FuCQBrAwUKc3Rha2VkTG9hbgUHU0NBTEUxMAUYdG90YWxTaGFyZUFtb3VudFdpdGhMb2FuAAAEEW5ld0ludGVyZXN0Tm9Mb2FuAwkAZgIJAGUCBRB0b3RhbFNoYXJlQW1vdW50BRh0b3RhbFNoYXJlQW1vdW50V2l0aExvYW4AAAkAZAIFFWN1clBvb2xJbnRlcmVzdE5vTG9hbgkAawMFDHN0YWtlZE5vTG9hbgUHU0NBTEUxMAkAZQIFEHRvdGFsU2hhcmVBbW91bnQFGHRvdGFsU2hhcmVBbW91bnRXaXRoTG9hbgAABAtheGx5RmVlTG9hbgkAawMFCnN0YWtlZExvYW4JAQpnZXRBeGx5RmVlAgUEcG9vbAUMQ0FQX0ZFRV9MT0FOBQpGRUVfU0NBTEU2BA1heGx5RmVlTm9Mb2FuCQBrAwUMc3Rha2VkTm9Mb2FuCQEKZ2V0QXhseUZlZQIFBHBvb2wFD0NBUF9GRUVfTk9fTE9BTgUKRkVFX1NDQUxFNgQHYXhseUZlZQkBCXVuc3Rha2VMUAQFBHBvb2wFBXBUeXBlBQdzaGFyZUlkCQBkAgULYXhseUZlZUxvYW4FDWF4bHlGZWVOb0xvYW4DCQAAAgUHYXhseUZlZQUHYXhseUZlZQkAzggCCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFBHBvb2wFEWtQb29sSW50ZXJlc3RMb2FuBQ9uZXdJbnRlcmVzdExvYW4JAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUEcG9vbAUTa1Bvb2xJbnRlcmVzdE5vTG9hbgURbmV3SW50ZXJlc3ROb0xvYW4JAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUEcG9vbAUKa1Bvb2xUb3RhbAkAZQIJAGQCBRB0b3RhbFNoYXJlQW1vdW50BQxzdGFrZWRBbW91bnQFB2F4bHlGZWUJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUEcG9vbAUOa1Bvb2xUb3RhbExvYW4JAGUCCQBkAgUYdG90YWxTaGFyZUFtb3VudFdpdGhMb2FuBQpzdGFrZWRMb2FuBQtheGx5RmVlTG9hbgkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQhtb25leUJveAkAZAIFC2F4bHlGZWVMb2FuBQ1heGx5RmVlTm9Mb2FuCQDZBAEFB3NoYXJlSWQFA25pbAkBDmdldEN1cnNFbnRyaWVzAwUDQUlkBQNCSWQFB3NoYXJlSWQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BEndpdGhkcmF3QW1vdW50Q2FsYwQEcG9vbA91c2VyQ2FuV2l0aGRyYXcEZGVidAtib3Jyb3dBc3NldAQIcG9vbEFkZHIJAQdBZGRyZXNzAQkA2QQBBQRwb29sBAVwVHlwZQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMJAKwCAgUFa1Bvb2wFBHBvb2wCDFVua25vd24gcG9vbAQNJHQwMjQ1NDIyNDYxOAkBC2dldFBvb2xEYXRhAgUIcG9vbEFkZHIFBXBUeXBlBAhhc3NldElkQQgFDSR0MDI0NTQyMjQ2MTgCXzEECGFzc2V0SWRCCAUNJHQwMjQ1NDIyNDYxOAJfMgQEYmFsQQgFDSR0MDI0NTQyMjQ2MTgCXzMEBGJhbEIIBQ0kdDAyNDU0MjI0NjE4Al80BAdzaGFyZUlkCAUNJHQwMjQ1NDIyNDYxOAJfNQQLY0JhbEFCZWZvcmUJAQ5hY2NvdW50QmFsYW5jZQEJAQ5hc3NldElkRnJvbVN0cgEFCGFzc2V0SWRBAwkAAAIFC2NCYWxBQmVmb3JlBQtjQmFsQUJlZm9yZQQLY0JhbEJCZWZvcmUJAQ5hY2NvdW50QmFsYW5jZQEJAQ5hc3NldElkRnJvbVN0cgEFCGFzc2V0SWRCAwkAAAIFC2NCYWxCQmVmb3JlBQtjQmFsQkJlZm9yZQQDaW52AwkAAAIFBXBUeXBlBQdTRl9QT09MCQD8BwQFCHBvb2xBZGRyAgxjYWxsRnVuY3Rpb24JAMwIAgIId2l0aGRyYXcJAMwIAgkAzAgCCQCkAwEFD3VzZXJDYW5XaXRoZHJhdwUDbmlsBQNuaWwFA25pbAQDaW52CQEJdW5zdGFrZUxQBAUEcG9vbAUFcFR5cGUFB3NoYXJlSWQFD3VzZXJDYW5XaXRoZHJhdwMJAAACBQNpbnYFA2ludgkA/AcEBQhwb29sQWRkcgIDZ2V0BQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJAQ5hc3NldElkRnJvbVN0cgEFB3NoYXJlSWQFD3VzZXJDYW5XaXRoZHJhdwUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAwkAAAIFA2ludgUDaW52BApjQmFsQUFmdGVyCQEOYWNjb3VudEJhbGFuY2UBCQEOYXNzZXRJZEZyb21TdHIBBQhhc3NldElkQQQKY0JhbEJBZnRlcgkBDmFjY291bnRCYWxhbmNlAQkBDmFzc2V0SWRGcm9tU3RyAQUIYXNzZXRJZEIEDSR0MDI1MTgxMjUyNzAJAJQKAgkAZQIFCmNCYWxBQWZ0ZXIFC2NCYWxBQmVmb3JlCQBlAgUKY0JhbEJBZnRlcgULY0JhbEJCZWZvcmUEDXRva2Vuc0Ftb3VudEEIBQ0kdDAyNTE4MTI1MjcwAl8xBA10b2tlbnNBbW91bnRCCAUNJHQwMjUxODEyNTI3MAJfMgQNJHQwMjUyNzMyNjA5MwMJAGYCBQRkZWJ0AAAEDWFtb3VudFRvR2V0RXgDAwkAAAIFC2JvcnJvd0Fzc2V0BQhhc3NldElkQQkAZgIFBGRlYnQFDXRva2Vuc0Ftb3VudEEHCQBlAgUEZGVidAUNdG9rZW5zQW1vdW50QQMDCQAAAgULYm9ycm93QXNzZXQFCGFzc2V0SWRCCQBmAgUEZGVidAUNdG9rZW5zQW1vdW50QgcJAGUCBQRkZWJ0BQ10b2tlbnNBbW91bnRCAAAEBWV4SW52AwkAZgIFDWFtb3VudFRvR2V0RXgAAAkBEGV4Y2hhbmdlRGlyZWN0bHkIBQVwVHlwZQUEcG9vbAUIYXNzZXRJZEEFCGFzc2V0SWRCBQRiYWxBBQRiYWxCBQ1hbW91bnRUb0dldEV4BQtib3Jyb3dBc3NldAAAAwkAAAIFBWV4SW52BQVleEludgQPY0JhbEFBZnRlclJlcGF5CQEOYWNjb3VudEJhbGFuY2UBCQEOYXNzZXRJZEZyb21TdHIBBQhhc3NldElkQQQPY0JhbEJBZnRlclJlcGF5CQEOYWNjb3VudEJhbGFuY2UBCQEOYXNzZXRJZEZyb21TdHIBBQhhc3NldElkQgMJAAACBQtib3Jyb3dBc3NldAUIYXNzZXRJZEEJAJQKAgkAZQIJAGUCBQ9jQmFsQUFmdGVyUmVwYXkFC2NCYWxBQmVmb3JlBQRkZWJ0CQBlAgUPY0JhbEJBZnRlclJlcGF5BQtjQmFsQkJlZm9yZQkAlAoCCQBlAgUPY0JhbEFBZnRlclJlcGF5BQtjQmFsQUJlZm9yZQkAZQIJAGUCBQ9jQmFsQkFmdGVyUmVwYXkFC2NCYWxCQmVmb3JlBQRkZWJ0CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQCUCgIFDXRva2Vuc0Ftb3VudEEFDXRva2Vuc0Ftb3VudEIEB3RvVXNlckEIBQ0kdDAyNTI3MzI2MDkzAl8xBAd0b1VzZXJCCAUNJHQwMjUyNzMyNjA5MwJfMgkAmQoHBQd0b1VzZXJBBQhhc3NldElkQQUHdG9Vc2VyQgUIYXNzZXRJZEIFCmNCYWxBQWZ0ZXIFCmNCYWxCQWZ0ZXIFB3NoYXJlSWQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BGHVzZXJDYW5XaXRoZHJhd1NoYXJlQ2FsYwQEdXNlcgRwb29sBXBvc0lkCGJvcnJvd2VkBAdwQW1vdW50CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUEdGhpcwkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBHBvb2wCAV8FBHVzZXICAV8FBXBvc0lkBQ1rVXNlclBvc2l0aW9uAhBVbmtub3duIHBvc2l0aW9uBAx1c2VySW50ZXJlc3QJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfBQVwb3NJZAUVa1VzZXJQb3NpdGlvbkludGVyZXN0BAxwb29sSW50ZXJlc3QDBQhib3Jyb3dlZAkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwkArAICBQRwb29sBRFrUG9vbEludGVyZXN0TG9hbgkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwkArAICBQRwb29sBRNrUG9vbEludGVyZXN0Tm9Mb2FuCQBkAgUHcEFtb3VudAkAawMFB3BBbW91bnQJAGUCBQxwb29sSW50ZXJlc3QFDHVzZXJJbnRlcmVzdAUHU0NBTEUxMAEOd2l0aGRyYXdUb1VzZXIEBHVzZXIEcG9vbAVwb3NJZAhzdG9wTG9zcwQHcEFtb3VudAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFBHRoaXMJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfBQVwb3NJZAUNa1VzZXJQb3NpdGlvbgIQVW5rbm93biBwb3NpdGlvbgQMYm9ycm93QW1vdW50CQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfBQVwb3NJZAURa1VzZXJCb3Jyb3dBbW91bnQAAAQPdXNlckNhbldpdGhkcmF3CQEYdXNlckNhbldpdGhkcmF3U2hhcmVDYWxjBAUEdXNlcgUEcG9vbAUFcG9zSWQJAGYCBQxib3Jyb3dBbW91bnQAAAQOcG9vbFRvdGFsU2hhcmUJARFnZXRQb29sVG90YWxTaGFyZQEFBHBvb2wECHVzZXJBZGRyCQEHQWRkcmVzcwEJANkEAQUEdXNlcgQLYm9ycm93QXNzZXQJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUEdGhpcwkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBHBvb2wCAV8FBHVzZXICAV8FBXBvc0lkBRJrVXNlckJvcnJvd0Fzc2V0SWQCAAQEZGVidAMJAGYCBQxib3Jyb3dBbW91bnQAAAoAAUAJAPwHBAkBDmdldExlbmRTcnZBZGRyAAIMZ2V0QXNzZXREZWJ0CQDMCAIHCQDMCAIJAKwCAgkArAICBQR1c2VyAgFfBQVwb3NJZAkAzAgCBQtib3Jyb3dBc3NldAUDbmlsBQNuaWwDCQABAgUBQAIDSW50BQFACQACAQkArAICCQADAQUBQAIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50AAAEDSR0MDI3NDgxMjc2MzQJARJ3aXRoZHJhd0Ftb3VudENhbGMEBQRwb29sBQ91c2VyQ2FuV2l0aGRyYXcFBGRlYnQFC2JvcnJvd0Fzc2V0AwkAAAIFDSR0MDI3NDgxMjc2MzQFDSR0MDI3NDgxMjc2MzQEB3NoYXJlSWQIBQ0kdDAyNzQ4MTI3NjM0Al83BApjQmFsQkFmdGVyCAUNJHQwMjc0ODEyNzYzNAJfNgQKY0JhbEFBZnRlcggFDSR0MDI3NDgxMjc2MzQCXzUECGFzc2V0SWRCCAUNJHQwMjc0ODEyNzYzNAJfNAQNdG9Vc2VyQW1vdW50QggFDSR0MDI3NDgxMjc2MzQCXzMECGFzc2V0SWRBCAUNJHQwMjc0ODEyNzYzNAJfMgQNdG9Vc2VyQW1vdW50QQgFDSR0MDI3NDgxMjc2MzQCXzEEC2Nsb3NlRGJ0SW52AwkAZgIFBGRlYnQAAAkA/AcECQEOZ2V0TGVuZFNydkFkZHIAAghyZXBheUZvcgkAzAgCCQCsAgIJAKwCAgUEdXNlcgIBXwUFcG9zSWQFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkBDmFzc2V0SWRGcm9tU3RyAQULYm9ycm93QXNzZXQFBGRlYnQFA25pbAAAAwkAAAIFC2Nsb3NlRGJ0SW52BQtjbG9zZURidEludgkAzggCCQDMCAIJAQtEZWxldGVFbnRyeQEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfBQVwb3NJZAUNa1VzZXJQb3NpdGlvbgkAzAgCCQELRGVsZXRlRW50cnkBCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUEcG9vbAIBXwUEdXNlcgIBXwUFcG9zSWQFFWtVc2VyUG9zaXRpb25JbnRlcmVzdAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQRwb29sBQprUG9vbFRvdGFsCQBlAgUOcG9vbFRvdGFsU2hhcmUFD3VzZXJDYW5XaXRoZHJhdwkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQh1c2VyQWRkcgUNdG9Vc2VyQW1vdW50QQkBDmFzc2V0SWRGcm9tU3RyAQUIYXNzZXRJZEEJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUIdXNlckFkZHIFDXRvVXNlckFtb3VudEIJAQ5hc3NldElkRnJvbVN0cgEFCGFzc2V0SWRCBQNuaWwJAQ5nZXRDdXJzRW50cmllcwMFCGFzc2V0SWRBBQhhc3NldElkQgUHc2hhcmVJZAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgEMcGFyc2VSZXF1ZXN0AQlyZXF1ZXN0SWQEB3JlcXVlc3QJALUJAgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMJAKwCAgUJcmVxdWVzdElkBQprUmVxdWVzdElkCQCsAgICE05vIHJlcXVlc3Qgd2l0aCBpZCAFCXJlcXVlc3RJZAIBLAQEdXNlcgkAkQMCBQdyZXF1ZXN0AAAEBHBvb2wJAJEDAgUHcmVxdWVzdAABBARwbXRBCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUHcmVxdWVzdAACBANBSWQJAJEDAgUHcmVxdWVzdAADBARwbXRCCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUHcmVxdWVzdAAEBANCSWQJAJEDAgUHcmVxdWVzdAAFBARiYWxBCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUHcmVxdWVzdAAGBARiYWxCCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUHcmVxdWVzdAAHBAdzaGFyZUlkCQCRAwIFB3JlcXVlc3QACAQHYndBc3NldAkAkQMCBQdyZXF1ZXN0AAkECGJ3QW1vdW50CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUHcmVxdWVzdAAKCQCdCgsFBHVzZXIFBHBvb2wFBHBtdEEFA0FJZAUEcG10QgUDQklkBQRiYWxBBQRiYWxCBQdzaGFyZUlkBQdid0Fzc2V0BQhid0Ftb3VudAEQY2FsY0JvcnJvd0Ftb3VudAYEcG10QQRwbXRCA2FJZANiSWQIbGV2ZXJhZ2UIYm9ycm93SWQEB2RQcmljZUEICgABQAkA/AcEBQ9wcmljZU9yYWNsZUFkZHICCWdldFRXQVA2MAkAzAgCBQNhSWQJAMwIAgcFA25pbAUDbmlsAwkAAQIFAUACCihJbnQsIEludCkFAUAJAAIBCQCsAgIJAAMBBQFAAh8gY291bGRuJ3QgYmUgY2FzdCB0byAoSW50LCBJbnQpAl8yBAdkUHJpY2VCCAoAAUAJAPwHBAUPcHJpY2VPcmFjbGVBZGRyAglnZXRUV0FQNjAJAMwIAgUDYklkCQDMCAIHBQNuaWwFA25pbAMJAAECBQFAAgooSW50LCBJbnQpBQFACQACAQkArAICCQADAQUBQAIfIGNvdWxkbid0IGJlIGNhc3QgdG8gKEludCwgSW50KQJfMgQGZGVjUHJBCQBsBgAKAAAJARBnZXRBc3NldERlY2ltYWxzAQUDYUlkAAAAAAUERE9XTgQGZGVjUHJCCQBsBgAKAAAJARBnZXRBc3NldERlY2ltYWxzAQUDYklkAAAAAAUERE9XTgQMcGF5ZEluRG9sbGFyCQBkAgkAawMFB2RQcmljZUEFBHBtdEEFBmRlY1ByQQkAawMFB2RQcmljZUIFBHBtdEIFBmRlY1ByQgQNJHQwMjkzMjAyOTQxNwMJAAACBQhib3Jyb3dJZAUDYUlkCQCUCgIFB2RQcmljZUEFBmRlY1ByQQkAlAoCBQdkUHJpY2VCBQZkZWNQckIEC2JvcnJvd1ByaWNlCAUNJHQwMjkzMjAyOTQxNwJfMQQLYm9ycm93RGVjUHIIBQ0kdDAyOTMyMDI5NDE3Al8yCQBrAwkAawMFDHBheWRJbkRvbGxhcgkAZQIFCGxldmVyYWdlAGQAZAULYm9ycm93RGVjUHIFC2JvcnJvd1ByaWNlEQFpARdjYWxjUHJpY2VJbXBhY3RFVkFMT05MWQUEcG9vbAhsZXZlcmFnZQhib3Jyb3dJZARwbXRBBHBtdEIDAwkAZgIAZAUIbGV2ZXJhZ2UGCQBmAgUIbGV2ZXJhZ2UArAIJAAIBAh9MZXZlcmFnZSBjYW4ndCBiZSA8MTAwIGFuZCA+MzAwBAVwVHlwZQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMJAKwCAgUFa1Bvb2wFBHBvb2wCElBvb2wgaXMgbm90IGluaXRlZAQNJHQwMjk4MzUyOTkyNQkBC2dldFBvb2xEYXRhAgkBB0FkZHJlc3MBCQDZBAEFBHBvb2wFBXBUeXBlBANBSWQIBQ0kdDAyOTgzNTI5OTI1Al8xBANCSWQIBQ0kdDAyOTgzNTI5OTI1Al8yBARiYWxBCAUNJHQwMjk4MzUyOTkyNQJfMwQEYmFsQggFDSR0MDI5ODM1Mjk5MjUCXzQEB3NoYXJlSWQIBQ0kdDAyOTgzNTI5OTI1Al81BAxib3Jyb3dBbW91bnQDCQBmAgUIbGV2ZXJhZ2UAZAkBEGNhbGNCb3Jyb3dBbW91bnQGBQRwbXRBBQRwbXRCBQNBSWQFA0JJZAUIbGV2ZXJhZ2UFCGJvcnJvd0lkAAAEDSR0MDMwMDYwMzAxNjcDCQAAAgUIYm9ycm93SWQFA0FJZAkAlAoCCQBkAgUEcG10QQUMYm9ycm93QW1vdW50BQRwbXRCCQCUCgIFBHBtdEEJAGQCBQRwbXRCBQxib3Jyb3dBbW91bnQEBnBheUluQQgFDSR0MDMwMDYwMzAxNjcCXzEEBnBheUluQggFDSR0MDMwMDYwMzAxNjcCXzIEDSR0MDMwMTcwMzAyNjMJARNjYWxjUmVwbGVuaXNoTFBWaXJ0CAUFcFR5cGUFBHBvb2wFBnBheUluQQUDQUlkBQZwYXlJbkIFA0JJZAUEYmFsQQUEYmFsQgQIbHBBbW91bnQIBQ0kdDAzMDE3MDMwMjYzAl8xBARsb3NzCAUNJHQwMzAxNzAzMDI2MwJfMgQJaW1wYWN0TW9kAwkAZgIAAAUEbG9zcwkAaAIFBGxvc3MA////////////AQUEbG9zcwkAlAoCBQNuaWwJAMwIAgUJaW1wYWN0TW9kBQNuaWwBaQEaZ2V0U2hhcmVBc3NldFByaWNlUkVBRE9OTFkBB3NoYXJlSWQEC3NoYXJlUHJpY2VzCQENZ2V0U2hhcmVQcmljZQEFB3NoYXJlSWQJAJQKAgUDbmlsBQtzaGFyZVByaWNlcwFpASJnZXRVc2VyUG9zaXRpb25TaGFyZUFtb3VudFJFQURPTkxZAgR1c2VyBnBvc051bQQEcG9vbAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMJAKwCAgkArAICCQCsAgIFBHVzZXICAV8FBnBvc051bQURa1VzZXJQb3NpdGlvblBvb2wCEFVua25vd24gcG9zaXRpb24EDGJvcnJvd0Ftb3VudAkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBHBvb2wCAV8FBHVzZXICAV8FBnBvc051bQURa1VzZXJCb3Jyb3dBbW91bnQED3VzZXJDYW5XaXRoZHJhdwkBGHVzZXJDYW5XaXRoZHJhd1NoYXJlQ2FsYwQFBHVzZXIFBHBvb2wFBnBvc051bQkAZgIFDGJvcnJvd0Ftb3VudAAACQCUCgIFA25pbAUPdXNlckNhbldpdGhkcmF3AWkBIGdldFVzZXJQb3NpdGlvbkluRG9sbGFyc1JFQURPTkxZAwR1c2VyBXBvb2xzBnBvc051bQoBB3VzZXJQb3MCAWEEcG9vbAQNJHQwMzEwNzYzMTExMAUBYQQIdG90YWxQb3MIBQ0kdDAzMTA3NjMxMTEwAl8xBAdwb3NEZWJ0CAUNJHQwMzEwNzYzMTExMAJfMgQFaW5kZXgIBQ0kdDAzMTA3NjMxMTEwAl8zBAVwVHlwZQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMJAKwCAgUFa1Bvb2wFBHBvb2wCElBvb2wgaXMgbm90IGluaXRlZAQNJHQwMzEyMDIzMTI5MgkBC2dldFBvb2xEYXRhAgkBB0FkZHJlc3MBCQDZBAEFBHBvb2wFBXBUeXBlBANBSWQIBQ0kdDAzMTIwMjMxMjkyAl8xBANCSWQIBQ0kdDAzMTIwMjMxMjkyAl8yBARiYWxBCAUNJHQwMzEyMDIzMTI5MgJfMwQEYmFsQggFDSR0MDMxMjAyMzEyOTICXzQEB3NoYXJlSWQIBQ0kdDAzMTIwMjMxMjkyAl81BAxib3Jyb3dBbW91bnQJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBHBvb2wCAV8FBHVzZXICAV8JAJEDAgUGcG9zTnVtBQVpbmRleAURa1VzZXJCb3Jyb3dBbW91bnQAAAQPdXNlckNhbldpdGhkcmF3CQEYdXNlckNhbldpdGhkcmF3U2hhcmVDYWxjBAUEdXNlcgUEcG9vbAkAkQMCBQZwb3NOdW0FBWluZGV4CQBmAgUMYm9ycm93QW1vdW50AAAEC3NoYXJlUHJpY2VzCQENZ2V0U2hhcmVQcmljZQEFB3NoYXJlSWQECmRlY1ByU2hhcmUJAGwGAAoAAAkBEGdldEFzc2V0RGVjaW1hbHMBBQdzaGFyZUlkAAAAAAUERE9XTgQGc2hhcmVECQBrAwUPdXNlckNhbldpdGhkcmF3BQtzaGFyZVByaWNlcwUKZGVjUHJTaGFyZQMJAAACBQxib3Jyb3dBbW91bnQAAAkAlQoDCQDNCAIFCHRvdGFsUG9zBQZzaGFyZUQJAM0IAgUHcG9zRGVidAAACQBkAgUFaW5kZXgAAQQLYm9ycm93QXNzZXQJARFAZXh0ck5hdGl2ZSgxMDUzKQIFBHRoaXMJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfCQCRAwIFBnBvc051bQUFaW5kZXgFEmtVc2VyQm9ycm93QXNzZXRJZAQEZGVidAoAAUAJAPwHBAkBDmdldExlbmRTcnZBZGRyAAIMZ2V0QXNzZXREZWJ0CQDMCAIHCQDMCAIJAKwCAgkArAICBQR1c2VyAgFfCQCRAwIFBnBvc051bQUFaW5kZXgJAMwIAgULYm9ycm93QXNzZXQFA25pbAUDbmlsAwkAAQIFAUACA0ludAUBQAkAAgEJAKwCAgkAAwEFAUACGCBjb3VsZG4ndCBiZSBjYXN0IHRvIEludAQQYm9ycm93QXNzZXRQcmljZQgKAAFACQD8BwQFD3ByaWNlT3JhY2xlQWRkcgIJZ2V0VFdBUDYwCQDMCAIFC2JvcnJvd0Fzc2V0CQDMCAIHBQNuaWwFA25pbAMJAAECBQFAAgooSW50LCBJbnQpBQFACQACAQkArAICCQADAQUBQAIfIGNvdWxkbid0IGJlIGNhc3QgdG8gKEludCwgSW50KQJfMQQNZGVjUHJCb3Jyb3dJZAkAbAYACgAACQEQZ2V0QXNzZXREZWNpbWFscwEFC2JvcnJvd0Fzc2V0AAAAAAUERE9XTgQFZGVidEQJAGsDBQRkZWJ0BRBib3Jyb3dBc3NldFByaWNlBQ1kZWNQckJvcnJvd0lkCQCVCgMJAM0IAgUIdG90YWxQb3MFBnNoYXJlRAkAzQgCBQdwb3NEZWJ0BQVkZWJ0RAkAZAIFBWluZGV4AAEEDSR0MDMyMzM1MzIzOTAKAAIkbAUFcG9vbHMKAAIkcwkAkAMBBQIkbAoABSRhY2MwCQCVCgMFA25pbAUDbmlsAAAKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBB3VzZXJQb3MCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDIwCQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoACwAMAA0ADgAPABAAEQASABMAFAQDcG9zCAUNJHQwMzIzMzUzMjM5MAJfMQQEZGVidAgFDSR0MDMyMzM1MzIzOTACXzIJAJQKAgUDbmlsCQCUCgIFA3BvcwUEZGVidAFpAQlyZXBsZW5pc2gDBHBvb2wIbGV2ZXJhZ2UIYm9ycm93SWQDAwkAZgIAZAUIbGV2ZXJhZ2UGCQBmAgUIbGV2ZXJhZ2UArAIJAAIBAh9MZXZlcmFnZSBjYW4ndCBiZSA8MTAwIGFuZCA+MzAwAwMJAQEhAQkBEUBleHRyTmF0aXZlKDEwNTEpAgUEdGhpcwkArAICBQRwb29sBQ5rUG9vbENhbkJvcnJvdwkAZgIFCGxldmVyYWdlAGQHCQACAQIdWW91IGNhbid0IGJvcnJvdyBpbiB0aGlzIHBvb2wEBXBUeXBlCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwkArAICBQVrUG9vbAUEcG9vbAISUG9vbCBpcyBub3QgaW5pdGVkBA0kdDAzMjgzMDMyOTIwCQELZ2V0UG9vbERhdGECCQEHQWRkcmVzcwEJANkEAQUEcG9vbAUFcFR5cGUEA0FJZAgFDSR0MDMyODMwMzI5MjACXzEEA0JJZAgFDSR0MDMyODMwMzI5MjACXzIEBGJhbEEIBQ0kdDAzMjgzMDMyOTIwAl8zBARiYWxCCAUNJHQwMzI4MzAzMjkyMAJfNAQHc2hhcmVJZAgFDSR0MDMyODMwMzI5MjACXzUEDSR0MDMyOTIzMzM1NjADCQAAAgkAkAMBCAUBaQhwYXltZW50cwACAwkBAiE9AgkBDGFzc2V0SWRUb1N0cgEICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAUDQUlkCQACAQIVV3JvbmcgcGF5bWVudCBhc3NldCBBAwkBAiE9AgkBDGFzc2V0SWRUb1N0cgEICQCRAwIIBQFpCHBheW1lbnRzAAEHYXNzZXRJZAUDQklkCQACAQIVV3JvbmcgcGF5bWVudCBhc3NldCBCCQCWCgQICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50BQNBSWQICQCRAwIIBQFpCHBheW1lbnRzAAEGYW1vdW50BQNCSWQDCQAAAgkAkAMBCAUBaQhwYXltZW50cwABAwkAAAIJAQxhc3NldElkVG9TdHIBCAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQFA0FJZAkAlgoECAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAUDQUlkAAAFA0JJZAMJAAACCQEMYXNzZXRJZFRvU3RyAQgJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkBQNCSWQJAJYKBAAABQNBSWQICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50BQNCSWQJAAIBAg1Xcm9uZyBwYXltZW50CQACAQIcT25lIG9yIHR3byBwYXltZW50cyBleHBlY3RlZAQEcG10QQgFDSR0MDMyOTIzMzM1NjACXzEECXBtdEFzc2V0QQgFDSR0MDMyOTIzMzM1NjACXzIEBHBtdEIIBQ0kdDAzMjkyMzMzNTYwAl8zBAlwbXRBc3NldEIIBQ0kdDAzMjkyMzMzNTYwAl80BAluZXdQb3NOdW0JARhnZXROZXdVc2VyUG9zaXRpb25OdW1iZXIBCQClCAEIBQFpBmNhbGxlcgMJAGYCBQhsZXZlcmFnZQBkBAxib3Jyb3dBbW91bnQJARBjYWxjQm9ycm93QW1vdW50BgUEcG10QQUEcG10QgUJcG10QXNzZXRBBQlwbXRBc3NldEIFCGxldmVyYWdlBQhib3Jyb3dJZAQHcmVxdWVzdAkAuQkCCQDMCAIJAKUIAQgFAWkGY2FsbGVyCQDMCAIFBHBvb2wJAMwIAgkApAMBBQRwbXRBCQDMCAIFCXBtdEFzc2V0QQkAzAgCCQCkAwEFBHBtdEIJAMwIAgUJcG10QXNzZXRCCQDMCAIJAKQDAQUEYmFsQQkAzAgCCQCkAwEFBGJhbEIJAMwIAgUHc2hhcmVJZAkAzAgCBQhib3Jyb3dJZAkAzAgCCQCkAwEFDGJvcnJvd0Ftb3VudAUDbmlsAgEsBAxuZXdSZXF1ZXN0SWQKAAFACQD8BwQFBHRoaXMCEGNyZWF0ZU5ld1JlcXVlc3QJAMwIAgUHcmVxdWVzdAUDbmlsBQNuaWwDCQABAgUBQAIDSW50BQFACQACAQkArAICCQADAQUBQAIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50AwkAAAIFDG5ld1JlcXVlc3RJZAUMbmV3UmVxdWVzdElkBARhcmdzCQDMCAIJAKwCAgkArAICCQClCAEIBQFpBmNhbGxlcgIBXwkApAMBBQluZXdQb3NOdW0JAMwIAgUHc2hhcmVJZAkAzAgCBQhib3Jyb3dJZAkAzAgCBQxib3Jyb3dBbW91bnQJAMwIAgkApQgBBQR0aGlzCQDMCAICEXJlcGxlbmlzaEZyb21MYW5kCQDMCAIJAKQDAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCBQxuZXdSZXF1ZXN0SWQCGENhbid0IGNyZWF0ZSBuZXcgcmVxdWVzdAUDbmlsBANpbnYJAP0HBAkBDmdldExlbmRTcnZBZGRyAAINZmxhc2hQb3NpdGlvbgUEYXJncwUDbmlsAwkAAAIFA2ludgUDaW52BQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4EDSR0MDM0NDg4MzQ2MDAJAQ9yZXBsZW5pc2hCeVR5cGUKBQVwVHlwZQUEcG9vbAULTk9fTE9BTl9GRUUFBHBtdEEFA0FJZAUEcG10QgUDQklkBQRiYWxBBQRiYWxCBQdzaGFyZUlkBAp1c2VyU3Rha2VkCAUNJHQwMzQ0ODgzNDYwMAJfMQQHYXhseUZlZQgFDSR0MDM0NDg4MzQ2MDACXzIJAM4IAgkBEHJlcGxlbmlzaEVudHJpZXMIBQRwb29sCQClCAEIBQFpBmNhbGxlcgUKdXNlclN0YWtlZAUHYXhseUZlZQUJbmV3UG9zTnVtBQdzaGFyZUlkBQVwVHlwZQcJAQ5nZXRDdXJzRW50cmllcwMFA0FJZAUDQklkBQdzaGFyZUlkAWkBCHdpdGhkcmF3AgRwb29sBXBvc0lkCQEOd2l0aGRyYXdUb1VzZXIECQClCAEIBQFpBmNhbGxlcgUEcG9vbAkApAMBBQVwb3NJZAcBaQEUY3JlYXRlVXBkYXRlU3RvcExvc3MEBXBvc0lkBnBvb2xJZAdhc3NldElkBXByaWNlBBB0b2tlbk9yYWNsZVByaWNlCAoAAUAJAPwHBAUPcHJpY2VPcmFjbGVBZGRyAglnZXRUV0FQNjAJAMwIAgUHYXNzZXRJZAkAzAgCBwUDbmlsBQNuaWwDCQABAgUBQAIKKEludCwgSW50KQUBQAkAAgEJAKwCAgkAAwEFAUACHyBjb3VsZG4ndCBiZSBjYXN0IHRvIChJbnQsIEludCkCXzEDCQEBIQEJAQlpc0RlZmluZWQBCQCaCAIFBHRoaXMJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQZwb29sSWQCAV8JAKUIAQgFAWkGY2FsbGVyAgFfCQCkAwEFBXBvc0lkBQ1rVXNlclBvc2l0aW9uCQACAQIaVGhlcmUgYXJlIG5vIHVzZXIgcG9zaXRpb24DCQBnAgAABQVwcmljZQkAAgECHFByaWNlIG11c3QgYmUgZ3JlYXRlciB0aGFuIDADCQBmAgUFcHJpY2UFEHRva2VuT3JhY2xlUHJpY2UJAAIBAitQcmljZSBtdXN0IGJlIGxlc3MgdGhhbiBjdXJyZW50IHRva2VuIHByaWNlCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKUIAQgFAWkGY2FsbGVyAgFfCQCkAwEFBXBvc0lkAgFfBQZwb29sSWQCAV8FB2Fzc2V0SWQFDWtVc2VyU3RvcExvc3MFBXByaWNlBQNuaWwBaQEOZGVsZXRlU3RvcExvc3MDBXBvc0lkBnBvb2xJZAdhc3NldElkAwkBASEBCQEJaXNEZWZpbmVkAQkAmggCBQR0aGlzCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKUIAQgFAWkGY2FsbGVyAgFfCQCkAwEFBXBvc0lkAgFfBQZwb29sSWQCAV8FB2Fzc2V0SWQFDWtVc2VyU3RvcExvc3MJAAIBAghObyBlbnRyeQkAzAgCCQELRGVsZXRlRW50cnkBCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKUIAQgFAWkGY2FsbGVyAgFfCQCkAwEFBXBvc0lkAgFfBQZwb29sSWQCAV8FB2Fzc2V0SWQFDWtVc2VyU3RvcExvc3MFA25pbAFpAQRpbml0CQxtb25leUJveEFkZHINc2ZGYXJtaW5nQWRkcghsZW5kQWRkcg9wcmljZU9yYWNsZUFkZHIQa2VlcGVyRXhDb250cmFjdA53eFN3YXBDb250cmFjdAtzd29wQXNzZXRJZAl3eEFzc2V0SWQLYWRtaW5QdWJLZXkDCQEJaXNEZWZpbmVkAQkAoggBBQlrTW9uZXlCb3gJAAIBAg5BbHJlYWR5IGluaXRlZAkAzAgCCQELU3RyaW5nRW50cnkCBQlrTW9uZXlCb3gFDG1vbmV5Qm94QWRkcgkAzAgCCQELU3RyaW5nRW50cnkCBQ5rU0ZGYXJtaW5nQWRkcgUNc2ZGYXJtaW5nQWRkcgkAzAgCCQELU3RyaW5nRW50cnkCBQxrTGVuZFNlcnZpY2UFCGxlbmRBZGRyCQDMCAIJAQtTdHJpbmdFbnRyeQIFDGtQcmljZU9yYWNsZQUPcHJpY2VPcmFjbGVBZGRyCQDMCAIJAQtTdHJpbmdFbnRyeQIFC2tFeENvbnRyYWN0BRBrZWVwZXJFeENvbnRyYWN0CQDMCAIJAQtTdHJpbmdFbnRyeQIFD2tXeFN3YXBDb250cmFjdAUOd3hTd2FwQ29udHJhY3QJAMwIAgkBC1N0cmluZ0VudHJ5AgUHa1N3b3BJZAULc3dvcEFzc2V0SWQJAMwIAgkBC1N0cmluZ0VudHJ5AgUFa1d4SWQFCXd4QXNzZXRJZAkAzAgCCQELU3RyaW5nRW50cnkCBQxrQWRtaW5DYWxsUEsFC2FkbWluUHViS2V5BQNuaWwBaQEQY3JlYXRlTmV3UmVxdWVzdAEGcGFyYW1zCQELdmFsdWVPckVsc2UCCQEKaXNTZWxmQ2FsbAEFAWkEDG5ld1JlcXVlc3RJZAkAZAIJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwUMa1JlcXVlc3RJdGVyAAAAAQkAlAoCCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkApAMBBQxuZXdSZXF1ZXN0SWQFCmtSZXF1ZXN0SWQFBnBhcmFtcwkAzAgCCQEMSW50ZWdlckVudHJ5AgUMa1JlcXVlc3RJdGVyBQxuZXdSZXF1ZXN0SWQFA25pbAUMbmV3UmVxdWVzdElkAWkBEXJlcGxlbmlzaEZyb21MYW5kAQlyZXF1ZXN0SWQJAQt2YWx1ZU9yRWxzZQIJAQppc0xhbmRDYWxsAQUBaQQNJHQwMzcwODAzNzE4NAkBDHBhcnNlUmVxdWVzdAEFCXJlcXVlc3RJZAQEdXNlcggFDSR0MDM3MDgwMzcxODQCXzEEBHBvb2wIBQ0kdDAzNzA4MDM3MTg0Al8yBARwbXRBCAUNJHQwMzcwODAzNzE4NAJfMwQDQUlkCAUNJHQwMzcwODAzNzE4NAJfNAQEcG10QggFDSR0MDM3MDgwMzcxODQCXzUEA0JJZAgFDSR0MDM3MDgwMzcxODQCXzYEBGJhbEEIBQ0kdDAzNzA4MDM3MTg0Al83BARiYWxCCAUNJHQwMzcwODAzNzE4NAJfOAQHc2hhcmVJZAgFDSR0MDM3MDgwMzcxODQCXzkEB2J3QXNzZXQIBQ0kdDAzNzA4MDM3MTg0A18xMAQIYndBbW91bnQIBQ0kdDAzNzA4MDM3MTg0A18xMQMJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAQkAAgECEldyb25nIHBheW1lbnQgc2l6ZQMDCQECIT0CCQEMYXNzZXRJZFRvU3RyAQgJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkBQdid0Fzc2V0BgkBAiE9AggJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQFCGJ3QW1vdW50CQACAQINV3JvbmcgcGF5bWVudAQNJHQwMzczNzQzNzQ5OAMJAAACBQNBSWQFB2J3QXNzZXQJAJQKAgkAZAIFBHBtdEEICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50BQRwbXRCCQCUCgIFBHBtdEEJAGQCBQRwbXRCCAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAQHcG10QWxsQQgFDSR0MDM3Mzc0Mzc0OTgCXzEEB3BtdEFsbEIIBQ0kdDAzNzM3NDM3NDk4Al8yBAVwVHlwZQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMJAKwCAgUFa1Bvb2wFBHBvb2wCDFVua25vd24gcG9vbAQNJHQwMzc1ODAzNzY5NQkBD3JlcGxlbmlzaEJ5VHlwZQoFBXBUeXBlBQRwb29sBQhMT0FOX0ZFRQUHcG10QWxsQQUDQUlkBQdwbXRBbGxCBQNCSWQFBGJhbEEFBGJhbEIFB3NoYXJlSWQECnVzZXJTdGFrZWQIBQ0kdDAzNzU4MDM3Njk1Al8xBAdheGx5RmVlCAUNJHQwMzc1ODAzNzY5NQJfMgQGcG9zTnVtCQEYZ2V0TmV3VXNlclBvc2l0aW9uTnVtYmVyAQUEdXNlcgQNYm9ycm93RW50cmllcwkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBHBvb2wCAV8FBHVzZXICAV8JAKQDAQUGcG9zTnVtBRFrVXNlckJvcnJvd0Ftb3VudAUIYndBbW91bnQJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBHBvb2wCAV8FBHVzZXICAV8JAKQDAQUGcG9zTnVtBRJrVXNlckJvcnJvd0Fzc2V0SWQFB2J3QXNzZXQFA25pbAQHZW50cmllcwkBEHJlcGxlbmlzaEVudHJpZXMIBQRwb29sBQR1c2VyBQp1c2VyU3Rha2VkBQdheGx5RmVlBQZwb3NOdW0FB3NoYXJlSWQFBXBUeXBlBgkAlAoCCQDNCAIJAM4IAgkAzggCBQdlbnRyaWVzCQEOZ2V0Q3Vyc0VudHJpZXMDBQNBSWQFA0JJZAUHc2hhcmVJZAUNYm9ycm93RW50cmllcwkBC0RlbGV0ZUVudHJ5AQkArAICBQlyZXF1ZXN0SWQFCmtSZXF1ZXN0SWQFCnVzZXJTdGFrZWQBaQEJbGlxdWlkYXRlAwR1c2VyBXBvc0lkD2xpcXVpZGF0ZUFtb3VudAkBC3ZhbHVlT3JFbHNlAgkBCmlzTGFuZENhbGwBBQFpBARwb29sCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwkArAICCQCsAgIJAKwCAgUEdXNlcgIBXwUFcG9zSWQFEWtVc2VyUG9zaXRpb25Qb29sAgtubyBwb3NpdGlvbgQFcFR5cGUJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzCQCsAgIFBWtQb29sBQRwb29sAhJQb29sIGlzIG5vdCBpbml0ZWQEDSR0MDM4NDc0Mzg1NjQJAQtnZXRQb29sRGF0YQIJAQdBZGRyZXNzAQkA2QQBBQRwb29sBQVwVHlwZQQDQUlkCAUNJHQwMzg0NzQzODU2NAJfMQQDQklkCAUNJHQwMzg0NzQzODU2NAJfMgQEYmFsQQgFDSR0MDM4NDc0Mzg1NjQCXzMEBGJhbEIIBQ0kdDAzODQ3NDM4NTY0Al80BAdzaGFyZUlkCAUNJHQwMzg0NzQzODU2NAJfNQQGYW1vdW50CQEJdW5zdGFrZUxQBAUEcG9vbAUFcFR5cGUFB3NoYXJlSWQFD2xpcXVpZGF0ZUFtb3VudAQMYm9ycm93QW1vdW50CQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUEcG9vbAIBXwUEdXNlcgIBXwUFcG9zSWQFEWtVc2VyQm9ycm93QW1vdW50BAtib3Jyb3dBc3NldAkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBHBvb2wCAV8FBHVzZXICAV8FBXBvc0lkBRJrVXNlckJvcnJvd0Fzc2V0SWQED3VzZXJDYW5XaXRoZHJhdwkBGHVzZXJDYW5XaXRoZHJhd1NoYXJlQ2FsYwQFBHVzZXIFBHBvb2wFBXBvc0lkCQBmAgUMYm9ycm93QW1vdW50AAADCQAAAgUMYm9ycm93QW1vdW50AAAJAAIBAitZb3UgY2FuJ3QgbGlxdWlkYXRlIHBvc2l0aW9uIHdpdGhvdXQgYm9ycm93CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUEcG9vbAIBXwUEdXNlcgIBXwUFcG9zSWQFFWtVc2VyUG9zaXRpb25JbnRlcmVzdAkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwkArAICBQRwb29sBRFrUG9vbEludGVyZXN0TG9hbgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQRwb29sBQ5rUG9vbFRvdGFsTG9hbgkAZQIJARlnZXRQb29sVG90YWxTaGFyZVdpdGhMb2FuAQUEcG9vbAUPbGlxdWlkYXRlQW1vdW50CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFBHBvb2wFCmtQb29sVG90YWwJAGUCCQERZ2V0UG9vbFRvdGFsU2hhcmUBBQRwb29sBQ9saXF1aWRhdGVBbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfBQVwb3NJZAUNa1VzZXJQb3NpdGlvbgkAZQIFD3VzZXJDYW5XaXRoZHJhdwUPbGlxdWlkYXRlQW1vdW50CQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgUGYW1vdW50CQDZBAEFB3NoYXJlSWQFA25pbAFpAQhzdG9wTG9zcwQEdXNlcgVwb3NJZARwb29sB2Fzc2V0SWQJAQt2YWx1ZU9yRWxzZQIJAQtpc0FkbWluQ2FsbAEFAWkEEHRva2VuT3JhY2xlUHJpY2UICgABQAkA/AcEBQ9wcmljZU9yYWNsZUFkZHICCWdldFRXQVA2MAkAzAgCBQdhc3NldElkCQDMCAIHBQNuaWwFA25pbAMJAAECBQFAAgooSW50LCBJbnQpBQFACQACAQkArAICCQADAQUBQAIfIGNvdWxkbid0IGJlIGNhc3QgdG8gKEludCwgSW50KQJfMQMJAQEhAQkBCWlzRGVmaW5lZAEJAJoIAgUEdGhpcwkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQR1c2VyAgFfCQCkAwEFBXBvc0lkAgFfBQRwb29sAgFfBQdhc3NldElkBQ1rVXNlclN0b3BMb3NzCQACAQIITm8gZW50cnkJAM0IAgkBDndpdGhkcmF3VG9Vc2VyBAkApQgBCAUBaQZjYWxsZXIFBHBvb2wJAKQDAQUFcG9zSWQGCQELRGVsZXRlRW50cnkBCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBHVzZXICAV8JAKQDAQUFcG9zSWQCAV8FBHBvb2wCAV8FB2Fzc2V0SWQFDWtVc2VyU3RvcExvc3MBaQESY2FwaXRhbGl6ZUV4S2VlcGVyDARwb29sBHR5cGUJdG9rZW5Ub0lkEGFtb3VudFRvRXhjaGFuZ2UFY2xhaW0JYW1vdW50c0luCWFkZHJlc3Nlcw9hc3NldHNUb1JlY2VpdmULZXN0UmVjZWl2ZWQRc2xpcHBhZ2VUb2xlcmFuY2ULbWluUmVjZWl2ZWQHb3B0aW9ucwkBC3ZhbHVlT3JFbHNlAgkBC2lzQWRtaW5DYWxsAQUBaQQNJHQwNDAzNTA0MDU0NAMFBWNsYWltCQELY2xhaW1GYXJtZWQCBQR0eXBlBQRwb29sBAxjbGFpbWVkQXNzZXQDCQAAAgUEdHlwZQUHU0ZfUE9PTAUGU1dPUElEBQRXWElECQCUCgIFEGFtb3VudFRvRXhjaGFuZ2UFDGNsYWltZWRBc3NldAQNY2xhaW1lZEFtb3VudAgFDSR0MDQwMzUwNDA1NDQCXzEEDGNsYWltZWRBc3NldAgFDSR0MDQwMzUwNDA1NDQCXzIED2V4Y2hhbmdlZEFtb3VudAkBDmV4Y2hhbmdlS2VlcGVyCgUJdG9rZW5Ub0lkBRBhbW91bnRUb0V4Y2hhbmdlBQxjbGFpbWVkQXNzZXQFCWFtb3VudHNJbgUJYWRkcmVzc2VzBQ9hc3NldHNUb1JlY2VpdmUFC2VzdFJlY2VpdmVkBRFzbGlwcGFnZVRvbGVyYW5jZQULbWluUmVjZWl2ZWQFB29wdGlvbnMEBmNoYW5nZQkAZQIFDWNsYWltZWRBbW91bnQFEGFtb3VudFRvRXhjaGFuZ2UEC2NoYW5nZUVudHJ5AwkAZgIFBmNoYW5nZQAACQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFBHBvb2wFDmtQb29sQ2FwQ2hhbmdlCQBkAgUGY2hhbmdlCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAKwCAgUEcG9vbAUOa1Bvb2xDYXBDaGFuZ2UAAAUDbmlsBQNuaWwJAM4IAgkBCmNhcGl0YWxpemUEBQRwb29sBQR0eXBlBQl0b2tlblRvSWQFD2V4Y2hhbmdlZEFtb3VudAULY2hhbmdlRW50cnkBaQESY2FwaXRhbGl6ZUV4UHV6emxlCARwb29sBHR5cGUJdG9rZW5Ub0lkEGFtb3VudFRvRXhjaGFuZ2UFY2xhaW0Jcm91dGVzU3RyDG1pblRvUmVjZWl2ZQdvcHRpb25zCQELdmFsdWVPckVsc2UCCQELaXNBZG1pbkNhbGwBBQFpBA0kdDA0MTIyOTQxNDIzAwUFY2xhaW0JAQtjbGFpbUZhcm1lZAIFBHR5cGUFBHBvb2wEDGNsYWltZWRBc3NldAMJAAACBQR0eXBlBQdTRl9QT09MBQZTV09QSUQFBFdYSUQJAJQKAgUQYW1vdW50VG9FeGNoYW5nZQUMY2xhaW1lZEFzc2V0BA1jbGFpbWVkQW1vdW50CAUNJHQwNDEyMjk0MTQyMwJfMQQMY2xhaW1lZEFzc2V0CAUNJHQwNDEyMjk0MTQyMwJfMgQPZXhjaGFuZ2VkQW1vdW50CQEOZXhjaGFuZ2VQdXp6bGUGBQl0b2tlblRvSWQFEGFtb3VudFRvRXhjaGFuZ2UFDGNsYWltZWRBc3NldAUJcm91dGVzU3RyBQxtaW5Ub1JlY2VpdmUFB29wdGlvbnMEBmNoYW5nZQkAZQIFDWNsYWltZWRBbW91bnQFEGFtb3VudFRvRXhjaGFuZ2UEC2NoYW5nZUVudHJ5AwkAZgIFBmNoYW5nZQAACQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFBHBvb2wFDmtQb29sQ2FwQ2hhbmdlCQBkAgUGY2hhbmdlCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAKwCAgUEcG9vbAUOa1Bvb2xDYXBDaGFuZ2UAAAUDbmlsBQNuaWwJAM4IAgkBCmNhcGl0YWxpemUEBQRwb29sBQR0eXBlBQl0b2tlblRvSWQFD2V4Y2hhbmdlZEFtb3VudAULY2hhbmdlRW50cnkBaQESY2FwaXRhbGl6ZUV4U3dvcEZpDARwb29sBHR5cGUJdG9rZW5Ub0lkEGFtb3VudFRvRXhjaGFuZ2UFY2xhaW0KZXhjaGFuZ2Vycw5leGNoYW5nZXJzVHlwZQVhcmdzMQVhcmdzMhFyb3V0aW5nQXNzZXRzS2V5cxJtaW5BbW91bnRUb1JlY2VpdmUHb3B0aW9ucwkBC3ZhbHVlT3JFbHNlAgkBC2lzQWRtaW5DYWxsAQUBaQQNJHQwNDIxNzQ0MjM2OAMFBWNsYWltCQELY2xhaW1GYXJtZWQCBQR0eXBlBQRwb29sBAxjbGFpbWVkQXNzZXQDCQAAAgUEdHlwZQUHU0ZfUE9PTAUGU1dPUElEBQRXWElECQCUCgIFEGFtb3VudFRvRXhjaGFuZ2UFDGNsYWltZWRBc3NldAQNY2xhaW1lZEFtb3VudAgFDSR0MDQyMTc0NDIzNjgCXzEEDGNsYWltZWRBc3NldAgFDSR0MDQyMTc0NDIzNjgCXzIED2V4Y2hhbmdlZEFtb3VudAkBDmV4Y2hhbmdlU3dvcEZpCgUJdG9rZW5Ub0lkBRBhbW91bnRUb0V4Y2hhbmdlBQxjbGFpbWVkQXNzZXQFCmV4Y2hhbmdlcnMFDmV4Y2hhbmdlcnNUeXBlBQVhcmdzMQUFYXJnczIFEXJvdXRpbmdBc3NldHNLZXlzBRJtaW5BbW91bnRUb1JlY2VpdmUFB29wdGlvbnMEBmNoYW5nZQkAZQIFDWNsYWltZWRBbW91bnQFEGFtb3VudFRvRXhjaGFuZ2UEC2NoYW5nZUVudHJ5AwkAZgIFBmNoYW5nZQAACQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFBHBvb2wFDmtQb29sQ2FwQ2hhbmdlCQBkAgUGY2hhbmdlCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAKwCAgUEcG9vbAUOa1Bvb2xDYXBDaGFuZ2UAAAUDbmlsBQNuaWwJAM4IAgkBCmNhcGl0YWxpemUEBQRwb29sBQR0eXBlBQl0b2tlblRvSWQFD2V4Y2hhbmdlZEFtb3VudAULY2hhbmdlRW50cnkBaQELaW5pdE5ld1Bvb2wJBHR5cGUIcG9vbEFkZHILaW5GZWVOb0xvYW4JaW5GZWVMb2FuDGNhcEZlZU5vTG9hbg5jYXBGZWVXaXRoTG9hbhFzdG9wbG9zc0ZlZU5vTG9hbhNzdG9wbG9zc0ZlZVdpdGhMb2FuCWNhbkJvcnJvdwkBC3ZhbHVlT3JFbHNlAgkBC2lzQWRtaW5DYWxsAQUBaQMDCQECIT0CBQR0eXBlBQdTRl9QT09MCQECIT0CBQR0eXBlBQdXWF9QT09MBwkAAgECCldyb25nIHR5cGUEDSR0MDQzMTA5NDMyMDMJAQtnZXRQb29sRGF0YQIJAQdBZGRyZXNzAQkA2QQBBQhwb29sQWRkcgUEdHlwZQQDYUlkCAUNJHQwNDMxMDk0MzIwMwJfMQQDYklkCAUNJHQwNDMxMDk0MzIwMwJfMgQEYUJhbAgFDSR0MDQzMTA5NDMyMDMCXzMEBGJCYWwIBQ0kdDA0MzEwOTQzMjAzAl80BAdzaGFyZUlkCAUNJHQwNDMxMDk0MzIwMwJfNQkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQhwb29sQWRkcgUVa0F4bHlJbkZlZVdpdGhvdXRMb2FuBQtpbkZlZU5vTG9hbgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQhwb29sQWRkcgUSa0F4bHlJbkZlZVdpdGhMb2FuBQlpbkZlZUxvYW4JAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUIcG9vbEFkZHIFEWtBeGx5Tm9Mb2FuQ2FwRmVlBQxjYXBGZWVOb0xvYW4JAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUIcG9vbEFkZHIFE2tBeGx5V2l0aExvYW5DYXBGZWUFDmNhcEZlZVdpdGhMb2FuCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFCHBvb2xBZGRyBRZrQXhseVN0b3BMb3NzTm9Mb2FuRmVlBRFzdG9wbG9zc0ZlZU5vTG9hbgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQhwb29sQWRkcgUUa0F4bHlTdG9wTG9zc0xvYW5GZWUFE3N0b3Bsb3NzRmVlV2l0aExvYW4JAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUIcG9vbEFkZHIFEWtQb29sSW50ZXJlc3RMb2FuAAAJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUIcG9vbEFkZHIFE2tQb29sSW50ZXJlc3ROb0xvYW4AAAkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIFBWtQb29sBQhwb29sQWRkcgUEdHlwZQkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIFB3NoYXJlSWQFCmtTaGFyZVBvb2wFCHBvb2xBZGRyCQDMCAIJAQxCb29sZWFuRW50cnkCCQCsAgIFCHBvb2xBZGRyBQ5rUG9vbENhbkJvcnJvdwUJY2FuQm9ycm93BQNuaWwBAnR4AQZ2ZXJpZnkACQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAACAUCdHgPc2VuZGVyUHVibGljS2V5zTnXUg==", "height": 2642390, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: DHfqMMfuipcaVH1h63yUiaGeYRdAvvHbpDjPEV8xTtF3 Next: DSmQDEwe6cvm6JWEPfvNjcZ96G24VNdmTb97JJXL2GCm Diff:
Old | New | Differences | |
---|---|---|---|
61 | 61 | ||
62 | 62 | let D = "_pool_interest_no_loan" | |
63 | 63 | ||
64 | - | let E = "_ | |
64 | + | let E = "_pool_can_borrow" | |
65 | 65 | ||
66 | - | let F = "_axly_fee_ | |
66 | + | let F = "_axly_fee_without_loan" | |
67 | 67 | ||
68 | - | let G = "_axly_fee_ | |
68 | + | let G = "_axly_fee_with_loan" | |
69 | 69 | ||
70 | - | let H = "_axly_fee_cap_ | |
70 | + | let H = "_axly_fee_cap_with_loan" | |
71 | 71 | ||
72 | - | let I = "_axly_fee_ | |
72 | + | let I = "_axly_fee_cap_no_loan" | |
73 | 73 | ||
74 | - | let J = "_axly_fee_stoploss_ | |
74 | + | let J = "_axly_fee_stoploss_with_loan" | |
75 | 75 | ||
76 | - | let K = "_ | |
76 | + | let K = "_axly_fee_stoploss_no_loan" | |
77 | 77 | ||
78 | - | let L = " | |
78 | + | let L = "_request_id" | |
79 | 79 | ||
80 | - | let M = " | |
80 | + | let M = "requests_iter" | |
81 | 81 | ||
82 | - | let N = " | |
82 | + | let N = "pool_" | |
83 | 83 | ||
84 | - | let O = "_pool_ | |
84 | + | let O = "_pool_share_id" | |
85 | 85 | ||
86 | - | let P = " | |
86 | + | let P = "_pool_cap_change" | |
87 | 87 | ||
88 | - | let Q = "_ | |
88 | + | let Q = "last_price" | |
89 | 89 | ||
90 | - | let R = " | |
90 | + | let R = "_stop_loss" | |
91 | 91 | ||
92 | - | let S = " | |
92 | + | let S = "axly_money_box" | |
93 | 93 | ||
94 | - | let T = " | |
94 | + | let T = "swopfi_farming_addr" | |
95 | 95 | ||
96 | - | let U = " | |
96 | + | let U = "lend_service_addr" | |
97 | 97 | ||
98 | - | let V = " | |
98 | + | let V = "admin_call_pub_key" | |
99 | 99 | ||
100 | - | let W = " | |
100 | + | let W = "price_oracle" | |
101 | 101 | ||
102 | - | let X = " | |
102 | + | let X = "exchange_contract" | |
103 | 103 | ||
104 | - | let Y = " | |
104 | + | let Y = "wx_swap_contract" | |
105 | 105 | ||
106 | - | let Z = " | |
106 | + | let Z = "swop_id" | |
107 | 107 | ||
108 | - | let aa = | |
108 | + | let aa = "wx_id" | |
109 | 109 | ||
110 | - | let ab = Address(fromBase58String(valueOrErrorMessage(getString(this, | |
110 | + | let ab = Address(fromBase58String(valueOrErrorMessage(getString(this, S), "No axly moneyBox address"))) | |
111 | 111 | ||
112 | - | let ac = Address(fromBase58String(valueOrErrorMessage(getString(this, | |
112 | + | let ac = Address(fromBase58String(valueOrErrorMessage(getString(this, X), "No exchange contract address"))) | |
113 | 113 | ||
114 | - | let ad = Address(fromBase58String(valueOrErrorMessage(getString(this, | |
114 | + | let ad = Address(fromBase58String(valueOrErrorMessage(getString(this, W), "No price oracle address"))) | |
115 | 115 | ||
116 | - | let ae = fromBase58String(valueOrErrorMessage(getString(this, Y), "No | |
116 | + | let ae = Address(fromBase58String(valueOrErrorMessage(getString(this, Y), "No wx swap address"))) | |
117 | 117 | ||
118 | - | let af = fromBase58String(valueOrErrorMessage(getString(this, Z), "No | |
118 | + | let af = fromBase58String(valueOrErrorMessage(getString(this, Z), "No swop id")) | |
119 | 119 | ||
120 | - | func ag () = Address(fromBase58String(valueOrErrorMessage(getString(this, T), "Can't get lend service addr"))) | |
120 | + | let ag = fromBase58String(valueOrErrorMessage(getString(this, aa), "No wx id")) | |
121 | + | ||
122 | + | func ah () = Address(fromBase58String(valueOrErrorMessage(getString(this, U), "Can't get lend service addr"))) | |
121 | 123 | ||
122 | 124 | ||
123 | - | func | |
125 | + | func ai () = addressFromPublicKey(fromBase58String(valueOrErrorMessage(getString(this, V), "Can't get admin addr"))) | |
124 | 126 | ||
125 | 127 | ||
126 | - | func | |
128 | + | func aj (ak) = if ((ak.caller == ai())) | |
127 | 129 | then unit | |
128 | 130 | else throw("Only admin can call this function") | |
129 | 131 | ||
130 | 132 | ||
131 | - | func | |
133 | + | func al (ak) = if ((ak.caller == this)) | |
132 | 134 | then unit | |
133 | 135 | else throw("Only contract itself can call this function") | |
134 | 136 | ||
135 | 137 | ||
136 | - | func | |
138 | + | func am (ak) = if ((ak.caller == ah())) | |
137 | 139 | then unit | |
138 | 140 | else throw("Only land contract can call this function") | |
139 | 141 | ||
140 | 142 | ||
141 | - | func | |
142 | - | let | |
143 | - | if ($isInstanceOf( | |
143 | + | func an (ao) = { | |
144 | + | let ap = ao | |
145 | + | if ($isInstanceOf(ap, "ByteVector")) | |
144 | 146 | then { | |
145 | - | let | |
146 | - | assetBalance(this, | |
147 | + | let aq = ap | |
148 | + | assetBalance(this, aq) | |
147 | 149 | } | |
148 | - | else if ($isInstanceOf( | |
150 | + | else if ($isInstanceOf(ap, "Unit")) | |
149 | 151 | then { | |
150 | - | let | |
152 | + | let ar = ap | |
151 | 153 | wavesBalance(this).available | |
152 | 154 | } | |
153 | 155 | else throw("Match error") | |
154 | 156 | } | |
155 | 157 | ||
156 | 158 | ||
157 | - | func | |
159 | + | func as (at) = $Tuple5(valueOrErrorMessage(getString(at, p), "Can't get pool A asset id"), valueOrErrorMessage(getString(at, q), "Can't get pool B asset id"), valueOrErrorMessage(getInteger(at, n), "Can't get pool A asset balance"), valueOrErrorMessage(getInteger(at, o), "Can't get pool B asset balance"), valueOrErrorMessage(getString(at, r), "Can't get share asset id")) | |
158 | 160 | ||
159 | 161 | ||
160 | - | func | |
161 | - | let | |
162 | - | let | |
163 | - | if ($isInstanceOf( | |
164 | - | then | |
165 | - | else throw(($getType( | |
162 | + | func au (at) = { | |
163 | + | let av = { | |
164 | + | let aw = invoke(at, "getPoolConfigWrapperREADONLY", nil, nil) | |
165 | + | if ($isInstanceOf(aw, "List[Any]")) | |
166 | + | then aw | |
167 | + | else throw(($getType(aw) + " couldn't be cast to List[Any]")) | |
166 | 168 | } | |
167 | - | if (( | |
169 | + | if ((av == av)) | |
168 | 170 | then { | |
169 | - | let | |
170 | - | let | |
171 | - | if ($isInstanceOf( | |
172 | - | then | |
171 | + | let ax = valueOrErrorMessage({ | |
172 | + | let aw = av[4] | |
173 | + | if ($isInstanceOf(aw, "String")) | |
174 | + | then aw | |
173 | 175 | else unit | |
174 | 176 | }, "Can't get pool A asset id") | |
175 | - | let | |
176 | - | let | |
177 | - | if ($isInstanceOf( | |
178 | - | then | |
177 | + | let ay = valueOrErrorMessage({ | |
178 | + | let aw = av[5] | |
179 | + | if ($isInstanceOf(aw, "String")) | |
180 | + | then aw | |
179 | 181 | else unit | |
180 | 182 | }, "Can't get pool B asset id") | |
181 | - | let | |
182 | - | let | |
183 | - | if ($isInstanceOf( | |
184 | - | then | |
183 | + | let az = valueOrErrorMessage({ | |
184 | + | let aw = av[3] | |
185 | + | if ($isInstanceOf(aw, "String")) | |
186 | + | then aw | |
185 | 187 | else unit | |
186 | 188 | }, "Can't get pool LP asset id") | |
187 | - | let | |
188 | - | let | |
189 | - | if ($isInstanceOf( | |
190 | - | then | |
191 | - | else throw(($getType( | |
189 | + | let aA = { | |
190 | + | let aw = invoke(at, "getAccBalanceWrapperREADONLY", [ax], nil) | |
191 | + | if ($isInstanceOf(aw, "Int")) | |
192 | + | then aw | |
193 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
192 | 194 | } | |
193 | - | if (( | |
195 | + | if ((aA == aA)) | |
194 | 196 | then { | |
195 | - | let | |
196 | - | let | |
197 | - | if ($isInstanceOf( | |
198 | - | then | |
199 | - | else throw(($getType( | |
197 | + | let aB = { | |
198 | + | let aw = invoke(at, "getAccBalanceWrapperREADONLY", [ay], nil) | |
199 | + | if ($isInstanceOf(aw, "Int")) | |
200 | + | then aw | |
201 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
200 | 202 | } | |
201 | - | if (( | |
202 | - | then $Tuple5( | |
203 | + | if ((aB == aB)) | |
204 | + | then $Tuple5(ax, ay, aA, aB, az) | |
203 | 205 | else throw("Strict value is not equal to itself.") | |
204 | 206 | } | |
205 | 207 | else throw("Strict value is not equal to itself.") | |
208 | 210 | } | |
209 | 211 | ||
210 | 212 | ||
211 | - | func | |
212 | - | then | |
213 | - | else if (( | |
214 | - | then at | |
213 | + | func aC (at,aD) = if ((aD == a)) | |
214 | + | then as(at) | |
215 | + | else if ((aD == b)) | |
216 | + | then au(at) | |
215 | 217 | else throw("Wrong pool type") | |
216 | 218 | ||
217 | 219 | ||
218 | - | func | |
219 | - | then valueOrErrorMessage(getInteger( | |
220 | - | else if (( | |
221 | - | then valueOrErrorMessage(assetInfo(fromBase58String( | |
220 | + | func aE (at,aD,az) = if ((aD == a)) | |
221 | + | then valueOrErrorMessage(getInteger(at, s), "Can't get share asset supply") | |
222 | + | else if ((aD == b)) | |
223 | + | then valueOrErrorMessage(assetInfo(fromBase58String(az)), "Wrong ShareId").quantity | |
222 | 224 | else throw("Wrong pool type") | |
223 | 225 | ||
224 | 226 | ||
225 | - | func | |
227 | + | func aF (aG) = valueOrElse(getInteger(this, (aG + A)), 0) | |
226 | 228 | ||
227 | 229 | ||
228 | - | func | |
230 | + | func aH (aG) = valueOrElse(getInteger(this, (aG + B)), 0) | |
229 | 231 | ||
230 | 232 | ||
231 | - | func | |
233 | + | func aI (aJ) = (valueOrElse(getInteger(this, (aJ + y)), 0) + 1) | |
232 | 234 | ||
233 | 235 | ||
234 | - | func | |
235 | - | then getIntegerValue(this, ( | |
236 | - | else if (( | |
237 | - | then getIntegerValue(this, ( | |
238 | - | else if (( | |
239 | - | then getIntegerValue(this, ( | |
240 | - | else if (( | |
241 | - | then getIntegerValue(this, ( | |
242 | - | else if (( | |
236 | + | func aK (aG,aL) = if ((aL == d)) | |
237 | + | then getIntegerValue(this, (aG + I)) | |
238 | + | else if ((aL == c)) | |
239 | + | then getIntegerValue(this, (aG + H)) | |
240 | + | else if ((aL == g)) | |
241 | + | then getIntegerValue(this, (aG + G)) | |
242 | + | else if ((aL == h)) | |
243 | + | then getIntegerValue(this, (aG + F)) | |
244 | + | else if ((aL == i)) | |
243 | 245 | then 0 | |
244 | 246 | else throw("Wrong fee type") | |
245 | 247 | ||
246 | 248 | ||
247 | - | func | |
249 | + | func aM () = Address(fromBase58String(valueOrErrorMessage(getString(this, T), "Can't get swopfi farming addr"))) | |
248 | 250 | ||
249 | 251 | ||
250 | - | func | |
251 | - | let | |
252 | - | let | |
253 | - | Address(fromBase58String( | |
252 | + | func aN (at) = { | |
253 | + | let aO = Address(fromBase58String(valueOrErrorMessage(getString(at, "%s__factoryContract"), "Can't get WX factory contract addr"))) | |
254 | + | let aP = split(valueOrErrorMessage(getString(aO, "%s__factoryConfig"), "Can't get WX factory cfg"), "__") | |
255 | + | Address(fromBase58String(aP[1])) | |
254 | 256 | } | |
255 | 257 | ||
256 | 258 | ||
257 | - | func | |
258 | - | let | |
259 | - | if ($isInstanceOf( | |
259 | + | func aQ (ao) = { | |
260 | + | let ap = ao | |
261 | + | if ($isInstanceOf(ap, "ByteVector")) | |
260 | 262 | then { | |
261 | - | let | |
262 | - | toBase58String( | |
263 | + | let aq = ap | |
264 | + | toBase58String(aq) | |
263 | 265 | } | |
264 | - | else if ($isInstanceOf( | |
266 | + | else if ($isInstanceOf(ap, "Unit")) | |
265 | 267 | then { | |
266 | - | let | |
268 | + | let ar = ap | |
267 | 269 | "WAVES" | |
268 | 270 | } | |
269 | 271 | else throw("Not Asset id") | |
270 | 272 | } | |
271 | 273 | ||
272 | 274 | ||
273 | - | func | |
275 | + | func aR (ao) = if ((ao == "WAVES")) | |
274 | 276 | then unit | |
275 | - | else fromBase58String( | |
277 | + | else fromBase58String(ao) | |
276 | 278 | ||
277 | 279 | ||
278 | - | func | |
280 | + | func aS (ao) = if ((ao == "WAVES")) | |
279 | 281 | then 8 | |
280 | 282 | else { | |
281 | - | let | |
282 | - | if ($isInstanceOf( | |
283 | + | let ap = assetInfo(fromBase58String(ao)) | |
284 | + | if ($isInstanceOf(ap, "Asset")) | |
283 | 285 | then { | |
284 | - | let | |
285 | - | | |
286 | + | let aT = ap | |
287 | + | aT.decimals | |
286 | 288 | } | |
287 | 289 | else throw("Can't find asset") | |
288 | 290 | } | |
289 | 291 | ||
290 | 292 | ||
291 | - | func | |
293 | + | func aU (ao) = pow(10, 0, aS(ao), 0, 0, DOWN) | |
292 | 294 | ||
293 | 295 | ||
294 | - | func | |
295 | - | func | |
296 | - | let | |
297 | - | if ($isInstanceOf( | |
298 | - | then | |
299 | - | else throw(($getType( | |
300 | - | ( | |
296 | + | func aV (aW) = { | |
297 | + | func aX (aY,ao) = { | |
298 | + | let aZ = ( let aw = invoke(ad, "getTWAP60", [ao, false], nil) | |
299 | + | if ($isInstanceOf(aw, "(Int, Int)")) | |
300 | + | then aw | |
301 | + | else throw(($getType(aw) + " couldn't be cast to (Int, Int)")))._2 | |
302 | + | (aY :+ aZ) | |
301 | 303 | } | |
302 | 304 | ||
303 | - | let | |
304 | - | let | |
305 | - | let | |
306 | - | func | |
307 | - | then | |
308 | - | else | |
305 | + | let ba = aW | |
306 | + | let bb = size(ba) | |
307 | + | let bc = nil | |
308 | + | func bd (be,bf) = if ((bf >= bb)) | |
309 | + | then be | |
310 | + | else aX(be, ba[bf]) | |
309 | 311 | ||
310 | - | func | |
311 | - | then | |
312 | + | func bg (be,bf) = if ((bf >= bb)) | |
313 | + | then be | |
312 | 314 | else throw("List size exceeds 50") | |
313 | 315 | ||
314 | - | | |
316 | + | bg(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bc, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20), 21), 22), 23), 24), 25), 26), 27), 28), 29), 30), 31), 32), 33), 34), 35), 36), 37), 38), 39), 40), 41), 42), 43), 44), 45), 46), 47), 48), 49), 50) | |
315 | 317 | } | |
316 | 318 | ||
317 | 319 | ||
318 | - | func | |
319 | - | let | |
320 | - | let | |
321 | - | let | |
322 | - | let | |
323 | - | let | |
324 | - | let | |
325 | - | let | |
326 | - | let | |
327 | - | let | |
328 | - | if ($isInstanceOf( | |
329 | - | then | |
330 | - | else throw(($getType( | |
331 | - | let | |
332 | - | if ($isInstanceOf( | |
333 | - | then | |
334 | - | else throw(($getType( | |
335 | - | let | |
336 | - | let | |
337 | - | let | |
338 | - | let | |
339 | - | let | |
340 | - | fraction(br, | |
320 | + | func bh (az) = { | |
321 | + | let aG = valueOrErrorMessage(getString(this, (az + O)), "Can't find pool addr by share id") | |
322 | + | let at = Address(fromBase58String(aG)) | |
323 | + | let bi = valueOrErrorMessage(getString(this, (N + aG)), "Pool is not inited") | |
324 | + | let bj = aC(at, bi) | |
325 | + | let ax = bj._1 | |
326 | + | let ay = bj._2 | |
327 | + | let bk = bj._3 | |
328 | + | let bl = bj._4 | |
329 | + | let bm = ( let aw = invoke(ad, "getTWAP60", [ax, false], nil) | |
330 | + | if ($isInstanceOf(aw, "(Int, Int)")) | |
331 | + | then aw | |
332 | + | else throw(($getType(aw) + " couldn't be cast to (Int, Int)")))._2 | |
333 | + | let bn = ( let aw = invoke(ad, "getTWAP60", [ay, false], nil) | |
334 | + | if ($isInstanceOf(aw, "(Int, Int)")) | |
335 | + | then aw | |
336 | + | else throw(($getType(aw) + " couldn't be cast to (Int, Int)")))._2 | |
337 | + | let bo = aE(at, bi, az) | |
338 | + | let bp = pow(10, 0, aS(ax), 0, 0, DOWN) | |
339 | + | let bq = pow(10, 0, aS(ay), 0, 0, DOWN) | |
340 | + | let br = pow(10, 0, aS(az), 0, 0, DOWN) | |
341 | + | let bs = (fraction(bk, bm, bp) + fraction(bl, bn, bq)) | |
342 | + | fraction(bs, br, bo) | |
341 | 343 | } | |
342 | 344 | ||
343 | 345 | ||
344 | - | func | |
345 | - | func | |
346 | + | func bt (bu) = { | |
347 | + | func aX (aY,az) = (aY :+ bh(az)) | |
346 | 348 | ||
347 | - | let | |
348 | - | let | |
349 | - | let | |
350 | - | func | |
351 | - | then | |
352 | - | else | |
349 | + | let ba = bu | |
350 | + | let bb = size(ba) | |
351 | + | let bc = nil | |
352 | + | func bd (be,bf) = if ((bf >= bb)) | |
353 | + | then be | |
354 | + | else aX(be, ba[bf]) | |
353 | 355 | ||
354 | - | func | |
355 | - | then | |
356 | + | func bg (be,bf) = if ((bf >= bb)) | |
357 | + | then be | |
356 | 358 | else throw("List size exceeds 20") | |
357 | 359 | ||
358 | - | | |
360 | + | bg(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bc, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20) | |
359 | 361 | } | |
360 | 362 | ||
361 | 363 | ||
362 | - | func | |
363 | - | let | |
364 | - | let | |
365 | - | let | |
366 | - | [StringEntry( | |
364 | + | func bv (ax,ay,az) = { | |
365 | + | let bw = aV([ax, ay]) | |
366 | + | let bx = bh(az) | |
367 | + | let by = [toString(bw[0]), toString(bw[1]), toString(bx)] | |
368 | + | [StringEntry(Q, makeString(by, ","))] | |
367 | 369 | } | |
368 | 370 | ||
369 | 371 | ||
370 | - | func | |
372 | + | func bz (bi,at,bA,ax,bB,ay,aA,aB) = if ((bi == a)) | |
371 | 373 | then { | |
372 | - | let | |
373 | - | let | |
374 | - | if ($isInstanceOf( | |
375 | - | then | |
376 | - | else throw(($getType( | |
374 | + | let bC = { | |
375 | + | let aw = invoke(at, "callFunction", ["calcLPReplenishTwoTokensREADONLY", [toString(bA), toString(bB)]], nil) | |
376 | + | if ($isInstanceOf(aw, "List[Any]")) | |
377 | + | then aw | |
378 | + | else throw(($getType(aw) + " couldn't be cast to List[Any]")) | |
377 | 379 | } | |
378 | - | if (( | |
380 | + | if ((bC == bC)) | |
379 | 381 | then $Tuple5({ | |
380 | - | let | |
381 | - | if ($isInstanceOf( | |
382 | - | then | |
383 | - | else throw(($getType( | |
382 | + | let aw = bC[3] | |
383 | + | if ($isInstanceOf(aw, "Int")) | |
384 | + | then aw | |
385 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
384 | 386 | }, { | |
385 | - | let | |
386 | - | if ($isInstanceOf( | |
387 | - | then | |
388 | - | else throw(($getType( | |
387 | + | let aw = bC[4] | |
388 | + | if ($isInstanceOf(aw, "Int")) | |
389 | + | then aw | |
390 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
389 | 391 | }, { | |
390 | - | let | |
391 | - | if ($isInstanceOf( | |
392 | - | then | |
393 | - | else throw(($getType( | |
394 | - | }, | |
395 | - | let | |
396 | - | if ($isInstanceOf( | |
397 | - | then | |
398 | - | else throw(($getType( | |
392 | + | let aw = bC[1] | |
393 | + | if ($isInstanceOf(aw, "Int")) | |
394 | + | then aw | |
395 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
396 | + | }, aQ(bC[2]), { | |
397 | + | let aw = bC[0] | |
398 | + | if ($isInstanceOf(aw, "Int")) | |
399 | + | then aw | |
400 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
399 | 401 | }) | |
400 | 402 | else throw("Strict value is not equal to itself.") | |
401 | 403 | } | |
402 | 404 | else { | |
403 | - | let | |
404 | - | let | |
405 | - | if ($isInstanceOf( | |
406 | - | then | |
407 | - | else throw(($getType( | |
405 | + | let bD = $Tuple2(split({ | |
406 | + | let aw = invoke(at, "evaluatePutByAmountAssetREADONLY", [bA], nil) | |
407 | + | if ($isInstanceOf(aw, "String")) | |
408 | + | then aw | |
409 | + | else throw(($getType(aw) + " couldn't be cast to String")) | |
408 | 410 | }, "__"), split({ | |
409 | - | let | |
410 | - | if ($isInstanceOf( | |
411 | - | then | |
412 | - | else throw(($getType( | |
411 | + | let aw = invoke(at, "evaluatePutByPriceAssetREADONLY", [bB], nil) | |
412 | + | if ($isInstanceOf(aw, "String")) | |
413 | + | then aw | |
414 | + | else throw(($getType(aw) + " couldn't be cast to String")) | |
413 | 415 | }, "__")) | |
414 | - | if (( | |
416 | + | if ((bD == bD)) | |
415 | 417 | then { | |
416 | - | let | |
417 | - | let | |
418 | - | let | |
419 | - | let | |
420 | - | if (( | |
418 | + | let bE = bD._2 | |
419 | + | let bF = bD._1 | |
420 | + | let bG = parseIntValue(bF[1]) | |
421 | + | let bH = parseIntValue(bE[1]) | |
422 | + | if ((bH > bG)) | |
421 | 423 | then { | |
422 | - | let | |
423 | - | $Tuple5( | |
424 | + | let bI = parseIntValue(bF[8]) | |
425 | + | $Tuple5(bA, bI, (bB - bI), ay, bH) | |
424 | 426 | } | |
425 | 427 | else { | |
426 | - | let | |
427 | - | $Tuple5( | |
428 | + | let bI = parseIntValue(bF[8]) | |
429 | + | $Tuple5(bI, bB, (bA - bI), ax, bG) | |
428 | 430 | } | |
429 | 431 | } | |
430 | 432 | else throw("Strict value is not equal to itself.") | |
431 | 433 | } | |
432 | 434 | ||
433 | 435 | ||
434 | - | func | |
435 | - | let | |
436 | - | if (( | |
437 | - | then invoke( | |
438 | - | else invoke( | |
436 | + | func bJ (at,bi,bA,ax,bB,ay) = { | |
437 | + | let bK = [AttachedPayment(aR(ax), bA), AttachedPayment(aR(ay), bB)] | |
438 | + | if ((bi == a)) | |
439 | + | then invoke(at, "callFunction", ["replenishWithTwoTokens", ["false", "0"]], bK) | |
440 | + | else invoke(at, "put", [1000000, false], bK) | |
439 | 441 | } | |
440 | 442 | ||
441 | 443 | ||
442 | - | func | |
443 | - | let | |
444 | - | if (( | |
445 | - | then invoke( | |
446 | - | else invoke( | |
444 | + | func bL (at,bi,bI,bM) = { | |
445 | + | let bK = [AttachedPayment(aR(bM), bI)] | |
446 | + | if ((bi == a)) | |
447 | + | then invoke(at, "callFunction", ["replenishWithOneToken", ["0", "false", "0"]], bK) | |
448 | + | else invoke(at, "putOneTkn", [0, false], bK) | |
447 | 449 | } | |
448 | 450 | ||
449 | 451 | ||
450 | - | func | |
451 | - | let | |
452 | - | if (( | |
453 | - | then invoke( | |
454 | - | else invoke( | |
452 | + | func bN (aG,bi,az,bO) = { | |
453 | + | let bK = [AttachedPayment(fromBase58String(az), bO)] | |
454 | + | if ((bi == a)) | |
455 | + | then invoke(aM(), "lockShareTokens", [aG, 0], bK) | |
456 | + | else invoke(aN(addressFromStringValue(aG)), "stake", nil, bK) | |
455 | 457 | } | |
456 | 458 | ||
457 | 459 | ||
458 | - | func | |
459 | - | let | |
460 | - | then $Tuple3( | |
461 | - | else if (( | |
462 | - | then $Tuple3( | |
460 | + | func bP (aG,bi,az,bO) = { | |
461 | + | let bQ = if ((bi == a)) | |
462 | + | then $Tuple3(aM(), "withdrawShareTokens", [aG, bO]) | |
463 | + | else if ((bi == b)) | |
464 | + | then $Tuple3(aN(Address(fromBase58String(aG))), "unstake", [az, bO]) | |
463 | 465 | else throw("Wrong pool type") | |
464 | - | let | |
465 | - | let | |
466 | - | let | |
467 | - | let | |
468 | - | if (( | |
469 | - | then | |
466 | + | let bR = bQ._1 | |
467 | + | let bS = bQ._2 | |
468 | + | let bT = bQ._3 | |
469 | + | let bU = invoke(bR, bS, bT, nil) | |
470 | + | if ((bU == bU)) | |
471 | + | then bO | |
470 | 472 | else throw("Strict value is not equal to itself.") | |
471 | 473 | } | |
472 | 474 | ||
473 | 475 | ||
474 | - | func | |
475 | - | let | |
476 | - | let | |
477 | - | let | |
478 | - | let | |
479 | - | let | |
476 | + | func bV (aG,bW,bX,aA,aB,bY,bZ) = { | |
477 | + | let at = Address(fromBase58String(aG)) | |
478 | + | let ca = 1000000 | |
479 | + | let cb = getIntegerValue(at, t) | |
480 | + | let cc = fraction(bY, ca, (ca - cb)) | |
481 | + | let cd = if ((bZ == bW)) | |
480 | 482 | then { | |
481 | - | let | |
482 | - | $Tuple2( | |
483 | + | let ce = fraction(cc, aB, (aA - cc)) | |
484 | + | $Tuple2(ce, bX) | |
483 | 485 | } | |
484 | 486 | else { | |
485 | - | let | |
486 | - | $Tuple2( | |
487 | + | let ce = fraction(cc, aA, (aB - cc)) | |
488 | + | $Tuple2(ce, bW) | |
487 | 489 | } | |
488 | - | let | |
489 | - | let | |
490 | - | $Tuple2( | |
490 | + | let ce = cd._1 | |
491 | + | let cf = cd._2 | |
492 | + | $Tuple2(cf, ce) | |
491 | 493 | } | |
492 | 494 | ||
493 | 495 | ||
494 | - | func | |
495 | - | let | |
496 | - | let | |
497 | - | let | |
498 | - | let | |
496 | + | func cg (aG,bW,bX,aA,aB,bY,bZ) = { | |
497 | + | let ch = getIntegerValue(ae, "%s__protocolFee") | |
498 | + | let ci = getIntegerValue(ae, "%s__poolFee") | |
499 | + | let cj = toBigInt(100000000) | |
500 | + | let ck = if ((bZ == bW)) | |
499 | 501 | then { | |
500 | - | let | |
501 | - | $Tuple2( | |
502 | + | let ce = fraction(bY, aB, (aA - bY)) | |
503 | + | $Tuple2(ce, bX) | |
502 | 504 | } | |
503 | 505 | else { | |
504 | - | let | |
505 | - | $Tuple2( | |
506 | + | let ce = fraction(bY, aA, (aB - bY)) | |
507 | + | $Tuple2(ce, bW) | |
506 | 508 | } | |
507 | - | let | |
508 | - | let | |
509 | - | let | |
510 | - | $Tuple2( | |
509 | + | let ce = ck._1 | |
510 | + | let cf = ck._2 | |
511 | + | let cl = toInt(fraction(toBigInt(ce), cj, (cj - toBigInt((ch + ci))), CEILING)) | |
512 | + | $Tuple2(cf, fraction(cl, 102, 100)) | |
511 | 513 | } | |
512 | 514 | ||
513 | 515 | ||
514 | - | func | |
516 | + | func cm (aD,aG,bW,bX,aA,aB,bY,bZ) = if ((aD == a)) | |
515 | 517 | then { | |
516 | - | let | |
517 | - | let | |
518 | - | let | |
519 | - | invoke(addressFromStringValue( | |
518 | + | let cn = bV(aG, bW, bX, aA, aB, bY, bZ) | |
519 | + | let cf = cn._1 | |
520 | + | let ce = cn._2 | |
521 | + | invoke(addressFromStringValue(aG), "callFunction", ["exchange", [toString(bY)]], [AttachedPayment(aR(cf), ce)]) | |
520 | 522 | } | |
521 | 523 | else { | |
522 | - | let | |
523 | - | let | |
524 | - | let | |
525 | - | invoke( | |
524 | + | let co = cg(aG, bW, bX, aA, aB, bY, bZ) | |
525 | + | let cf = co._1 | |
526 | + | let ce = co._2 | |
527 | + | invoke(ae, "swap", [bY, bZ, toString(this)], [AttachedPayment(aR(cf), ce)]) | |
526 | 528 | } | |
527 | 529 | ||
528 | 530 | ||
529 | - | func | |
530 | - | let | |
531 | - | if (( | |
531 | + | func cp (bi,aG,bA,ax,bB,ay,aA,aB) = { | |
532 | + | let at = addressFromStringValue(aG) | |
533 | + | if ((bi == a)) | |
532 | 534 | then { | |
533 | - | let | |
534 | - | let | |
535 | - | if ($isInstanceOf( | |
536 | - | then | |
537 | - | else throw(($getType( | |
535 | + | let bU = { | |
536 | + | let aw = invoke(at, "callFunction", ["calcLPReplenishDiffPropREADONLY", [toString(bA), toString(bB), "0"]], nil) | |
537 | + | if ($isInstanceOf(aw, "List[Any]")) | |
538 | + | then aw | |
539 | + | else throw(($getType(aw) + " couldn't be cast to List[Any]")) | |
538 | 540 | } | |
539 | - | if (( | |
541 | + | if ((bU == bU)) | |
540 | 542 | then $Tuple2({ | |
541 | - | let | |
542 | - | if ($isInstanceOf( | |
543 | - | then | |
544 | - | else throw(($getType( | |
543 | + | let aw = bU[0] | |
544 | + | if ($isInstanceOf(aw, "Int")) | |
545 | + | then aw | |
546 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
545 | 547 | }, { | |
546 | - | let | |
547 | - | if ($isInstanceOf( | |
548 | - | then | |
549 | - | else throw(($getType( | |
548 | + | let aw = bU[1] | |
549 | + | if ($isInstanceOf(aw, "Int")) | |
550 | + | then aw | |
551 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
550 | 552 | }) | |
551 | 553 | else throw("Strict value is not equal to itself.") | |
552 | 554 | } | |
553 | - | else if (( | |
555 | + | else if ((bi == b)) | |
554 | 556 | then { | |
555 | - | let | |
556 | - | then ( | |
557 | + | let cq = if (if ((bA > 0)) | |
558 | + | then (bB > 0) | |
557 | 559 | else false) | |
558 | 560 | then { | |
559 | - | let | |
560 | - | let | |
561 | - | let | |
562 | - | let | |
563 | - | let | |
564 | - | let | |
565 | - | $Tuple3( | |
561 | + | let cr = bz(bi, at, bA, ax, bB, ay, aA, aB) | |
562 | + | let cs = cr._1 | |
563 | + | let ct = cr._2 | |
564 | + | let cu = cr._3 | |
565 | + | let cv = cr._4 | |
566 | + | let cw = cr._5 | |
567 | + | $Tuple3(cu, cv, cw) | |
566 | 568 | } | |
567 | - | else if (( | |
568 | - | then $Tuple3( | |
569 | - | else $Tuple3( | |
570 | - | let | |
571 | - | let | |
572 | - | let | |
573 | - | let | |
569 | + | else if ((bA > 0)) | |
570 | + | then $Tuple3(bA, ax, 0) | |
571 | + | else $Tuple3(bB, ay, 0) | |
572 | + | let cu = cq._1 | |
573 | + | let cv = cq._2 | |
574 | + | let cx = cq._3 | |
575 | + | let cy = if ((cu > 0)) | |
574 | 576 | then { | |
575 | - | let | |
576 | - | let | |
577 | - | if ($isInstanceOf( | |
578 | - | then | |
579 | - | else throw(($getType( | |
577 | + | let bU = { | |
578 | + | let aw = invoke(at, "putOneTknREADONLY", [cv, cu], nil) | |
579 | + | if ($isInstanceOf(aw, "(Int, Int, Int)")) | |
580 | + | then aw | |
581 | + | else throw(($getType(aw) + " couldn't be cast to (Int, Int, Int)")) | |
580 | 582 | } | |
581 | - | if (( | |
582 | - | then $Tuple2( | |
583 | + | if ((bU == bU)) | |
584 | + | then $Tuple2(bU._1, bU._3) | |
583 | 585 | else throw("Strict value is not equal to itself.") | |
584 | 586 | } | |
585 | 587 | else $Tuple2(0, 0) | |
586 | - | let | |
587 | - | let | |
588 | - | $Tuple2(( | |
588 | + | let cz = cy._1 | |
589 | + | let cA = cy._2 | |
590 | + | $Tuple2((cx + cz), cA) | |
589 | 591 | } | |
590 | 592 | else throw("Wrong pool type") | |
591 | 593 | } | |
592 | 594 | ||
593 | 595 | ||
594 | - | func | |
595 | - | let | |
596 | - | let | |
596 | + | func cB (bi,aG,cw,az,ax,ay,aA,aB,cC,cD) = { | |
597 | + | let at = addressFromStringValue(aG) | |
598 | + | let cE = if ((bi == a)) | |
597 | 599 | then { | |
598 | - | let | |
599 | - | let | |
600 | - | if ($isInstanceOf( | |
601 | - | then | |
602 | - | else throw(($getType( | |
600 | + | let bU = { | |
601 | + | let aw = invoke(at, "callFunction", ["withdrawREADONLY", [toString(cw), toString(aA), toString(aB)]], nil) | |
602 | + | if ($isInstanceOf(aw, "List[Any]")) | |
603 | + | then aw | |
604 | + | else throw(($getType(aw) + " couldn't be cast to List[Any]")) | |
603 | 605 | } | |
604 | - | if (( | |
606 | + | if ((bU == bU)) | |
605 | 607 | then $Tuple2({ | |
606 | - | let | |
607 | - | if ($isInstanceOf( | |
608 | - | then | |
609 | - | else throw(($getType( | |
608 | + | let aw = bU[0] | |
609 | + | if ($isInstanceOf(aw, "Int")) | |
610 | + | then aw | |
611 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
610 | 612 | }, { | |
611 | - | let | |
612 | - | if ($isInstanceOf( | |
613 | - | then | |
614 | - | else throw(($getType( | |
613 | + | let aw = bU[1] | |
614 | + | if ($isInstanceOf(aw, "Int")) | |
615 | + | then aw | |
616 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
615 | 617 | }) | |
616 | 618 | else throw("Strict value is not equal to itself.") | |
617 | 619 | } | |
618 | - | else if (( | |
620 | + | else if ((bi == b)) | |
619 | 621 | then { | |
620 | - | let | |
621 | - | let | |
622 | - | if ($isInstanceOf( | |
623 | - | then | |
624 | - | else throw(($getType( | |
622 | + | let cF = split({ | |
623 | + | let aw = invoke(at, "evaluateGetREADONLY", [az, cw], nil) | |
624 | + | if ($isInstanceOf(aw, "String")) | |
625 | + | then aw | |
626 | + | else throw(($getType(aw) + " couldn't be cast to String")) | |
625 | 627 | }, "__") | |
626 | - | if (( | |
627 | - | then $Tuple2(parseIntValue( | |
628 | + | if ((cF == cF)) | |
629 | + | then $Tuple2(parseIntValue(cF[1]), parseIntValue(cF[2])) | |
628 | 630 | else throw("Strict value is not equal to itself.") | |
629 | 631 | } | |
630 | 632 | else throw("Wrong pool type") | |
631 | - | let | |
632 | - | let | |
633 | - | if (( | |
633 | + | let cG = cE._1 | |
634 | + | let cH = cE._2 | |
635 | + | if ((cC > 0)) | |
634 | 636 | then { | |
635 | - | let | |
636 | - | then ( | |
637 | + | let cI = if (if ((cD == ax)) | |
638 | + | then (cC > cG) | |
637 | 639 | else false) | |
638 | - | then ( | |
639 | - | else if (if (( | |
640 | - | then ( | |
640 | + | then (cC - cG) | |
641 | + | else if (if ((cD == ay)) | |
642 | + | then (cC > cH) | |
641 | 643 | else false) | |
642 | - | then ( | |
644 | + | then (cC - cH) | |
643 | 645 | else 0 | |
644 | - | let | |
645 | - | then if (( | |
646 | - | then | |
647 | - | else | |
646 | + | let cJ = if ((cI > 0)) | |
647 | + | then if ((bi == a)) | |
648 | + | then bV(aG, ax, ay, aA, aB, cI, cD) | |
649 | + | else cg(aG, ax, ay, aA, aB, cI, cD) | |
648 | 650 | else $Tuple2("", 0) | |
649 | - | let | |
650 | - | let | |
651 | - | if (( | |
652 | - | then $Tuple2((( | |
653 | - | else $Tuple2(( | |
651 | + | let cf = cJ._1 | |
652 | + | let ce = cJ._2 | |
653 | + | if ((cD == ax)) | |
654 | + | then $Tuple2(((cG + cI) - cC), (cH - ce)) | |
655 | + | else $Tuple2((cG - ce), ((cH + cI) - cC)) | |
654 | 656 | } | |
655 | - | else $Tuple2( | |
657 | + | else $Tuple2(cG, cH) | |
656 | 658 | } | |
657 | 659 | ||
658 | 660 | ||
659 | - | func | |
661 | + | func cK (aD,aG) = if ((aD == a)) | |
660 | 662 | then { | |
661 | - | let | |
662 | - | if (( | |
663 | + | let cL = an(af) | |
664 | + | if ((cL == cL)) | |
663 | 665 | then { | |
664 | - | let | |
665 | - | if (( | |
666 | + | let bU = invoke(aM(), "claim", [aG], nil) | |
667 | + | if ((bU == bU)) | |
666 | 668 | then { | |
667 | - | let | |
668 | - | $Tuple2(( | |
669 | + | let cM = an(af) | |
670 | + | $Tuple2((cM - cL), af) | |
669 | 671 | } | |
670 | 672 | else throw("Strict value is not equal to itself.") | |
671 | 673 | } | |
672 | 674 | else throw("Strict value is not equal to itself.") | |
673 | 675 | } | |
674 | - | else if (( | |
676 | + | else if ((aD == b)) | |
675 | 677 | then { | |
676 | - | let | |
677 | - | if (( | |
678 | + | let cL = an(ag) | |
679 | + | if ((cL == cL)) | |
678 | 680 | then { | |
679 | - | let | |
680 | - | if (( | |
681 | + | let bU = invoke(aN(Address(fromBase58String(aG))), "claimWX", [aG], nil) | |
682 | + | if ((bU == bU)) | |
681 | 683 | then { | |
682 | - | let | |
683 | - | $Tuple2(( | |
684 | + | let cM = an(ag) | |
685 | + | $Tuple2((cM - cL), ag) | |
684 | 686 | } | |
685 | 687 | else throw("Strict value is not equal to itself.") | |
686 | 688 | } | |
689 | 691 | else throw("Wrong pool type") | |
690 | 692 | ||
691 | 693 | ||
692 | - | func | |
693 | - | let | |
694 | - | if (( | |
694 | + | func cN (bi,aG,aL,bA,ax,bB,ay,aA,aB,cO) = { | |
695 | + | let cP = an(fromBase58String(cO)) | |
696 | + | if ((cP == cP)) | |
695 | 697 | then { | |
696 | - | let | |
697 | - | let | |
698 | - | then ( | |
698 | + | let at = addressFromStringValue(aG) | |
699 | + | let cQ = if (if ((bA > 0)) | |
700 | + | then (bB > 0) | |
699 | 701 | else false) | |
700 | 702 | then { | |
701 | - | let | |
702 | - | let | |
703 | - | let | |
704 | - | let | |
705 | - | let | |
706 | - | let | |
707 | - | if (( | |
708 | - | then $Tuple2( | |
703 | + | let cR = bz(bi, at, bA, ax, bB, ay, aA, aB) | |
704 | + | let cs = cR._1 | |
705 | + | let ct = cR._2 | |
706 | + | let cu = cR._3 | |
707 | + | let cv = cR._4 | |
708 | + | let bU = bJ(at, bi, cs, ax, ct, ay) | |
709 | + | if ((bU == bU)) | |
710 | + | then $Tuple2(cu, cv) | |
709 | 711 | else throw("Strict value is not equal to itself.") | |
710 | 712 | } | |
711 | - | else if (( | |
712 | - | then $Tuple2( | |
713 | - | else if (( | |
714 | - | then $Tuple2( | |
713 | + | else if ((bA > 0)) | |
714 | + | then $Tuple2(bA, ax) | |
715 | + | else if ((bB > 0)) | |
716 | + | then $Tuple2(bB, ay) | |
715 | 717 | else throw("pmts must be > 0") | |
716 | - | let | |
717 | - | let | |
718 | - | let | |
719 | - | then | |
718 | + | let cu = cQ._1 | |
719 | + | let cv = cQ._2 | |
720 | + | let bU = if ((cu > 0)) | |
721 | + | then bL(at, bi, cu, cv) | |
720 | 722 | else nil | |
721 | - | if (( | |
723 | + | if ((bU == bU)) | |
722 | 724 | then { | |
723 | - | let | |
724 | - | let | |
725 | - | let | |
726 | - | let | |
727 | - | if ((0 >= | |
725 | + | let cS = an(fromBase58String(cO)) | |
726 | + | let cT = (cS - cP) | |
727 | + | let cU = fraction(cT, aK(aG, aL), m) | |
728 | + | let cV = (cT - cU) | |
729 | + | if ((0 >= cV)) | |
728 | 730 | then throw("amount of staked sharetokens must be > 0") | |
729 | 731 | else { | |
730 | - | let | |
731 | - | if (( | |
732 | - | then $Tuple2( | |
732 | + | let cW = bN(aG, bi, cO, cV) | |
733 | + | if ((cW == cW)) | |
734 | + | then $Tuple2(cV, cU) | |
733 | 735 | else throw("Strict value is not equal to itself.") | |
734 | 736 | } | |
735 | 737 | } | |
739 | 741 | } | |
740 | 742 | ||
741 | 743 | ||
742 | - | func | |
743 | - | let | |
744 | - | let | |
745 | - | let | |
746 | - | then $Tuple2(getIntegerValue(this, ( | |
747 | - | else $Tuple2(getIntegerValue(this, ( | |
748 | - | let | |
749 | - | let | |
750 | - | [IntegerEntry(( | |
744 | + | func cX (aG,aJ,cY,cU,cZ,az,aD,da) = { | |
745 | + | let db = aF(aG) | |
746 | + | let dc = aH(aG) | |
747 | + | let dd = if (da) | |
748 | + | then $Tuple2(getIntegerValue(this, (aG + C)), (dc + cY)) | |
749 | + | else $Tuple2(getIntegerValue(this, (aG + D)), dc) | |
750 | + | let de = dd._1 | |
751 | + | let df = dd._2 | |
752 | + | [IntegerEntry((aG + A), (db + cY)), IntegerEntry((aG + B), df), IntegerEntry((((((aG + "_") + aJ) + "_") + toString(cZ)) + u), cY), IntegerEntry((((((aG + "_") + aJ) + "_") + toString(cZ)) + z), de), StringEntry((((aJ + "_") + toString(cZ)) + v), aG), IntegerEntry((aJ + y), cZ), ScriptTransfer(ab, cU, fromBase58String(az))] | |
751 | 753 | } | |
752 | 754 | ||
753 | 755 | ||
754 | - | func | |
755 | - | let | |
756 | - | if (( | |
756 | + | func dg (dh,di,dj,dk,dl,dm,dn,do,dp,dq) = { | |
757 | + | let dr = an(aR(dh)) | |
758 | + | if ((dr == dr)) | |
757 | 759 | then { | |
758 | - | let | |
759 | - | if (( | |
760 | - | then ( | |
760 | + | let bU = invoke(ac, "swap", [dk, dl, dm, dn, do, dp, dq], [AttachedPayment(dj, di)]) | |
761 | + | if ((bU == bU)) | |
762 | + | then (an(aR(dh)) - dr) | |
761 | 763 | else throw("Strict value is not equal to itself.") | |
762 | 764 | } | |
763 | 765 | else throw("Strict value is not equal to itself.") | |
764 | 766 | } | |
765 | 767 | ||
766 | 768 | ||
767 | - | func | |
768 | - | let | |
769 | - | if (( | |
769 | + | func ds (dh,di,dj,dt,du,dq) = { | |
770 | + | let dr = an(aR(dh)) | |
771 | + | if ((dr == dr)) | |
770 | 772 | then { | |
771 | - | let | |
772 | - | if (( | |
773 | - | then ( | |
773 | + | let bU = invoke(ac, "puzzleSwap", [dt, du, dq], [AttachedPayment(dj, di)]) | |
774 | + | if ((bU == bU)) | |
775 | + | then (an(aR(dh)) - dr) | |
774 | 776 | else throw("Strict value is not equal to itself.") | |
775 | 777 | } | |
776 | 778 | else throw("Strict value is not equal to itself.") | |
777 | 779 | } | |
778 | 780 | ||
779 | 781 | ||
780 | - | func | |
781 | - | let | |
782 | - | if (( | |
782 | + | func dv (dh,di,dj,dw,dx,dy,dz,dA,dB,dq) = { | |
783 | + | let dr = an(aR(dh)) | |
784 | + | if ((dr == dr)) | |
783 | 785 | then { | |
784 | - | let | |
785 | - | if (( | |
786 | - | then ( | |
786 | + | let bU = invoke(ac, "swopfiSwap", [dw, dx, dy, dz, dA, dB, dq], [AttachedPayment(dj, di)]) | |
787 | + | if ((bU == bU)) | |
788 | + | then (an(aR(dh)) - dr) | |
787 | 789 | else throw("Strict value is not equal to itself.") | |
788 | 790 | } | |
789 | 791 | else throw("Strict value is not equal to itself.") | |
790 | 792 | } | |
791 | 793 | ||
792 | 794 | ||
793 | - | func | |
794 | - | let | |
795 | - | let | |
796 | - | let | |
797 | - | let | |
798 | - | let | |
799 | - | let | |
800 | - | let | |
801 | - | if (if (( | |
802 | - | then ( | |
795 | + | func dC (aG,bi,dD,dE) = { | |
796 | + | let at = Address(fromBase58String(aG)) | |
797 | + | let dF = aC(at, bi) | |
798 | + | let dG = dF._1 | |
799 | + | let dH = dF._2 | |
800 | + | let aA = dF._3 | |
801 | + | let aB = dF._4 | |
802 | + | let az = dF._5 | |
803 | + | if (if ((dD != dG)) | |
804 | + | then (dD != dH) | |
803 | 805 | else false) | |
804 | 806 | then throw("Wrong asset") | |
805 | 807 | else { | |
806 | - | let | |
807 | - | then $Tuple2( | |
808 | - | else $Tuple2(0, | |
809 | - | let | |
810 | - | let | |
811 | - | let | |
812 | - | let | |
813 | - | let | |
814 | - | let | |
815 | - | let | |
816 | - | let | |
817 | - | let | |
818 | - | let | |
819 | - | let | |
820 | - | let | |
821 | - | let | |
822 | - | then ( | |
808 | + | let dI = if ((dD == dG)) | |
809 | + | then $Tuple2(dE, 0) | |
810 | + | else $Tuple2(0, dE) | |
811 | + | let bA = dI._1 | |
812 | + | let bB = dI._2 | |
813 | + | let dJ = cN(bi, aG, i, bA, dG, bB, dH, aA, aB, az) | |
814 | + | let cY = dJ._1 | |
815 | + | let dK = dJ._2 | |
816 | + | let dL = valueOrElse(getInteger(this, (aG + C)), 0) | |
817 | + | let dM = valueOrElse(getInteger(this, (aG + D)), 0) | |
818 | + | let dN = aF(aG) | |
819 | + | let dO = aH(aG) | |
820 | + | let dP = fraction(dO, j, dN) | |
821 | + | let dQ = fraction(cY, dP, j) | |
822 | + | let dR = (cY - dQ) | |
823 | + | let dS = if ((dO > 0)) | |
824 | + | then (dL + fraction(dQ, k, dO)) | |
823 | 825 | else 0 | |
824 | - | let | |
825 | - | then ( | |
826 | + | let dT = if (((dN - dO) > 0)) | |
827 | + | then (dM + fraction(dR, k, (dN - dO))) | |
826 | 828 | else 0 | |
827 | - | let | |
828 | - | let | |
829 | - | let | |
830 | - | if (( | |
831 | - | then ([IntegerEntry(( | |
829 | + | let dU = fraction(dQ, aK(aG, d), m) | |
830 | + | let dV = fraction(dR, aK(aG, c), m) | |
831 | + | let dW = bP(aG, bi, az, (dU + dV)) | |
832 | + | if ((dW == dW)) | |
833 | + | then ([IntegerEntry((aG + C), dS), IntegerEntry((aG + D), dT), IntegerEntry((aG + A), ((dN + cY) - dW)), IntegerEntry((aG + B), ((dO + dQ) - dU)), ScriptTransfer(ab, (dU + dV), fromBase58String(az))] ++ bv(dG, dH, az)) | |
832 | 834 | else throw("Strict value is not equal to itself.") | |
833 | 835 | } | |
834 | 836 | } | |
835 | 837 | ||
836 | 838 | ||
837 | - | func | |
838 | - | let | |
839 | - | let | |
840 | - | let | |
841 | - | let | |
842 | - | let | |
843 | - | let | |
844 | - | let | |
845 | - | let | |
846 | - | let | |
847 | - | if (( | |
839 | + | func dX (aG,dY,dZ,ea) = { | |
840 | + | let at = Address(fromBase58String(aG)) | |
841 | + | let bi = valueOrErrorMessage(getString(this, (N + aG)), "Unknown pool") | |
842 | + | let eb = aC(at, bi) | |
843 | + | let bW = eb._1 | |
844 | + | let bX = eb._2 | |
845 | + | let aA = eb._3 | |
846 | + | let aB = eb._4 | |
847 | + | let az = eb._5 | |
848 | + | let ec = an(aR(bW)) | |
849 | + | if ((ec == ec)) | |
848 | 850 | then { | |
849 | - | let | |
850 | - | if (( | |
851 | + | let ed = an(aR(bX)) | |
852 | + | if ((ed == ed)) | |
851 | 853 | then { | |
852 | - | let | |
853 | - | then invoke( | |
854 | + | let bU = if ((bi == a)) | |
855 | + | then invoke(at, "callFunction", ["withdraw", [toString(dY)]], nil) | |
854 | 856 | else { | |
855 | - | let | |
856 | - | if (( | |
857 | - | then invoke( | |
857 | + | let bU = bP(aG, bi, az, dY) | |
858 | + | if ((bU == bU)) | |
859 | + | then invoke(at, "get", nil, [AttachedPayment(aR(az), dY)]) | |
858 | 860 | else throw("Strict value is not equal to itself.") | |
859 | 861 | } | |
860 | - | if (( | |
862 | + | if ((bU == bU)) | |
861 | 863 | then { | |
862 | - | let | |
863 | - | let | |
864 | - | let | |
865 | - | let | |
866 | - | let | |
867 | - | let | |
864 | + | let ee = an(aR(bW)) | |
865 | + | let ef = an(aR(bX)) | |
866 | + | let eg = $Tuple2((ee - ec), (ef - ed)) | |
867 | + | let eh = eg._1 | |
868 | + | let ei = eg._2 | |
869 | + | let ej = if ((dZ > 0)) | |
868 | 870 | then { | |
869 | - | let | |
870 | - | then ( | |
871 | + | let cI = if (if ((ea == bW)) | |
872 | + | then (dZ > eh) | |
871 | 873 | else false) | |
872 | - | then ( | |
873 | - | else if (if (( | |
874 | - | then ( | |
874 | + | then (dZ - eh) | |
875 | + | else if (if ((ea == bX)) | |
876 | + | then (dZ > ei) | |
875 | 877 | else false) | |
876 | - | then ( | |
878 | + | then (dZ - ei) | |
877 | 879 | else 0 | |
878 | - | let | |
879 | - | then | |
880 | + | let ek = if ((cI > 0)) | |
881 | + | then cm(bi, aG, bW, bX, aA, aB, cI, ea) | |
880 | 882 | else 0 | |
881 | - | if (( | |
883 | + | if ((ek == ek)) | |
882 | 884 | then { | |
883 | - | let | |
884 | - | let | |
885 | - | if (( | |
886 | - | then $Tuple2((( | |
887 | - | else $Tuple2(( | |
885 | + | let el = an(aR(bW)) | |
886 | + | let em = an(aR(bX)) | |
887 | + | if ((ea == bW)) | |
888 | + | then $Tuple2(((el - ec) - dZ), (em - ed)) | |
889 | + | else $Tuple2((el - ec), ((em - ed) - dZ)) | |
888 | 890 | } | |
889 | 891 | else throw("Strict value is not equal to itself.") | |
890 | 892 | } | |
891 | - | else $Tuple2( | |
892 | - | let | |
893 | - | let | |
894 | - | $Tuple7( | |
893 | + | else $Tuple2(eh, ei) | |
894 | + | let en = ej._1 | |
895 | + | let eo = ej._2 | |
896 | + | $Tuple7(en, bW, eo, bX, ee, ef, az) | |
895 | 897 | } | |
896 | 898 | else throw("Strict value is not equal to itself.") | |
897 | 899 | } | |
901 | 903 | } | |
902 | 904 | ||
903 | 905 | ||
904 | - | func | |
905 | - | let | |
906 | - | let | |
907 | - | let | |
908 | - | then getIntegerValue(this, ( | |
909 | - | else getIntegerValue(this, ( | |
910 | - | ( | |
906 | + | func ep (aJ,aG,eq,er) = { | |
907 | + | let es = valueOrErrorMessage(getInteger(this, (((((aG + "_") + aJ) + "_") + eq) + u)), "Unknown position") | |
908 | + | let et = getIntegerValue(this, (((((aG + "_") + aJ) + "_") + eq) + z)) | |
909 | + | let eu = if (er) | |
910 | + | then getIntegerValue(this, (aG + C)) | |
911 | + | else getIntegerValue(this, (aG + D)) | |
912 | + | (es + fraction(es, (eu - et), k)) | |
911 | 913 | } | |
912 | 914 | ||
913 | 915 | ||
914 | - | func | |
915 | - | let | |
916 | - | let | |
917 | - | let | |
918 | - | let | |
919 | - | let | |
920 | - | let | |
921 | - | let | |
916 | + | func ev (aJ,aG,eq,ew) = { | |
917 | + | let es = valueOrErrorMessage(getInteger(this, (((((aG + "_") + aJ) + "_") + eq) + u)), "Unknown position") | |
918 | + | let cC = valueOrElse(getInteger(this, (((((aG + "_") + aJ) + "_") + eq) + w)), 0) | |
919 | + | let dY = ep(aJ, aG, eq, (cC > 0)) | |
920 | + | let ex = aF(aG) | |
921 | + | let ey = Address(fromBase58String(aJ)) | |
922 | + | let ea = valueOrElse(getString(this, (((((aG + "_") + aJ) + "_") + eq) + x)), "") | |
923 | + | let dZ = if ((cC > 0)) | |
922 | 924 | then { | |
923 | - | let | |
924 | - | if ($isInstanceOf( | |
925 | - | then | |
926 | - | else throw(($getType( | |
925 | + | let aw = invoke(ah(), "getAssetDebt", [false, ((aJ + "_") + eq), ea], nil) | |
926 | + | if ($isInstanceOf(aw, "Int")) | |
927 | + | then aw | |
928 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
927 | 929 | } | |
928 | 930 | else 0 | |
929 | - | let | |
930 | - | if (( | |
931 | + | let ez = dX(aG, dY, dZ, ea) | |
932 | + | if ((ez == ez)) | |
931 | 933 | then { | |
932 | - | let | |
933 | - | let | |
934 | - | let | |
935 | - | let | |
936 | - | let | |
937 | - | let | |
938 | - | let | |
939 | - | let | |
940 | - | then invoke( | |
934 | + | let az = ez._7 | |
935 | + | let ef = ez._6 | |
936 | + | let ee = ez._5 | |
937 | + | let bX = ez._4 | |
938 | + | let eA = ez._3 | |
939 | + | let bW = ez._2 | |
940 | + | let eB = ez._1 | |
941 | + | let eC = if ((dZ > 0)) | |
942 | + | then invoke(ah(), "repayFor", [((aJ + "_") + eq)], [AttachedPayment(aR(ea), dZ)]) | |
941 | 943 | else 0 | |
942 | - | if (( | |
943 | - | then ([DeleteEntry(((((( | |
944 | + | if ((eC == eC)) | |
945 | + | then ([DeleteEntry((((((aG + "_") + aJ) + "_") + eq) + u)), DeleteEntry((((((aG + "_") + aJ) + "_") + eq) + z)), IntegerEntry((aG + A), (ex - dY)), ScriptTransfer(ey, eB, aR(bW)), ScriptTransfer(ey, eA, aR(bX))] ++ bv(bW, bX, az)) | |
944 | 946 | else throw("Strict value is not equal to itself.") | |
945 | 947 | } | |
946 | 948 | else throw("Strict value is not equal to itself.") | |
947 | 949 | } | |
948 | 950 | ||
949 | 951 | ||
950 | - | func | |
951 | - | let | |
952 | - | let | |
953 | - | let | |
954 | - | let | |
955 | - | let | |
956 | - | let | |
957 | - | let | |
958 | - | let | |
959 | - | let | |
960 | - | let | |
961 | - | let | |
962 | - | let | |
963 | - | $Tuple11( | |
952 | + | func eD (eE) = { | |
953 | + | let eF = split(valueOrErrorMessage(getString(this, (eE + L)), ("No request with id " + eE)), ",") | |
954 | + | let aJ = eF[0] | |
955 | + | let aG = eF[1] | |
956 | + | let bA = parseIntValue(eF[2]) | |
957 | + | let dG = eF[3] | |
958 | + | let bB = parseIntValue(eF[4]) | |
959 | + | let dH = eF[5] | |
960 | + | let aA = parseIntValue(eF[6]) | |
961 | + | let aB = parseIntValue(eF[7]) | |
962 | + | let az = eF[8] | |
963 | + | let eG = eF[9] | |
964 | + | let eH = parseIntValue(eF[10]) | |
965 | + | $Tuple11(aJ, aG, bA, dG, bB, dH, aA, aB, az, eG, eH) | |
964 | 966 | } | |
965 | 967 | ||
966 | 968 | ||
967 | - | func | |
968 | - | let | |
969 | - | if ($isInstanceOf( | |
970 | - | then | |
971 | - | else throw(($getType( | |
972 | - | let | |
973 | - | if ($isInstanceOf( | |
974 | - | then | |
975 | - | else throw(($getType( | |
976 | - | let | |
977 | - | let | |
978 | - | let | |
979 | - | let | |
980 | - | then $Tuple2( | |
981 | - | else $Tuple2( | |
982 | - | let | |
983 | - | let | |
984 | - | fraction(fraction( | |
969 | + | func eI (bA,bB,ax,ay,eJ,eK) = { | |
970 | + | let bm = ( let aw = invoke(ad, "getTWAP60", [ax, false], nil) | |
971 | + | if ($isInstanceOf(aw, "(Int, Int)")) | |
972 | + | then aw | |
973 | + | else throw(($getType(aw) + " couldn't be cast to (Int, Int)")))._2 | |
974 | + | let bn = ( let aw = invoke(ad, "getTWAP60", [ay, false], nil) | |
975 | + | if ($isInstanceOf(aw, "(Int, Int)")) | |
976 | + | then aw | |
977 | + | else throw(($getType(aw) + " couldn't be cast to (Int, Int)")))._2 | |
978 | + | let eL = pow(10, 0, aS(ax), 0, 0, DOWN) | |
979 | + | let eM = pow(10, 0, aS(ay), 0, 0, DOWN) | |
980 | + | let eN = (fraction(bm, bA, eL) + fraction(bn, bB, eM)) | |
981 | + | let eO = if ((eK == ax)) | |
982 | + | then $Tuple2(bm, eL) | |
983 | + | else $Tuple2(bn, eM) | |
984 | + | let eP = eO._1 | |
985 | + | let eQ = eO._2 | |
986 | + | fraction(fraction(eN, (eJ - 100), 100), eQ, eP) | |
985 | 987 | } | |
986 | 988 | ||
987 | 989 | ||
988 | - | @Callable( | |
989 | - | func calcPriceImpactEVALONLY ( | |
990 | + | @Callable(ak) | |
991 | + | func calcPriceImpactEVALONLY (aG,eJ,eK,bA,bB) = if (if ((100 > eJ)) | |
990 | 992 | then true | |
991 | - | else ( | |
993 | + | else (eJ > 300)) | |
992 | 994 | then throw("Leverage can't be <100 and >300") | |
993 | 995 | else { | |
994 | - | let | |
995 | - | let | |
996 | - | let | |
997 | - | let | |
998 | - | let | |
999 | - | let | |
1000 | - | let | |
1001 | - | let | |
1002 | - | then | |
996 | + | let bi = valueOrErrorMessage(getString(this, (N + aG)), "Pool is not inited") | |
997 | + | let eR = aC(Address(fromBase58String(aG)), bi) | |
998 | + | let dG = eR._1 | |
999 | + | let dH = eR._2 | |
1000 | + | let aA = eR._3 | |
1001 | + | let aB = eR._4 | |
1002 | + | let az = eR._5 | |
1003 | + | let cC = if ((eJ > 100)) | |
1004 | + | then eI(bA, bB, dG, dH, eJ, eK) | |
1003 | 1005 | else 0 | |
1004 | - | let | |
1005 | - | then $Tuple2(( | |
1006 | - | else $Tuple2( | |
1007 | - | let | |
1008 | - | let | |
1009 | - | let | |
1010 | - | let | |
1011 | - | let | |
1012 | - | let | |
1013 | - | then ( | |
1014 | - | else | |
1015 | - | $Tuple2(nil, [ | |
1006 | + | let eS = if ((eK == dG)) | |
1007 | + | then $Tuple2((bA + cC), bB) | |
1008 | + | else $Tuple2(bA, (bB + cC)) | |
1009 | + | let eT = eS._1 | |
1010 | + | let eU = eS._2 | |
1011 | + | let eV = cp(bi, aG, eT, dG, eU, dH, aA, aB) | |
1012 | + | let cw = eV._1 | |
1013 | + | let cA = eV._2 | |
1014 | + | let eW = if ((0 > cA)) | |
1015 | + | then (cA * -1) | |
1016 | + | else cA | |
1017 | + | $Tuple2(nil, [eW]) | |
1016 | 1018 | } | |
1017 | 1019 | ||
1018 | 1020 | ||
1019 | 1021 | ||
1020 | - | @Callable( | |
1021 | - | func getShareAssetPriceREADONLY ( | |
1022 | - | let | |
1023 | - | $Tuple2(nil, | |
1022 | + | @Callable(ak) | |
1023 | + | func getShareAssetPriceREADONLY (az) = { | |
1024 | + | let eX = bh(az) | |
1025 | + | $Tuple2(nil, eX) | |
1024 | 1026 | } | |
1025 | 1027 | ||
1026 | 1028 | ||
1027 | 1029 | ||
1028 | - | @Callable( | |
1029 | - | func getUserPositionShareAmountREADONLY ( | |
1030 | - | let | |
1031 | - | let | |
1032 | - | let | |
1033 | - | $Tuple2(nil, | |
1030 | + | @Callable(ak) | |
1031 | + | func getUserPositionShareAmountREADONLY (aJ,cZ) = { | |
1032 | + | let aG = valueOrErrorMessage(getString(this, (((aJ + "_") + cZ) + v)), "Unknown position") | |
1033 | + | let cC = getIntegerValue(this, (((((aG + "_") + aJ) + "_") + cZ) + w)) | |
1034 | + | let dY = ep(aJ, aG, cZ, (cC > 0)) | |
1035 | + | $Tuple2(nil, dY) | |
1034 | 1036 | } | |
1035 | 1037 | ||
1036 | 1038 | ||
1037 | 1039 | ||
1038 | - | @Callable( | |
1039 | - | func getUserPositionInDollarsREADONLY ( | |
1040 | - | func | |
1041 | - | let | |
1042 | - | let | |
1043 | - | let | |
1044 | - | let | |
1045 | - | let | |
1046 | - | let | |
1047 | - | let | |
1048 | - | let | |
1049 | - | let | |
1050 | - | let | |
1051 | - | let | |
1052 | - | let | |
1053 | - | let | |
1054 | - | let | |
1055 | - | let | |
1056 | - | let | |
1057 | - | if (( | |
1058 | - | then $Tuple3(( | |
1040 | + | @Callable(ak) | |
1041 | + | func getUserPositionInDollarsREADONLY (aJ,eY,cZ) = { | |
1042 | + | func eZ (aY,aG) = { | |
1043 | + | let fa = aY | |
1044 | + | let fb = fa._1 | |
1045 | + | let fc = fa._2 | |
1046 | + | let fd = fa._3 | |
1047 | + | let bi = valueOrErrorMessage(getString(this, (N + aG)), "Pool is not inited") | |
1048 | + | let fe = aC(Address(fromBase58String(aG)), bi) | |
1049 | + | let dG = fe._1 | |
1050 | + | let dH = fe._2 | |
1051 | + | let aA = fe._3 | |
1052 | + | let aB = fe._4 | |
1053 | + | let az = fe._5 | |
1054 | + | let cC = valueOrElse(getInteger(this, (((((aG + "_") + aJ) + "_") + cZ[fd]) + w)), 0) | |
1055 | + | let dY = ep(aJ, aG, cZ[fd], (cC > 0)) | |
1056 | + | let eX = bh(az) | |
1057 | + | let ff = pow(10, 0, aS(az), 0, 0, DOWN) | |
1058 | + | let fg = fraction(dY, eX, ff) | |
1059 | + | if ((cC == 0)) | |
1060 | + | then $Tuple3((fb :+ fg), (fc :+ 0), (fd + 1)) | |
1059 | 1061 | else { | |
1060 | - | let | |
1061 | - | let | |
1062 | - | let | |
1063 | - | if ($isInstanceOf( | |
1064 | - | then | |
1065 | - | else throw(($getType( | |
1062 | + | let ea = getStringValue(this, (((((aG + "_") + aJ) + "_") + cZ[fd]) + x)) | |
1063 | + | let dZ = { | |
1064 | + | let aw = invoke(ah(), "getAssetDebt", [false, ((aJ + "_") + cZ[fd]), ea], nil) | |
1065 | + | if ($isInstanceOf(aw, "Int")) | |
1066 | + | then aw | |
1067 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
1066 | 1068 | } | |
1067 | - | let | |
1068 | - | if ($isInstanceOf( | |
1069 | - | then | |
1070 | - | else throw(($getType( | |
1071 | - | let | |
1072 | - | let | |
1073 | - | $Tuple3(( | |
1069 | + | let fh = ( let aw = invoke(ad, "getTWAP60", [ea, false], nil) | |
1070 | + | if ($isInstanceOf(aw, "(Int, Int)")) | |
1071 | + | then aw | |
1072 | + | else throw(($getType(aw) + " couldn't be cast to (Int, Int)")))._1 | |
1073 | + | let fi = pow(10, 0, aS(ea), 0, 0, DOWN) | |
1074 | + | let fj = fraction(dZ, fh, fi) | |
1075 | + | $Tuple3((fb :+ fg), (fc :+ fj), (fd + 1)) | |
1074 | 1076 | } | |
1075 | 1077 | } | |
1076 | 1078 | ||
1077 | - | let | |
1078 | - | let | |
1079 | - | let | |
1080 | - | let | |
1081 | - | func | |
1082 | - | then | |
1083 | - | else | |
1079 | + | let fk = { | |
1080 | + | let ba = eY | |
1081 | + | let bb = size(ba) | |
1082 | + | let bc = $Tuple3(nil, nil, 0) | |
1083 | + | func bd (be,bf) = if ((bf >= bb)) | |
1084 | + | then be | |
1085 | + | else eZ(be, ba[bf]) | |
1084 | 1086 | ||
1085 | - | func | |
1086 | - | then | |
1087 | + | func bg (be,bf) = if ((bf >= bb)) | |
1088 | + | then be | |
1087 | 1089 | else throw("List size exceeds 20") | |
1088 | 1090 | ||
1089 | - | | |
1091 | + | bg(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bc, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20) | |
1090 | 1092 | } | |
1091 | - | let | |
1092 | - | let | |
1093 | - | $Tuple2(nil, $Tuple2( | |
1093 | + | let fl = fk._1 | |
1094 | + | let dZ = fk._2 | |
1095 | + | $Tuple2(nil, $Tuple2(fl, dZ)) | |
1094 | 1096 | } | |
1095 | 1097 | ||
1096 | 1098 | ||
1097 | 1099 | ||
1098 | - | @Callable( | |
1099 | - | func replenish ( | |
1100 | + | @Callable(ak) | |
1101 | + | func replenish (aG,eJ,eK) = if (if ((100 > eJ)) | |
1100 | 1102 | then true | |
1101 | - | else ( | |
1103 | + | else (eJ > 300)) | |
1102 | 1104 | then throw("Leverage can't be <100 and >300") | |
1103 | - | else { | |
1104 | - | let bh = valueOrErrorMessage(getString(this, (M + aF)), "Pool is not inited") | |
1105 | - | let fl = aB(Address(fromBase58String(aF)), bh) | |
1106 | - | let dF = fl._1 | |
1107 | - | let dG = fl._2 | |
1108 | - | let az = fl._3 | |
1109 | - | let aA = fl._4 | |
1110 | - | let ay = fl._5 | |
1111 | - | let fm = if ((size(aj.payments) == 2)) | |
1112 | - | then if ((aP(aj.payments[0].assetId) != dF)) | |
1113 | - | then throw("Wrong payment asset A") | |
1114 | - | else if ((aP(aj.payments[1].assetId) != dG)) | |
1115 | - | then throw("Wrong payment asset B") | |
1116 | - | else $Tuple4(aj.payments[0].amount, dF, aj.payments[1].amount, dG) | |
1117 | - | else if ((size(aj.payments) == 1)) | |
1118 | - | then if ((aP(aj.payments[0].assetId) == dF)) | |
1119 | - | then $Tuple4(aj.payments[0].amount, dF, 0, dG) | |
1120 | - | else if ((aP(aj.payments[0].assetId) == dG)) | |
1121 | - | then $Tuple4(0, dF, aj.payments[0].amount, dG) | |
1122 | - | else throw("Wrong payment") | |
1123 | - | else throw("One or two payments expected") | |
1124 | - | let bz = fm._1 | |
1125 | - | let fn = fm._2 | |
1126 | - | let bA = fm._3 | |
1127 | - | let fo = fm._4 | |
1128 | - | let fp = aH(toString(aj.caller)) | |
1129 | - | if ((eI > 100)) | |
1130 | - | then { | |
1131 | - | let cB = eH(bz, bA, fn, fo, eI, eJ) | |
1132 | - | let eE = makeString([toString(aj.caller), aF, toString(bz), fn, toString(bA), fo, toString(az), toString(aA), ay, eJ, toString(cB)], ",") | |
1133 | - | let fq = { | |
1134 | - | let av = invoke(this, "createNewRequest", [eE], nil) | |
1135 | - | if ($isInstanceOf(av, "Int")) | |
1136 | - | then av | |
1137 | - | else throw(($getType(av) + " couldn't be cast to Int")) | |
1105 | + | else if (if (!(getBooleanValue(this, (aG + E)))) | |
1106 | + | then (eJ > 100) | |
1107 | + | else false) | |
1108 | + | then throw("You can't borrow in this pool") | |
1109 | + | else { | |
1110 | + | let bi = valueOrErrorMessage(getString(this, (N + aG)), "Pool is not inited") | |
1111 | + | let fm = aC(Address(fromBase58String(aG)), bi) | |
1112 | + | let dG = fm._1 | |
1113 | + | let dH = fm._2 | |
1114 | + | let aA = fm._3 | |
1115 | + | let aB = fm._4 | |
1116 | + | let az = fm._5 | |
1117 | + | let fn = if ((size(ak.payments) == 2)) | |
1118 | + | then if ((aQ(ak.payments[0].assetId) != dG)) | |
1119 | + | then throw("Wrong payment asset A") | |
1120 | + | else if ((aQ(ak.payments[1].assetId) != dH)) | |
1121 | + | then throw("Wrong payment asset B") | |
1122 | + | else $Tuple4(ak.payments[0].amount, dG, ak.payments[1].amount, dH) | |
1123 | + | else if ((size(ak.payments) == 1)) | |
1124 | + | then if ((aQ(ak.payments[0].assetId) == dG)) | |
1125 | + | then $Tuple4(ak.payments[0].amount, dG, 0, dH) | |
1126 | + | else if ((aQ(ak.payments[0].assetId) == dH)) | |
1127 | + | then $Tuple4(0, dG, ak.payments[0].amount, dH) | |
1128 | + | else throw("Wrong payment") | |
1129 | + | else throw("One or two payments expected") | |
1130 | + | let bA = fn._1 | |
1131 | + | let fo = fn._2 | |
1132 | + | let bB = fn._3 | |
1133 | + | let fp = fn._4 | |
1134 | + | let fq = aI(toString(ak.caller)) | |
1135 | + | if ((eJ > 100)) | |
1136 | + | then { | |
1137 | + | let cC = eI(bA, bB, fo, fp, eJ, eK) | |
1138 | + | let eF = makeString([toString(ak.caller), aG, toString(bA), fo, toString(bB), fp, toString(aA), toString(aB), az, eK, toString(cC)], ",") | |
1139 | + | let fr = { | |
1140 | + | let aw = invoke(this, "createNewRequest", [eF], nil) | |
1141 | + | if ($isInstanceOf(aw, "Int")) | |
1142 | + | then aw | |
1143 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
1144 | + | } | |
1145 | + | if ((fr == fr)) | |
1146 | + | then { | |
1147 | + | let fs = [((toString(ak.caller) + "_") + toString(fq)), az, eK, cC, toString(this), "replenishFromLand", toString(valueOrErrorMessage(fr, "Can't create new request"))] | |
1148 | + | let bU = reentrantInvoke(ah(), "flashPosition", fs, nil) | |
1149 | + | if ((bU == bU)) | |
1150 | + | then nil | |
1151 | + | else throw("Strict value is not equal to itself.") | |
1152 | + | } | |
1153 | + | else throw("Strict value is not equal to itself.") | |
1138 | 1154 | } | |
1139 | - | if ((fq == fq)) | |
1140 | - | then { | |
1141 | - | let fr = [((toString(aj.caller) + "_") + toString(fp)), ay, eJ, cB, toString(this), "replenishFromLand", toString(valueOrErrorMessage(fq, "Can't create new request"))] | |
1142 | - | let bT = reentrantInvoke(ag(), "flashPosition", fr, nil) | |
1143 | - | if ((bT == bT)) | |
1144 | - | then nil | |
1145 | - | else throw("Strict value is not equal to itself.") | |
1146 | - | } | |
1147 | - | else throw("Strict value is not equal to itself.") | |
1148 | - | } | |
1149 | - | else { | |
1150 | - | let fs = cM(bh, aF, h, bz, dF, bA, dG, az, aA, ay) | |
1151 | - | let ft = fs._1 | |
1152 | - | let dV = fs._2 | |
1153 | - | (cW(aF, toString(aj.caller), ft, dV, fp, ay, bh, false) ++ bu(dF, dG, ay)) | |
1154 | - | } | |
1155 | - | } | |
1155 | + | else { | |
1156 | + | let ft = cN(bi, aG, h, bA, dG, bB, dH, aA, aB, az) | |
1157 | + | let fu = ft._1 | |
1158 | + | let dW = ft._2 | |
1159 | + | (cX(aG, toString(ak.caller), fu, dW, fq, az, bi, false) ++ bv(dG, dH, az)) | |
1160 | + | } | |
1161 | + | } | |
1156 | 1162 | ||
1157 | 1163 | ||
1158 | 1164 | ||
1159 | - | @Callable( | |
1160 | - | func withdraw ( | |
1165 | + | @Callable(ak) | |
1166 | + | func withdraw (aG,eq) = ev(toString(ak.caller), aG, toString(eq), false) | |
1161 | 1167 | ||
1162 | 1168 | ||
1163 | 1169 | ||
1164 | - | @Callable( | |
1165 | - | func createUpdateStopLoss ( | |
1166 | - | let | |
1167 | - | if ($isInstanceOf( | |
1168 | - | then | |
1169 | - | else throw(($getType( | |
1170 | - | if (!(isDefined(getInteger(this, ((((( | |
1170 | + | @Callable(ak) | |
1171 | + | func createUpdateStopLoss (eq,fv,ao,fw) = { | |
1172 | + | let fx = ( let aw = invoke(ad, "getTWAP60", [ao, false], nil) | |
1173 | + | if ($isInstanceOf(aw, "(Int, Int)")) | |
1174 | + | then aw | |
1175 | + | else throw(($getType(aw) + " couldn't be cast to (Int, Int)")))._1 | |
1176 | + | if (!(isDefined(getInteger(this, (((((fv + "_") + toString(ak.caller)) + "_") + toString(eq)) + u))))) | |
1171 | 1177 | then throw("There are no user position") | |
1172 | - | else if ((0 >= | |
1178 | + | else if ((0 >= fw)) | |
1173 | 1179 | then throw("Price must be greater than 0") | |
1174 | - | else if (( | |
1180 | + | else if ((fw > fx)) | |
1175 | 1181 | then throw("Price must be less than current token price") | |
1176 | - | else [IntegerEntry((((((((toString( | |
1182 | + | else [IntegerEntry((((((((toString(ak.caller) + "_") + toString(eq)) + "_") + fv) + "_") + ao) + R), fw)] | |
1177 | 1183 | } | |
1178 | 1184 | ||
1179 | 1185 | ||
1180 | 1186 | ||
1181 | - | @Callable( | |
1182 | - | func deleteStopLoss ( | |
1187 | + | @Callable(ak) | |
1188 | + | func deleteStopLoss (eq,fv,ao) = if (!(isDefined(getInteger(this, (((((((toString(ak.caller) + "_") + toString(eq)) + "_") + fv) + "_") + ao) + R))))) | |
1183 | 1189 | then throw("No entry") | |
1184 | - | else [DeleteEntry((((((((toString( | |
1190 | + | else [DeleteEntry((((((((toString(ak.caller) + "_") + toString(eq)) + "_") + fv) + "_") + ao) + R))] | |
1185 | 1191 | ||
1186 | 1192 | ||
1187 | 1193 | ||
1188 | - | @Callable( | |
1189 | - | func init ( | |
1194 | + | @Callable(ak) | |
1195 | + | func init (fy,fz,fA,ad,fB,ae,fC,fD,fE) = if (isDefined(getString(S))) | |
1190 | 1196 | then throw("Already inited") | |
1191 | - | else [ | |
1197 | + | else [StringEntry(S, fy), StringEntry(T, fz), StringEntry(U, fA), StringEntry(W, ad), StringEntry(X, fB), StringEntry(Y, ae), StringEntry(Z, fC), StringEntry(aa, fD), StringEntry(V, fE)] | |
1192 | 1198 | ||
1193 | 1199 | ||
1194 | 1200 | ||
1195 | - | @Callable( | |
1196 | - | func createNewRequest ( | |
1197 | - | let | |
1198 | - | $Tuple2([StringEntry((toString( | |
1201 | + | @Callable(ak) | |
1202 | + | func createNewRequest (bT) = valueOrElse(al(ak), { | |
1203 | + | let fr = (valueOrElse(getInteger(this, M), 0) + 1) | |
1204 | + | $Tuple2([StringEntry((toString(fr) + L), bT), IntegerEntry(M, fr)], fr) | |
1199 | 1205 | }) | |
1200 | 1206 | ||
1201 | 1207 | ||
1202 | 1208 | ||
1203 | - | @Callable( | |
1204 | - | func replenishFromLand ( | |
1205 | - | let | |
1206 | - | let | |
1207 | - | let | |
1208 | - | let | |
1209 | - | let | |
1210 | - | let | |
1211 | - | let | |
1212 | - | let | |
1213 | - | let | |
1214 | - | let | |
1215 | - | let | |
1216 | - | let | |
1217 | - | if ((size( | |
1209 | + | @Callable(ak) | |
1210 | + | func replenishFromLand (eE) = valueOrElse(am(ak), { | |
1211 | + | let fF = eD(eE) | |
1212 | + | let aJ = fF._1 | |
1213 | + | let aG = fF._2 | |
1214 | + | let bA = fF._3 | |
1215 | + | let dG = fF._4 | |
1216 | + | let bB = fF._5 | |
1217 | + | let dH = fF._6 | |
1218 | + | let aA = fF._7 | |
1219 | + | let aB = fF._8 | |
1220 | + | let az = fF._9 | |
1221 | + | let eG = fF._10 | |
1222 | + | let eH = fF._11 | |
1223 | + | if ((size(ak.payments) != 1)) | |
1218 | 1224 | then throw("Wrong payment size") | |
1219 | - | else if (if (( | |
1225 | + | else if (if ((aQ(ak.payments[0].assetId) != eG)) | |
1220 | 1226 | then true | |
1221 | - | else ( | |
1227 | + | else (ak.payments[0].amount != eH)) | |
1222 | 1228 | then throw("Wrong payment") | |
1223 | 1229 | else { | |
1224 | - | let | |
1225 | - | then $Tuple2(( | |
1226 | - | else $Tuple2( | |
1227 | - | let | |
1228 | - | let | |
1229 | - | let | |
1230 | - | let | |
1231 | - | let | |
1232 | - | let | |
1233 | - | let | |
1234 | - | let | |
1235 | - | let | |
1236 | - | $Tuple2(((( | |
1230 | + | let fG = if ((dG == eG)) | |
1231 | + | then $Tuple2((bA + ak.payments[0].amount), bB) | |
1232 | + | else $Tuple2(bA, (bB + ak.payments[0].amount)) | |
1233 | + | let fH = fG._1 | |
1234 | + | let fI = fG._2 | |
1235 | + | let bi = valueOrErrorMessage(getString(this, (N + aG)), "Unknown pool") | |
1236 | + | let fJ = cN(bi, aG, g, fH, dG, fI, dH, aA, aB, az) | |
1237 | + | let fu = fJ._1 | |
1238 | + | let dW = fJ._2 | |
1239 | + | let cZ = aI(aJ) | |
1240 | + | let fK = [IntegerEntry((((((aG + "_") + aJ) + "_") + toString(cZ)) + w), eH), StringEntry((((((aG + "_") + aJ) + "_") + toString(cZ)) + x), eG)] | |
1241 | + | let fL = cX(aG, aJ, fu, dW, cZ, az, bi, true) | |
1242 | + | $Tuple2((((fL ++ bv(dG, dH, az)) ++ fK) :+ DeleteEntry((eE + L))), fu) | |
1237 | 1243 | } | |
1238 | 1244 | }) | |
1239 | 1245 | ||
1240 | 1246 | ||
1241 | 1247 | ||
1242 | - | @Callable( | |
1243 | - | func liquidate ( | |
1244 | - | let | |
1245 | - | let | |
1246 | - | let | |
1247 | - | let | |
1248 | - | let | |
1249 | - | let | |
1250 | - | let | |
1251 | - | let | |
1252 | - | let | |
1253 | - | let | |
1254 | - | let | |
1255 | - | let | |
1256 | - | if (( | |
1248 | + | @Callable(ak) | |
1249 | + | func liquidate (aJ,eq,fM) = valueOrElse(am(ak), { | |
1250 | + | let aG = valueOrErrorMessage(getString(this, (((aJ + "_") + eq) + v)), "no position") | |
1251 | + | let bi = valueOrErrorMessage(getString(this, (N + aG)), "Pool is not inited") | |
1252 | + | let fN = aC(Address(fromBase58String(aG)), bi) | |
1253 | + | let dG = fN._1 | |
1254 | + | let dH = fN._2 | |
1255 | + | let aA = fN._3 | |
1256 | + | let aB = fN._4 | |
1257 | + | let az = fN._5 | |
1258 | + | let bO = bP(aG, bi, az, fM) | |
1259 | + | let cC = getIntegerValue(this, (((((aG + "_") + aJ) + "_") + eq) + w)) | |
1260 | + | let ea = getStringValue(this, (((((aG + "_") + aJ) + "_") + eq) + x)) | |
1261 | + | let dY = ep(aJ, aG, eq, (cC > 0)) | |
1262 | + | if ((cC == 0)) | |
1257 | 1263 | then throw("You can't liquidate position without borrow") | |
1258 | - | else [IntegerEntry(((((( | |
1264 | + | else [IntegerEntry((((((aG + "_") + aJ) + "_") + eq) + z), getIntegerValue(this, (aG + C))), IntegerEntry((aG + B), (aH(aG) - fM)), IntegerEntry((aG + A), (aF(aG) - fM)), IntegerEntry((((((aG + "_") + aJ) + "_") + eq) + u), (dY - fM)), ScriptTransfer(ak.caller, bO, fromBase58String(az))] | |
1259 | 1265 | }) | |
1260 | 1266 | ||
1261 | 1267 | ||
1262 | 1268 | ||
1263 | - | @Callable( | |
1264 | - | func stopLoss ( | |
1265 | - | let | |
1266 | - | if ($isInstanceOf( | |
1267 | - | then | |
1268 | - | else throw(($getType( | |
1269 | - | if (!(isDefined(getInteger(this, ((((((( | |
1269 | + | @Callable(ak) | |
1270 | + | func stopLoss (aJ,eq,aG,ao) = valueOrElse(aj(ak), { | |
1271 | + | let fx = ( let aw = invoke(ad, "getTWAP60", [ao, false], nil) | |
1272 | + | if ($isInstanceOf(aw, "(Int, Int)")) | |
1273 | + | then aw | |
1274 | + | else throw(($getType(aw) + " couldn't be cast to (Int, Int)")))._1 | |
1275 | + | if (!(isDefined(getInteger(this, (((((((aJ + "_") + toString(eq)) + "_") + aG) + "_") + ao) + R))))) | |
1270 | 1276 | then throw("No entry") | |
1271 | - | else ( | |
1277 | + | else (ev(toString(ak.caller), aG, toString(eq), true) :+ DeleteEntry((((((((aJ + "_") + toString(eq)) + "_") + aG) + "_") + ao) + R))) | |
1272 | 1278 | }) | |
1273 | 1279 | ||
1274 | 1280 | ||
1275 | 1281 | ||
1276 | - | @Callable( | |
1277 | - | func capitalizeExKeeper ( | |
1278 | - | let | |
1279 | - | then | |
1282 | + | @Callable(ak) | |
1283 | + | func capitalizeExKeeper (aG,aD,fO,fP,fQ,dk,dl,dm,dn,do,dp,dq) = valueOrElse(aj(ak), { | |
1284 | + | let fR = if (fQ) | |
1285 | + | then cK(aD, aG) | |
1280 | 1286 | else { | |
1281 | - | let | |
1282 | - | then | |
1283 | - | else | |
1284 | - | $Tuple2( | |
1287 | + | let fS = if ((aD == a)) | |
1288 | + | then af | |
1289 | + | else ag | |
1290 | + | $Tuple2(fP, fS) | |
1285 | 1291 | } | |
1286 | - | let | |
1287 | - | let | |
1288 | - | let | |
1289 | - | let | |
1290 | - | let | |
1291 | - | then [IntegerEntry(( | |
1292 | + | let fT = fR._1 | |
1293 | + | let fS = fR._2 | |
1294 | + | let fU = dg(fO, fP, fS, dk, dl, dm, dn, do, dp, dq) | |
1295 | + | let cu = (fT - fP) | |
1296 | + | let fV = if ((cu > 0)) | |
1297 | + | then [IntegerEntry((aG + P), (cu + valueOrElse(getInteger(this, (aG + P)), 0)))] | |
1292 | 1298 | else nil | |
1293 | - | ( | |
1299 | + | (dC(aG, aD, fO, fU) ++ fV) | |
1294 | 1300 | }) | |
1295 | 1301 | ||
1296 | 1302 | ||
1297 | 1303 | ||
1298 | - | @Callable( | |
1299 | - | func capitalizeExPuzzle ( | |
1300 | - | let | |
1301 | - | then | |
1304 | + | @Callable(ak) | |
1305 | + | func capitalizeExPuzzle (aG,aD,fO,fP,fQ,dt,du,dq) = valueOrElse(aj(ak), { | |
1306 | + | let fW = if (fQ) | |
1307 | + | then cK(aD, aG) | |
1302 | 1308 | else { | |
1303 | - | let | |
1304 | - | then | |
1305 | - | else | |
1306 | - | $Tuple2( | |
1309 | + | let fS = if ((aD == a)) | |
1310 | + | then af | |
1311 | + | else ag | |
1312 | + | $Tuple2(fP, fS) | |
1307 | 1313 | } | |
1308 | - | let | |
1309 | - | let | |
1310 | - | let | |
1311 | - | let | |
1312 | - | let | |
1313 | - | then [IntegerEntry(( | |
1314 | + | let fT = fW._1 | |
1315 | + | let fS = fW._2 | |
1316 | + | let fU = ds(fO, fP, fS, dt, du, dq) | |
1317 | + | let cu = (fT - fP) | |
1318 | + | let fV = if ((cu > 0)) | |
1319 | + | then [IntegerEntry((aG + P), (cu + valueOrElse(getInteger(this, (aG + P)), 0)))] | |
1314 | 1320 | else nil | |
1315 | - | ( | |
1321 | + | (dC(aG, aD, fO, fU) ++ fV) | |
1316 | 1322 | }) | |
1317 | 1323 | ||
1318 | 1324 | ||
1319 | 1325 | ||
1320 | - | @Callable( | |
1321 | - | func capitalizeExSwopFi ( | |
1322 | - | let | |
1323 | - | then | |
1326 | + | @Callable(ak) | |
1327 | + | func capitalizeExSwopFi (aG,aD,fO,fP,fQ,dw,dx,dy,dz,dA,dB,dq) = valueOrElse(aj(ak), { | |
1328 | + | let fX = if (fQ) | |
1329 | + | then cK(aD, aG) | |
1324 | 1330 | else { | |
1325 | - | let | |
1326 | - | then | |
1327 | - | else | |
1328 | - | $Tuple2( | |
1331 | + | let fS = if ((aD == a)) | |
1332 | + | then af | |
1333 | + | else ag | |
1334 | + | $Tuple2(fP, fS) | |
1329 | 1335 | } | |
1330 | - | let | |
1331 | - | let | |
1332 | - | let | |
1333 | - | let | |
1334 | - | let | |
1335 | - | then [IntegerEntry(( | |
1336 | + | let fT = fX._1 | |
1337 | + | let fS = fX._2 | |
1338 | + | let fU = dv(fO, fP, fS, dw, dx, dy, dz, dA, dB, dq) | |
1339 | + | let cu = (fT - fP) | |
1340 | + | let fV = if ((cu > 0)) | |
1341 | + | then [IntegerEntry((aG + P), (cu + valueOrElse(getInteger(this, (aG + P)), 0)))] | |
1336 | 1342 | else nil | |
1337 | - | ( | |
1343 | + | (dC(aG, aD, fO, fU) ++ fV) | |
1338 | 1344 | }) | |
1339 | 1345 | ||
1340 | 1346 | ||
1341 | 1347 | ||
1342 | - | @Callable( | |
1343 | - | func initNewPool ( | |
1344 | - | then ( | |
1348 | + | @Callable(ak) | |
1349 | + | func initNewPool (aD,at,fY,fZ,ga,gb,gc,gd,ge) = valueOrElse(aj(ak), if (if ((aD != a)) | |
1350 | + | then (aD != b) | |
1345 | 1351 | else false) | |
1346 | 1352 | then throw("Wrong type") | |
1347 | 1353 | else { | |
1348 | - | let | |
1349 | - | let | |
1350 | - | let | |
1351 | - | let | |
1352 | - | let | |
1353 | - | let | |
1354 | - | [IntegerEntry(( | |
1354 | + | let gf = aC(Address(fromBase58String(at)), aD) | |
1355 | + | let ax = gf._1 | |
1356 | + | let ay = gf._2 | |
1357 | + | let gg = gf._3 | |
1358 | + | let gh = gf._4 | |
1359 | + | let az = gf._5 | |
1360 | + | [IntegerEntry((at + F), fY), IntegerEntry((at + G), fZ), IntegerEntry((at + H), ga), IntegerEntry((at + I), gb), IntegerEntry((at + J), gc), IntegerEntry((at + K), gd), IntegerEntry((at + C), 0), IntegerEntry((at + D), 0), StringEntry((N + at), aD), StringEntry((az + O), at), BooleanEntry((at + E), ge)] | |
1355 | 1361 | }) | |
1356 | 1362 | ||
1357 | 1363 | ||
1358 | - | @Verifier( | |
1359 | - | func | |
1364 | + | @Verifier(gi) | |
1365 | + | func gj () = sigVerify(gi.bodyBytes, gi.proofs[0], gi.senderPublicKey) | |
1360 | 1366 |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let a = "SF" | |
5 | 5 | ||
6 | 6 | let b = "WX" | |
7 | 7 | ||
8 | 8 | let c = "capNoLoan" | |
9 | 9 | ||
10 | 10 | let d = "capLoan" | |
11 | 11 | ||
12 | 12 | let e = "stopLossNoLoan" | |
13 | 13 | ||
14 | 14 | let f = "stopLossLoan" | |
15 | 15 | ||
16 | 16 | let g = "loan" | |
17 | 17 | ||
18 | 18 | let h = "noLoan" | |
19 | 19 | ||
20 | 20 | let i = "noFee" | |
21 | 21 | ||
22 | 22 | let j = 100000000 | |
23 | 23 | ||
24 | 24 | let k = 10000000000 | |
25 | 25 | ||
26 | 26 | let l = toBigInt(10000000000000000) | |
27 | 27 | ||
28 | 28 | let m = 1000000 | |
29 | 29 | ||
30 | 30 | let n = "A_asset_balance" | |
31 | 31 | ||
32 | 32 | let o = "B_asset_balance" | |
33 | 33 | ||
34 | 34 | let p = "A_asset_id" | |
35 | 35 | ||
36 | 36 | let q = "B_asset_id" | |
37 | 37 | ||
38 | 38 | let r = "share_asset_id" | |
39 | 39 | ||
40 | 40 | let s = "share_asset_supply" | |
41 | 41 | ||
42 | 42 | let t = "commission" | |
43 | 43 | ||
44 | 44 | let u = "_user_position" | |
45 | 45 | ||
46 | 46 | let v = "_user_position_pool" | |
47 | 47 | ||
48 | 48 | let w = "_user_position_borrow_amount" | |
49 | 49 | ||
50 | 50 | let x = "_user_position_borrow_asset_id" | |
51 | 51 | ||
52 | 52 | let y = "_user_position_number" | |
53 | 53 | ||
54 | 54 | let z = "_user_position_interest" | |
55 | 55 | ||
56 | 56 | let A = "_pool_total" | |
57 | 57 | ||
58 | 58 | let B = "_pool_total_loan" | |
59 | 59 | ||
60 | 60 | let C = "_pool_interest_loan" | |
61 | 61 | ||
62 | 62 | let D = "_pool_interest_no_loan" | |
63 | 63 | ||
64 | - | let E = "_ | |
64 | + | let E = "_pool_can_borrow" | |
65 | 65 | ||
66 | - | let F = "_axly_fee_ | |
66 | + | let F = "_axly_fee_without_loan" | |
67 | 67 | ||
68 | - | let G = "_axly_fee_ | |
68 | + | let G = "_axly_fee_with_loan" | |
69 | 69 | ||
70 | - | let H = "_axly_fee_cap_ | |
70 | + | let H = "_axly_fee_cap_with_loan" | |
71 | 71 | ||
72 | - | let I = "_axly_fee_ | |
72 | + | let I = "_axly_fee_cap_no_loan" | |
73 | 73 | ||
74 | - | let J = "_axly_fee_stoploss_ | |
74 | + | let J = "_axly_fee_stoploss_with_loan" | |
75 | 75 | ||
76 | - | let K = "_ | |
76 | + | let K = "_axly_fee_stoploss_no_loan" | |
77 | 77 | ||
78 | - | let L = " | |
78 | + | let L = "_request_id" | |
79 | 79 | ||
80 | - | let M = " | |
80 | + | let M = "requests_iter" | |
81 | 81 | ||
82 | - | let N = " | |
82 | + | let N = "pool_" | |
83 | 83 | ||
84 | - | let O = "_pool_ | |
84 | + | let O = "_pool_share_id" | |
85 | 85 | ||
86 | - | let P = " | |
86 | + | let P = "_pool_cap_change" | |
87 | 87 | ||
88 | - | let Q = "_ | |
88 | + | let Q = "last_price" | |
89 | 89 | ||
90 | - | let R = " | |
90 | + | let R = "_stop_loss" | |
91 | 91 | ||
92 | - | let S = " | |
92 | + | let S = "axly_money_box" | |
93 | 93 | ||
94 | - | let T = " | |
94 | + | let T = "swopfi_farming_addr" | |
95 | 95 | ||
96 | - | let U = " | |
96 | + | let U = "lend_service_addr" | |
97 | 97 | ||
98 | - | let V = " | |
98 | + | let V = "admin_call_pub_key" | |
99 | 99 | ||
100 | - | let W = " | |
100 | + | let W = "price_oracle" | |
101 | 101 | ||
102 | - | let X = " | |
102 | + | let X = "exchange_contract" | |
103 | 103 | ||
104 | - | let Y = " | |
104 | + | let Y = "wx_swap_contract" | |
105 | 105 | ||
106 | - | let Z = " | |
106 | + | let Z = "swop_id" | |
107 | 107 | ||
108 | - | let aa = | |
108 | + | let aa = "wx_id" | |
109 | 109 | ||
110 | - | let ab = Address(fromBase58String(valueOrErrorMessage(getString(this, | |
110 | + | let ab = Address(fromBase58String(valueOrErrorMessage(getString(this, S), "No axly moneyBox address"))) | |
111 | 111 | ||
112 | - | let ac = Address(fromBase58String(valueOrErrorMessage(getString(this, | |
112 | + | let ac = Address(fromBase58String(valueOrErrorMessage(getString(this, X), "No exchange contract address"))) | |
113 | 113 | ||
114 | - | let ad = Address(fromBase58String(valueOrErrorMessage(getString(this, | |
114 | + | let ad = Address(fromBase58String(valueOrErrorMessage(getString(this, W), "No price oracle address"))) | |
115 | 115 | ||
116 | - | let ae = fromBase58String(valueOrErrorMessage(getString(this, Y), "No | |
116 | + | let ae = Address(fromBase58String(valueOrErrorMessage(getString(this, Y), "No wx swap address"))) | |
117 | 117 | ||
118 | - | let af = fromBase58String(valueOrErrorMessage(getString(this, Z), "No | |
118 | + | let af = fromBase58String(valueOrErrorMessage(getString(this, Z), "No swop id")) | |
119 | 119 | ||
120 | - | func ag () = Address(fromBase58String(valueOrErrorMessage(getString(this, T), "Can't get lend service addr"))) | |
120 | + | let ag = fromBase58String(valueOrErrorMessage(getString(this, aa), "No wx id")) | |
121 | + | ||
122 | + | func ah () = Address(fromBase58String(valueOrErrorMessage(getString(this, U), "Can't get lend service addr"))) | |
121 | 123 | ||
122 | 124 | ||
123 | - | func | |
125 | + | func ai () = addressFromPublicKey(fromBase58String(valueOrErrorMessage(getString(this, V), "Can't get admin addr"))) | |
124 | 126 | ||
125 | 127 | ||
126 | - | func | |
128 | + | func aj (ak) = if ((ak.caller == ai())) | |
127 | 129 | then unit | |
128 | 130 | else throw("Only admin can call this function") | |
129 | 131 | ||
130 | 132 | ||
131 | - | func | |
133 | + | func al (ak) = if ((ak.caller == this)) | |
132 | 134 | then unit | |
133 | 135 | else throw("Only contract itself can call this function") | |
134 | 136 | ||
135 | 137 | ||
136 | - | func | |
138 | + | func am (ak) = if ((ak.caller == ah())) | |
137 | 139 | then unit | |
138 | 140 | else throw("Only land contract can call this function") | |
139 | 141 | ||
140 | 142 | ||
141 | - | func | |
142 | - | let | |
143 | - | if ($isInstanceOf( | |
143 | + | func an (ao) = { | |
144 | + | let ap = ao | |
145 | + | if ($isInstanceOf(ap, "ByteVector")) | |
144 | 146 | then { | |
145 | - | let | |
146 | - | assetBalance(this, | |
147 | + | let aq = ap | |
148 | + | assetBalance(this, aq) | |
147 | 149 | } | |
148 | - | else if ($isInstanceOf( | |
150 | + | else if ($isInstanceOf(ap, "Unit")) | |
149 | 151 | then { | |
150 | - | let | |
152 | + | let ar = ap | |
151 | 153 | wavesBalance(this).available | |
152 | 154 | } | |
153 | 155 | else throw("Match error") | |
154 | 156 | } | |
155 | 157 | ||
156 | 158 | ||
157 | - | func | |
159 | + | func as (at) = $Tuple5(valueOrErrorMessage(getString(at, p), "Can't get pool A asset id"), valueOrErrorMessage(getString(at, q), "Can't get pool B asset id"), valueOrErrorMessage(getInteger(at, n), "Can't get pool A asset balance"), valueOrErrorMessage(getInteger(at, o), "Can't get pool B asset balance"), valueOrErrorMessage(getString(at, r), "Can't get share asset id")) | |
158 | 160 | ||
159 | 161 | ||
160 | - | func | |
161 | - | let | |
162 | - | let | |
163 | - | if ($isInstanceOf( | |
164 | - | then | |
165 | - | else throw(($getType( | |
162 | + | func au (at) = { | |
163 | + | let av = { | |
164 | + | let aw = invoke(at, "getPoolConfigWrapperREADONLY", nil, nil) | |
165 | + | if ($isInstanceOf(aw, "List[Any]")) | |
166 | + | then aw | |
167 | + | else throw(($getType(aw) + " couldn't be cast to List[Any]")) | |
166 | 168 | } | |
167 | - | if (( | |
169 | + | if ((av == av)) | |
168 | 170 | then { | |
169 | - | let | |
170 | - | let | |
171 | - | if ($isInstanceOf( | |
172 | - | then | |
171 | + | let ax = valueOrErrorMessage({ | |
172 | + | let aw = av[4] | |
173 | + | if ($isInstanceOf(aw, "String")) | |
174 | + | then aw | |
173 | 175 | else unit | |
174 | 176 | }, "Can't get pool A asset id") | |
175 | - | let | |
176 | - | let | |
177 | - | if ($isInstanceOf( | |
178 | - | then | |
177 | + | let ay = valueOrErrorMessage({ | |
178 | + | let aw = av[5] | |
179 | + | if ($isInstanceOf(aw, "String")) | |
180 | + | then aw | |
179 | 181 | else unit | |
180 | 182 | }, "Can't get pool B asset id") | |
181 | - | let | |
182 | - | let | |
183 | - | if ($isInstanceOf( | |
184 | - | then | |
183 | + | let az = valueOrErrorMessage({ | |
184 | + | let aw = av[3] | |
185 | + | if ($isInstanceOf(aw, "String")) | |
186 | + | then aw | |
185 | 187 | else unit | |
186 | 188 | }, "Can't get pool LP asset id") | |
187 | - | let | |
188 | - | let | |
189 | - | if ($isInstanceOf( | |
190 | - | then | |
191 | - | else throw(($getType( | |
189 | + | let aA = { | |
190 | + | let aw = invoke(at, "getAccBalanceWrapperREADONLY", [ax], nil) | |
191 | + | if ($isInstanceOf(aw, "Int")) | |
192 | + | then aw | |
193 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
192 | 194 | } | |
193 | - | if (( | |
195 | + | if ((aA == aA)) | |
194 | 196 | then { | |
195 | - | let | |
196 | - | let | |
197 | - | if ($isInstanceOf( | |
198 | - | then | |
199 | - | else throw(($getType( | |
197 | + | let aB = { | |
198 | + | let aw = invoke(at, "getAccBalanceWrapperREADONLY", [ay], nil) | |
199 | + | if ($isInstanceOf(aw, "Int")) | |
200 | + | then aw | |
201 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
200 | 202 | } | |
201 | - | if (( | |
202 | - | then $Tuple5( | |
203 | + | if ((aB == aB)) | |
204 | + | then $Tuple5(ax, ay, aA, aB, az) | |
203 | 205 | else throw("Strict value is not equal to itself.") | |
204 | 206 | } | |
205 | 207 | else throw("Strict value is not equal to itself.") | |
206 | 208 | } | |
207 | 209 | else throw("Strict value is not equal to itself.") | |
208 | 210 | } | |
209 | 211 | ||
210 | 212 | ||
211 | - | func | |
212 | - | then | |
213 | - | else if (( | |
214 | - | then at | |
213 | + | func aC (at,aD) = if ((aD == a)) | |
214 | + | then as(at) | |
215 | + | else if ((aD == b)) | |
216 | + | then au(at) | |
215 | 217 | else throw("Wrong pool type") | |
216 | 218 | ||
217 | 219 | ||
218 | - | func | |
219 | - | then valueOrErrorMessage(getInteger( | |
220 | - | else if (( | |
221 | - | then valueOrErrorMessage(assetInfo(fromBase58String( | |
220 | + | func aE (at,aD,az) = if ((aD == a)) | |
221 | + | then valueOrErrorMessage(getInteger(at, s), "Can't get share asset supply") | |
222 | + | else if ((aD == b)) | |
223 | + | then valueOrErrorMessage(assetInfo(fromBase58String(az)), "Wrong ShareId").quantity | |
222 | 224 | else throw("Wrong pool type") | |
223 | 225 | ||
224 | 226 | ||
225 | - | func | |
227 | + | func aF (aG) = valueOrElse(getInteger(this, (aG + A)), 0) | |
226 | 228 | ||
227 | 229 | ||
228 | - | func | |
230 | + | func aH (aG) = valueOrElse(getInteger(this, (aG + B)), 0) | |
229 | 231 | ||
230 | 232 | ||
231 | - | func | |
233 | + | func aI (aJ) = (valueOrElse(getInteger(this, (aJ + y)), 0) + 1) | |
232 | 234 | ||
233 | 235 | ||
234 | - | func | |
235 | - | then getIntegerValue(this, ( | |
236 | - | else if (( | |
237 | - | then getIntegerValue(this, ( | |
238 | - | else if (( | |
239 | - | then getIntegerValue(this, ( | |
240 | - | else if (( | |
241 | - | then getIntegerValue(this, ( | |
242 | - | else if (( | |
236 | + | func aK (aG,aL) = if ((aL == d)) | |
237 | + | then getIntegerValue(this, (aG + I)) | |
238 | + | else if ((aL == c)) | |
239 | + | then getIntegerValue(this, (aG + H)) | |
240 | + | else if ((aL == g)) | |
241 | + | then getIntegerValue(this, (aG + G)) | |
242 | + | else if ((aL == h)) | |
243 | + | then getIntegerValue(this, (aG + F)) | |
244 | + | else if ((aL == i)) | |
243 | 245 | then 0 | |
244 | 246 | else throw("Wrong fee type") | |
245 | 247 | ||
246 | 248 | ||
247 | - | func | |
249 | + | func aM () = Address(fromBase58String(valueOrErrorMessage(getString(this, T), "Can't get swopfi farming addr"))) | |
248 | 250 | ||
249 | 251 | ||
250 | - | func | |
251 | - | let | |
252 | - | let | |
253 | - | Address(fromBase58String( | |
252 | + | func aN (at) = { | |
253 | + | let aO = Address(fromBase58String(valueOrErrorMessage(getString(at, "%s__factoryContract"), "Can't get WX factory contract addr"))) | |
254 | + | let aP = split(valueOrErrorMessage(getString(aO, "%s__factoryConfig"), "Can't get WX factory cfg"), "__") | |
255 | + | Address(fromBase58String(aP[1])) | |
254 | 256 | } | |
255 | 257 | ||
256 | 258 | ||
257 | - | func | |
258 | - | let | |
259 | - | if ($isInstanceOf( | |
259 | + | func aQ (ao) = { | |
260 | + | let ap = ao | |
261 | + | if ($isInstanceOf(ap, "ByteVector")) | |
260 | 262 | then { | |
261 | - | let | |
262 | - | toBase58String( | |
263 | + | let aq = ap | |
264 | + | toBase58String(aq) | |
263 | 265 | } | |
264 | - | else if ($isInstanceOf( | |
266 | + | else if ($isInstanceOf(ap, "Unit")) | |
265 | 267 | then { | |
266 | - | let | |
268 | + | let ar = ap | |
267 | 269 | "WAVES" | |
268 | 270 | } | |
269 | 271 | else throw("Not Asset id") | |
270 | 272 | } | |
271 | 273 | ||
272 | 274 | ||
273 | - | func | |
275 | + | func aR (ao) = if ((ao == "WAVES")) | |
274 | 276 | then unit | |
275 | - | else fromBase58String( | |
277 | + | else fromBase58String(ao) | |
276 | 278 | ||
277 | 279 | ||
278 | - | func | |
280 | + | func aS (ao) = if ((ao == "WAVES")) | |
279 | 281 | then 8 | |
280 | 282 | else { | |
281 | - | let | |
282 | - | if ($isInstanceOf( | |
283 | + | let ap = assetInfo(fromBase58String(ao)) | |
284 | + | if ($isInstanceOf(ap, "Asset")) | |
283 | 285 | then { | |
284 | - | let | |
285 | - | | |
286 | + | let aT = ap | |
287 | + | aT.decimals | |
286 | 288 | } | |
287 | 289 | else throw("Can't find asset") | |
288 | 290 | } | |
289 | 291 | ||
290 | 292 | ||
291 | - | func | |
293 | + | func aU (ao) = pow(10, 0, aS(ao), 0, 0, DOWN) | |
292 | 294 | ||
293 | 295 | ||
294 | - | func | |
295 | - | func | |
296 | - | let | |
297 | - | if ($isInstanceOf( | |
298 | - | then | |
299 | - | else throw(($getType( | |
300 | - | ( | |
296 | + | func aV (aW) = { | |
297 | + | func aX (aY,ao) = { | |
298 | + | let aZ = ( let aw = invoke(ad, "getTWAP60", [ao, false], nil) | |
299 | + | if ($isInstanceOf(aw, "(Int, Int)")) | |
300 | + | then aw | |
301 | + | else throw(($getType(aw) + " couldn't be cast to (Int, Int)")))._2 | |
302 | + | (aY :+ aZ) | |
301 | 303 | } | |
302 | 304 | ||
303 | - | let | |
304 | - | let | |
305 | - | let | |
306 | - | func | |
307 | - | then | |
308 | - | else | |
305 | + | let ba = aW | |
306 | + | let bb = size(ba) | |
307 | + | let bc = nil | |
308 | + | func bd (be,bf) = if ((bf >= bb)) | |
309 | + | then be | |
310 | + | else aX(be, ba[bf]) | |
309 | 311 | ||
310 | - | func | |
311 | - | then | |
312 | + | func bg (be,bf) = if ((bf >= bb)) | |
313 | + | then be | |
312 | 314 | else throw("List size exceeds 50") | |
313 | 315 | ||
314 | - | | |
316 | + | bg(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bc, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20), 21), 22), 23), 24), 25), 26), 27), 28), 29), 30), 31), 32), 33), 34), 35), 36), 37), 38), 39), 40), 41), 42), 43), 44), 45), 46), 47), 48), 49), 50) | |
315 | 317 | } | |
316 | 318 | ||
317 | 319 | ||
318 | - | func | |
319 | - | let | |
320 | - | let | |
321 | - | let | |
322 | - | let | |
323 | - | let | |
324 | - | let | |
325 | - | let | |
326 | - | let | |
327 | - | let | |
328 | - | if ($isInstanceOf( | |
329 | - | then | |
330 | - | else throw(($getType( | |
331 | - | let | |
332 | - | if ($isInstanceOf( | |
333 | - | then | |
334 | - | else throw(($getType( | |
335 | - | let | |
336 | - | let | |
337 | - | let | |
338 | - | let | |
339 | - | let | |
340 | - | fraction(br, | |
320 | + | func bh (az) = { | |
321 | + | let aG = valueOrErrorMessage(getString(this, (az + O)), "Can't find pool addr by share id") | |
322 | + | let at = Address(fromBase58String(aG)) | |
323 | + | let bi = valueOrErrorMessage(getString(this, (N + aG)), "Pool is not inited") | |
324 | + | let bj = aC(at, bi) | |
325 | + | let ax = bj._1 | |
326 | + | let ay = bj._2 | |
327 | + | let bk = bj._3 | |
328 | + | let bl = bj._4 | |
329 | + | let bm = ( let aw = invoke(ad, "getTWAP60", [ax, false], nil) | |
330 | + | if ($isInstanceOf(aw, "(Int, Int)")) | |
331 | + | then aw | |
332 | + | else throw(($getType(aw) + " couldn't be cast to (Int, Int)")))._2 | |
333 | + | let bn = ( let aw = invoke(ad, "getTWAP60", [ay, false], nil) | |
334 | + | if ($isInstanceOf(aw, "(Int, Int)")) | |
335 | + | then aw | |
336 | + | else throw(($getType(aw) + " couldn't be cast to (Int, Int)")))._2 | |
337 | + | let bo = aE(at, bi, az) | |
338 | + | let bp = pow(10, 0, aS(ax), 0, 0, DOWN) | |
339 | + | let bq = pow(10, 0, aS(ay), 0, 0, DOWN) | |
340 | + | let br = pow(10, 0, aS(az), 0, 0, DOWN) | |
341 | + | let bs = (fraction(bk, bm, bp) + fraction(bl, bn, bq)) | |
342 | + | fraction(bs, br, bo) | |
341 | 343 | } | |
342 | 344 | ||
343 | 345 | ||
344 | - | func | |
345 | - | func | |
346 | + | func bt (bu) = { | |
347 | + | func aX (aY,az) = (aY :+ bh(az)) | |
346 | 348 | ||
347 | - | let | |
348 | - | let | |
349 | - | let | |
350 | - | func | |
351 | - | then | |
352 | - | else | |
349 | + | let ba = bu | |
350 | + | let bb = size(ba) | |
351 | + | let bc = nil | |
352 | + | func bd (be,bf) = if ((bf >= bb)) | |
353 | + | then be | |
354 | + | else aX(be, ba[bf]) | |
353 | 355 | ||
354 | - | func | |
355 | - | then | |
356 | + | func bg (be,bf) = if ((bf >= bb)) | |
357 | + | then be | |
356 | 358 | else throw("List size exceeds 20") | |
357 | 359 | ||
358 | - | | |
360 | + | bg(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bc, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20) | |
359 | 361 | } | |
360 | 362 | ||
361 | 363 | ||
362 | - | func | |
363 | - | let | |
364 | - | let | |
365 | - | let | |
366 | - | [StringEntry( | |
364 | + | func bv (ax,ay,az) = { | |
365 | + | let bw = aV([ax, ay]) | |
366 | + | let bx = bh(az) | |
367 | + | let by = [toString(bw[0]), toString(bw[1]), toString(bx)] | |
368 | + | [StringEntry(Q, makeString(by, ","))] | |
367 | 369 | } | |
368 | 370 | ||
369 | 371 | ||
370 | - | func | |
372 | + | func bz (bi,at,bA,ax,bB,ay,aA,aB) = if ((bi == a)) | |
371 | 373 | then { | |
372 | - | let | |
373 | - | let | |
374 | - | if ($isInstanceOf( | |
375 | - | then | |
376 | - | else throw(($getType( | |
374 | + | let bC = { | |
375 | + | let aw = invoke(at, "callFunction", ["calcLPReplenishTwoTokensREADONLY", [toString(bA), toString(bB)]], nil) | |
376 | + | if ($isInstanceOf(aw, "List[Any]")) | |
377 | + | then aw | |
378 | + | else throw(($getType(aw) + " couldn't be cast to List[Any]")) | |
377 | 379 | } | |
378 | - | if (( | |
380 | + | if ((bC == bC)) | |
379 | 381 | then $Tuple5({ | |
380 | - | let | |
381 | - | if ($isInstanceOf( | |
382 | - | then | |
383 | - | else throw(($getType( | |
382 | + | let aw = bC[3] | |
383 | + | if ($isInstanceOf(aw, "Int")) | |
384 | + | then aw | |
385 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
384 | 386 | }, { | |
385 | - | let | |
386 | - | if ($isInstanceOf( | |
387 | - | then | |
388 | - | else throw(($getType( | |
387 | + | let aw = bC[4] | |
388 | + | if ($isInstanceOf(aw, "Int")) | |
389 | + | then aw | |
390 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
389 | 391 | }, { | |
390 | - | let | |
391 | - | if ($isInstanceOf( | |
392 | - | then | |
393 | - | else throw(($getType( | |
394 | - | }, | |
395 | - | let | |
396 | - | if ($isInstanceOf( | |
397 | - | then | |
398 | - | else throw(($getType( | |
392 | + | let aw = bC[1] | |
393 | + | if ($isInstanceOf(aw, "Int")) | |
394 | + | then aw | |
395 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
396 | + | }, aQ(bC[2]), { | |
397 | + | let aw = bC[0] | |
398 | + | if ($isInstanceOf(aw, "Int")) | |
399 | + | then aw | |
400 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
399 | 401 | }) | |
400 | 402 | else throw("Strict value is not equal to itself.") | |
401 | 403 | } | |
402 | 404 | else { | |
403 | - | let | |
404 | - | let | |
405 | - | if ($isInstanceOf( | |
406 | - | then | |
407 | - | else throw(($getType( | |
405 | + | let bD = $Tuple2(split({ | |
406 | + | let aw = invoke(at, "evaluatePutByAmountAssetREADONLY", [bA], nil) | |
407 | + | if ($isInstanceOf(aw, "String")) | |
408 | + | then aw | |
409 | + | else throw(($getType(aw) + " couldn't be cast to String")) | |
408 | 410 | }, "__"), split({ | |
409 | - | let | |
410 | - | if ($isInstanceOf( | |
411 | - | then | |
412 | - | else throw(($getType( | |
411 | + | let aw = invoke(at, "evaluatePutByPriceAssetREADONLY", [bB], nil) | |
412 | + | if ($isInstanceOf(aw, "String")) | |
413 | + | then aw | |
414 | + | else throw(($getType(aw) + " couldn't be cast to String")) | |
413 | 415 | }, "__")) | |
414 | - | if (( | |
416 | + | if ((bD == bD)) | |
415 | 417 | then { | |
416 | - | let | |
417 | - | let | |
418 | - | let | |
419 | - | let | |
420 | - | if (( | |
418 | + | let bE = bD._2 | |
419 | + | let bF = bD._1 | |
420 | + | let bG = parseIntValue(bF[1]) | |
421 | + | let bH = parseIntValue(bE[1]) | |
422 | + | if ((bH > bG)) | |
421 | 423 | then { | |
422 | - | let | |
423 | - | $Tuple5( | |
424 | + | let bI = parseIntValue(bF[8]) | |
425 | + | $Tuple5(bA, bI, (bB - bI), ay, bH) | |
424 | 426 | } | |
425 | 427 | else { | |
426 | - | let | |
427 | - | $Tuple5( | |
428 | + | let bI = parseIntValue(bF[8]) | |
429 | + | $Tuple5(bI, bB, (bA - bI), ax, bG) | |
428 | 430 | } | |
429 | 431 | } | |
430 | 432 | else throw("Strict value is not equal to itself.") | |
431 | 433 | } | |
432 | 434 | ||
433 | 435 | ||
434 | - | func | |
435 | - | let | |
436 | - | if (( | |
437 | - | then invoke( | |
438 | - | else invoke( | |
436 | + | func bJ (at,bi,bA,ax,bB,ay) = { | |
437 | + | let bK = [AttachedPayment(aR(ax), bA), AttachedPayment(aR(ay), bB)] | |
438 | + | if ((bi == a)) | |
439 | + | then invoke(at, "callFunction", ["replenishWithTwoTokens", ["false", "0"]], bK) | |
440 | + | else invoke(at, "put", [1000000, false], bK) | |
439 | 441 | } | |
440 | 442 | ||
441 | 443 | ||
442 | - | func | |
443 | - | let | |
444 | - | if (( | |
445 | - | then invoke( | |
446 | - | else invoke( | |
444 | + | func bL (at,bi,bI,bM) = { | |
445 | + | let bK = [AttachedPayment(aR(bM), bI)] | |
446 | + | if ((bi == a)) | |
447 | + | then invoke(at, "callFunction", ["replenishWithOneToken", ["0", "false", "0"]], bK) | |
448 | + | else invoke(at, "putOneTkn", [0, false], bK) | |
447 | 449 | } | |
448 | 450 | ||
449 | 451 | ||
450 | - | func | |
451 | - | let | |
452 | - | if (( | |
453 | - | then invoke( | |
454 | - | else invoke( | |
452 | + | func bN (aG,bi,az,bO) = { | |
453 | + | let bK = [AttachedPayment(fromBase58String(az), bO)] | |
454 | + | if ((bi == a)) | |
455 | + | then invoke(aM(), "lockShareTokens", [aG, 0], bK) | |
456 | + | else invoke(aN(addressFromStringValue(aG)), "stake", nil, bK) | |
455 | 457 | } | |
456 | 458 | ||
457 | 459 | ||
458 | - | func | |
459 | - | let | |
460 | - | then $Tuple3( | |
461 | - | else if (( | |
462 | - | then $Tuple3( | |
460 | + | func bP (aG,bi,az,bO) = { | |
461 | + | let bQ = if ((bi == a)) | |
462 | + | then $Tuple3(aM(), "withdrawShareTokens", [aG, bO]) | |
463 | + | else if ((bi == b)) | |
464 | + | then $Tuple3(aN(Address(fromBase58String(aG))), "unstake", [az, bO]) | |
463 | 465 | else throw("Wrong pool type") | |
464 | - | let | |
465 | - | let | |
466 | - | let | |
467 | - | let | |
468 | - | if (( | |
469 | - | then | |
466 | + | let bR = bQ._1 | |
467 | + | let bS = bQ._2 | |
468 | + | let bT = bQ._3 | |
469 | + | let bU = invoke(bR, bS, bT, nil) | |
470 | + | if ((bU == bU)) | |
471 | + | then bO | |
470 | 472 | else throw("Strict value is not equal to itself.") | |
471 | 473 | } | |
472 | 474 | ||
473 | 475 | ||
474 | - | func | |
475 | - | let | |
476 | - | let | |
477 | - | let | |
478 | - | let | |
479 | - | let | |
476 | + | func bV (aG,bW,bX,aA,aB,bY,bZ) = { | |
477 | + | let at = Address(fromBase58String(aG)) | |
478 | + | let ca = 1000000 | |
479 | + | let cb = getIntegerValue(at, t) | |
480 | + | let cc = fraction(bY, ca, (ca - cb)) | |
481 | + | let cd = if ((bZ == bW)) | |
480 | 482 | then { | |
481 | - | let | |
482 | - | $Tuple2( | |
483 | + | let ce = fraction(cc, aB, (aA - cc)) | |
484 | + | $Tuple2(ce, bX) | |
483 | 485 | } | |
484 | 486 | else { | |
485 | - | let | |
486 | - | $Tuple2( | |
487 | + | let ce = fraction(cc, aA, (aB - cc)) | |
488 | + | $Tuple2(ce, bW) | |
487 | 489 | } | |
488 | - | let | |
489 | - | let | |
490 | - | $Tuple2( | |
490 | + | let ce = cd._1 | |
491 | + | let cf = cd._2 | |
492 | + | $Tuple2(cf, ce) | |
491 | 493 | } | |
492 | 494 | ||
493 | 495 | ||
494 | - | func | |
495 | - | let | |
496 | - | let | |
497 | - | let | |
498 | - | let | |
496 | + | func cg (aG,bW,bX,aA,aB,bY,bZ) = { | |
497 | + | let ch = getIntegerValue(ae, "%s__protocolFee") | |
498 | + | let ci = getIntegerValue(ae, "%s__poolFee") | |
499 | + | let cj = toBigInt(100000000) | |
500 | + | let ck = if ((bZ == bW)) | |
499 | 501 | then { | |
500 | - | let | |
501 | - | $Tuple2( | |
502 | + | let ce = fraction(bY, aB, (aA - bY)) | |
503 | + | $Tuple2(ce, bX) | |
502 | 504 | } | |
503 | 505 | else { | |
504 | - | let | |
505 | - | $Tuple2( | |
506 | + | let ce = fraction(bY, aA, (aB - bY)) | |
507 | + | $Tuple2(ce, bW) | |
506 | 508 | } | |
507 | - | let | |
508 | - | let | |
509 | - | let | |
510 | - | $Tuple2( | |
509 | + | let ce = ck._1 | |
510 | + | let cf = ck._2 | |
511 | + | let cl = toInt(fraction(toBigInt(ce), cj, (cj - toBigInt((ch + ci))), CEILING)) | |
512 | + | $Tuple2(cf, fraction(cl, 102, 100)) | |
511 | 513 | } | |
512 | 514 | ||
513 | 515 | ||
514 | - | func | |
516 | + | func cm (aD,aG,bW,bX,aA,aB,bY,bZ) = if ((aD == a)) | |
515 | 517 | then { | |
516 | - | let | |
517 | - | let | |
518 | - | let | |
519 | - | invoke(addressFromStringValue( | |
518 | + | let cn = bV(aG, bW, bX, aA, aB, bY, bZ) | |
519 | + | let cf = cn._1 | |
520 | + | let ce = cn._2 | |
521 | + | invoke(addressFromStringValue(aG), "callFunction", ["exchange", [toString(bY)]], [AttachedPayment(aR(cf), ce)]) | |
520 | 522 | } | |
521 | 523 | else { | |
522 | - | let | |
523 | - | let | |
524 | - | let | |
525 | - | invoke( | |
524 | + | let co = cg(aG, bW, bX, aA, aB, bY, bZ) | |
525 | + | let cf = co._1 | |
526 | + | let ce = co._2 | |
527 | + | invoke(ae, "swap", [bY, bZ, toString(this)], [AttachedPayment(aR(cf), ce)]) | |
526 | 528 | } | |
527 | 529 | ||
528 | 530 | ||
529 | - | func | |
530 | - | let | |
531 | - | if (( | |
531 | + | func cp (bi,aG,bA,ax,bB,ay,aA,aB) = { | |
532 | + | let at = addressFromStringValue(aG) | |
533 | + | if ((bi == a)) | |
532 | 534 | then { | |
533 | - | let | |
534 | - | let | |
535 | - | if ($isInstanceOf( | |
536 | - | then | |
537 | - | else throw(($getType( | |
535 | + | let bU = { | |
536 | + | let aw = invoke(at, "callFunction", ["calcLPReplenishDiffPropREADONLY", [toString(bA), toString(bB), "0"]], nil) | |
537 | + | if ($isInstanceOf(aw, "List[Any]")) | |
538 | + | then aw | |
539 | + | else throw(($getType(aw) + " couldn't be cast to List[Any]")) | |
538 | 540 | } | |
539 | - | if (( | |
541 | + | if ((bU == bU)) | |
540 | 542 | then $Tuple2({ | |
541 | - | let | |
542 | - | if ($isInstanceOf( | |
543 | - | then | |
544 | - | else throw(($getType( | |
543 | + | let aw = bU[0] | |
544 | + | if ($isInstanceOf(aw, "Int")) | |
545 | + | then aw | |
546 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
545 | 547 | }, { | |
546 | - | let | |
547 | - | if ($isInstanceOf( | |
548 | - | then | |
549 | - | else throw(($getType( | |
548 | + | let aw = bU[1] | |
549 | + | if ($isInstanceOf(aw, "Int")) | |
550 | + | then aw | |
551 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
550 | 552 | }) | |
551 | 553 | else throw("Strict value is not equal to itself.") | |
552 | 554 | } | |
553 | - | else if (( | |
555 | + | else if ((bi == b)) | |
554 | 556 | then { | |
555 | - | let | |
556 | - | then ( | |
557 | + | let cq = if (if ((bA > 0)) | |
558 | + | then (bB > 0) | |
557 | 559 | else false) | |
558 | 560 | then { | |
559 | - | let | |
560 | - | let | |
561 | - | let | |
562 | - | let | |
563 | - | let | |
564 | - | let | |
565 | - | $Tuple3( | |
561 | + | let cr = bz(bi, at, bA, ax, bB, ay, aA, aB) | |
562 | + | let cs = cr._1 | |
563 | + | let ct = cr._2 | |
564 | + | let cu = cr._3 | |
565 | + | let cv = cr._4 | |
566 | + | let cw = cr._5 | |
567 | + | $Tuple3(cu, cv, cw) | |
566 | 568 | } | |
567 | - | else if (( | |
568 | - | then $Tuple3( | |
569 | - | else $Tuple3( | |
570 | - | let | |
571 | - | let | |
572 | - | let | |
573 | - | let | |
569 | + | else if ((bA > 0)) | |
570 | + | then $Tuple3(bA, ax, 0) | |
571 | + | else $Tuple3(bB, ay, 0) | |
572 | + | let cu = cq._1 | |
573 | + | let cv = cq._2 | |
574 | + | let cx = cq._3 | |
575 | + | let cy = if ((cu > 0)) | |
574 | 576 | then { | |
575 | - | let | |
576 | - | let | |
577 | - | if ($isInstanceOf( | |
578 | - | then | |
579 | - | else throw(($getType( | |
577 | + | let bU = { | |
578 | + | let aw = invoke(at, "putOneTknREADONLY", [cv, cu], nil) | |
579 | + | if ($isInstanceOf(aw, "(Int, Int, Int)")) | |
580 | + | then aw | |
581 | + | else throw(($getType(aw) + " couldn't be cast to (Int, Int, Int)")) | |
580 | 582 | } | |
581 | - | if (( | |
582 | - | then $Tuple2( | |
583 | + | if ((bU == bU)) | |
584 | + | then $Tuple2(bU._1, bU._3) | |
583 | 585 | else throw("Strict value is not equal to itself.") | |
584 | 586 | } | |
585 | 587 | else $Tuple2(0, 0) | |
586 | - | let | |
587 | - | let | |
588 | - | $Tuple2(( | |
588 | + | let cz = cy._1 | |
589 | + | let cA = cy._2 | |
590 | + | $Tuple2((cx + cz), cA) | |
589 | 591 | } | |
590 | 592 | else throw("Wrong pool type") | |
591 | 593 | } | |
592 | 594 | ||
593 | 595 | ||
594 | - | func | |
595 | - | let | |
596 | - | let | |
596 | + | func cB (bi,aG,cw,az,ax,ay,aA,aB,cC,cD) = { | |
597 | + | let at = addressFromStringValue(aG) | |
598 | + | let cE = if ((bi == a)) | |
597 | 599 | then { | |
598 | - | let | |
599 | - | let | |
600 | - | if ($isInstanceOf( | |
601 | - | then | |
602 | - | else throw(($getType( | |
600 | + | let bU = { | |
601 | + | let aw = invoke(at, "callFunction", ["withdrawREADONLY", [toString(cw), toString(aA), toString(aB)]], nil) | |
602 | + | if ($isInstanceOf(aw, "List[Any]")) | |
603 | + | then aw | |
604 | + | else throw(($getType(aw) + " couldn't be cast to List[Any]")) | |
603 | 605 | } | |
604 | - | if (( | |
606 | + | if ((bU == bU)) | |
605 | 607 | then $Tuple2({ | |
606 | - | let | |
607 | - | if ($isInstanceOf( | |
608 | - | then | |
609 | - | else throw(($getType( | |
608 | + | let aw = bU[0] | |
609 | + | if ($isInstanceOf(aw, "Int")) | |
610 | + | then aw | |
611 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
610 | 612 | }, { | |
611 | - | let | |
612 | - | if ($isInstanceOf( | |
613 | - | then | |
614 | - | else throw(($getType( | |
613 | + | let aw = bU[1] | |
614 | + | if ($isInstanceOf(aw, "Int")) | |
615 | + | then aw | |
616 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
615 | 617 | }) | |
616 | 618 | else throw("Strict value is not equal to itself.") | |
617 | 619 | } | |
618 | - | else if (( | |
620 | + | else if ((bi == b)) | |
619 | 621 | then { | |
620 | - | let | |
621 | - | let | |
622 | - | if ($isInstanceOf( | |
623 | - | then | |
624 | - | else throw(($getType( | |
622 | + | let cF = split({ | |
623 | + | let aw = invoke(at, "evaluateGetREADONLY", [az, cw], nil) | |
624 | + | if ($isInstanceOf(aw, "String")) | |
625 | + | then aw | |
626 | + | else throw(($getType(aw) + " couldn't be cast to String")) | |
625 | 627 | }, "__") | |
626 | - | if (( | |
627 | - | then $Tuple2(parseIntValue( | |
628 | + | if ((cF == cF)) | |
629 | + | then $Tuple2(parseIntValue(cF[1]), parseIntValue(cF[2])) | |
628 | 630 | else throw("Strict value is not equal to itself.") | |
629 | 631 | } | |
630 | 632 | else throw("Wrong pool type") | |
631 | - | let | |
632 | - | let | |
633 | - | if (( | |
633 | + | let cG = cE._1 | |
634 | + | let cH = cE._2 | |
635 | + | if ((cC > 0)) | |
634 | 636 | then { | |
635 | - | let | |
636 | - | then ( | |
637 | + | let cI = if (if ((cD == ax)) | |
638 | + | then (cC > cG) | |
637 | 639 | else false) | |
638 | - | then ( | |
639 | - | else if (if (( | |
640 | - | then ( | |
640 | + | then (cC - cG) | |
641 | + | else if (if ((cD == ay)) | |
642 | + | then (cC > cH) | |
641 | 643 | else false) | |
642 | - | then ( | |
644 | + | then (cC - cH) | |
643 | 645 | else 0 | |
644 | - | let | |
645 | - | then if (( | |
646 | - | then | |
647 | - | else | |
646 | + | let cJ = if ((cI > 0)) | |
647 | + | then if ((bi == a)) | |
648 | + | then bV(aG, ax, ay, aA, aB, cI, cD) | |
649 | + | else cg(aG, ax, ay, aA, aB, cI, cD) | |
648 | 650 | else $Tuple2("", 0) | |
649 | - | let | |
650 | - | let | |
651 | - | if (( | |
652 | - | then $Tuple2((( | |
653 | - | else $Tuple2(( | |
651 | + | let cf = cJ._1 | |
652 | + | let ce = cJ._2 | |
653 | + | if ((cD == ax)) | |
654 | + | then $Tuple2(((cG + cI) - cC), (cH - ce)) | |
655 | + | else $Tuple2((cG - ce), ((cH + cI) - cC)) | |
654 | 656 | } | |
655 | - | else $Tuple2( | |
657 | + | else $Tuple2(cG, cH) | |
656 | 658 | } | |
657 | 659 | ||
658 | 660 | ||
659 | - | func | |
661 | + | func cK (aD,aG) = if ((aD == a)) | |
660 | 662 | then { | |
661 | - | let | |
662 | - | if (( | |
663 | + | let cL = an(af) | |
664 | + | if ((cL == cL)) | |
663 | 665 | then { | |
664 | - | let | |
665 | - | if (( | |
666 | + | let bU = invoke(aM(), "claim", [aG], nil) | |
667 | + | if ((bU == bU)) | |
666 | 668 | then { | |
667 | - | let | |
668 | - | $Tuple2(( | |
669 | + | let cM = an(af) | |
670 | + | $Tuple2((cM - cL), af) | |
669 | 671 | } | |
670 | 672 | else throw("Strict value is not equal to itself.") | |
671 | 673 | } | |
672 | 674 | else throw("Strict value is not equal to itself.") | |
673 | 675 | } | |
674 | - | else if (( | |
676 | + | else if ((aD == b)) | |
675 | 677 | then { | |
676 | - | let | |
677 | - | if (( | |
678 | + | let cL = an(ag) | |
679 | + | if ((cL == cL)) | |
678 | 680 | then { | |
679 | - | let | |
680 | - | if (( | |
681 | + | let bU = invoke(aN(Address(fromBase58String(aG))), "claimWX", [aG], nil) | |
682 | + | if ((bU == bU)) | |
681 | 683 | then { | |
682 | - | let | |
683 | - | $Tuple2(( | |
684 | + | let cM = an(ag) | |
685 | + | $Tuple2((cM - cL), ag) | |
684 | 686 | } | |
685 | 687 | else throw("Strict value is not equal to itself.") | |
686 | 688 | } | |
687 | 689 | else throw("Strict value is not equal to itself.") | |
688 | 690 | } | |
689 | 691 | else throw("Wrong pool type") | |
690 | 692 | ||
691 | 693 | ||
692 | - | func | |
693 | - | let | |
694 | - | if (( | |
694 | + | func cN (bi,aG,aL,bA,ax,bB,ay,aA,aB,cO) = { | |
695 | + | let cP = an(fromBase58String(cO)) | |
696 | + | if ((cP == cP)) | |
695 | 697 | then { | |
696 | - | let | |
697 | - | let | |
698 | - | then ( | |
698 | + | let at = addressFromStringValue(aG) | |
699 | + | let cQ = if (if ((bA > 0)) | |
700 | + | then (bB > 0) | |
699 | 701 | else false) | |
700 | 702 | then { | |
701 | - | let | |
702 | - | let | |
703 | - | let | |
704 | - | let | |
705 | - | let | |
706 | - | let | |
707 | - | if (( | |
708 | - | then $Tuple2( | |
703 | + | let cR = bz(bi, at, bA, ax, bB, ay, aA, aB) | |
704 | + | let cs = cR._1 | |
705 | + | let ct = cR._2 | |
706 | + | let cu = cR._3 | |
707 | + | let cv = cR._4 | |
708 | + | let bU = bJ(at, bi, cs, ax, ct, ay) | |
709 | + | if ((bU == bU)) | |
710 | + | then $Tuple2(cu, cv) | |
709 | 711 | else throw("Strict value is not equal to itself.") | |
710 | 712 | } | |
711 | - | else if (( | |
712 | - | then $Tuple2( | |
713 | - | else if (( | |
714 | - | then $Tuple2( | |
713 | + | else if ((bA > 0)) | |
714 | + | then $Tuple2(bA, ax) | |
715 | + | else if ((bB > 0)) | |
716 | + | then $Tuple2(bB, ay) | |
715 | 717 | else throw("pmts must be > 0") | |
716 | - | let | |
717 | - | let | |
718 | - | let | |
719 | - | then | |
718 | + | let cu = cQ._1 | |
719 | + | let cv = cQ._2 | |
720 | + | let bU = if ((cu > 0)) | |
721 | + | then bL(at, bi, cu, cv) | |
720 | 722 | else nil | |
721 | - | if (( | |
723 | + | if ((bU == bU)) | |
722 | 724 | then { | |
723 | - | let | |
724 | - | let | |
725 | - | let | |
726 | - | let | |
727 | - | if ((0 >= | |
725 | + | let cS = an(fromBase58String(cO)) | |
726 | + | let cT = (cS - cP) | |
727 | + | let cU = fraction(cT, aK(aG, aL), m) | |
728 | + | let cV = (cT - cU) | |
729 | + | if ((0 >= cV)) | |
728 | 730 | then throw("amount of staked sharetokens must be > 0") | |
729 | 731 | else { | |
730 | - | let | |
731 | - | if (( | |
732 | - | then $Tuple2( | |
732 | + | let cW = bN(aG, bi, cO, cV) | |
733 | + | if ((cW == cW)) | |
734 | + | then $Tuple2(cV, cU) | |
733 | 735 | else throw("Strict value is not equal to itself.") | |
734 | 736 | } | |
735 | 737 | } | |
736 | 738 | else throw("Strict value is not equal to itself.") | |
737 | 739 | } | |
738 | 740 | else throw("Strict value is not equal to itself.") | |
739 | 741 | } | |
740 | 742 | ||
741 | 743 | ||
742 | - | func | |
743 | - | let | |
744 | - | let | |
745 | - | let | |
746 | - | then $Tuple2(getIntegerValue(this, ( | |
747 | - | else $Tuple2(getIntegerValue(this, ( | |
748 | - | let | |
749 | - | let | |
750 | - | [IntegerEntry(( | |
744 | + | func cX (aG,aJ,cY,cU,cZ,az,aD,da) = { | |
745 | + | let db = aF(aG) | |
746 | + | let dc = aH(aG) | |
747 | + | let dd = if (da) | |
748 | + | then $Tuple2(getIntegerValue(this, (aG + C)), (dc + cY)) | |
749 | + | else $Tuple2(getIntegerValue(this, (aG + D)), dc) | |
750 | + | let de = dd._1 | |
751 | + | let df = dd._2 | |
752 | + | [IntegerEntry((aG + A), (db + cY)), IntegerEntry((aG + B), df), IntegerEntry((((((aG + "_") + aJ) + "_") + toString(cZ)) + u), cY), IntegerEntry((((((aG + "_") + aJ) + "_") + toString(cZ)) + z), de), StringEntry((((aJ + "_") + toString(cZ)) + v), aG), IntegerEntry((aJ + y), cZ), ScriptTransfer(ab, cU, fromBase58String(az))] | |
751 | 753 | } | |
752 | 754 | ||
753 | 755 | ||
754 | - | func | |
755 | - | let | |
756 | - | if (( | |
756 | + | func dg (dh,di,dj,dk,dl,dm,dn,do,dp,dq) = { | |
757 | + | let dr = an(aR(dh)) | |
758 | + | if ((dr == dr)) | |
757 | 759 | then { | |
758 | - | let | |
759 | - | if (( | |
760 | - | then ( | |
760 | + | let bU = invoke(ac, "swap", [dk, dl, dm, dn, do, dp, dq], [AttachedPayment(dj, di)]) | |
761 | + | if ((bU == bU)) | |
762 | + | then (an(aR(dh)) - dr) | |
761 | 763 | else throw("Strict value is not equal to itself.") | |
762 | 764 | } | |
763 | 765 | else throw("Strict value is not equal to itself.") | |
764 | 766 | } | |
765 | 767 | ||
766 | 768 | ||
767 | - | func | |
768 | - | let | |
769 | - | if (( | |
769 | + | func ds (dh,di,dj,dt,du,dq) = { | |
770 | + | let dr = an(aR(dh)) | |
771 | + | if ((dr == dr)) | |
770 | 772 | then { | |
771 | - | let | |
772 | - | if (( | |
773 | - | then ( | |
773 | + | let bU = invoke(ac, "puzzleSwap", [dt, du, dq], [AttachedPayment(dj, di)]) | |
774 | + | if ((bU == bU)) | |
775 | + | then (an(aR(dh)) - dr) | |
774 | 776 | else throw("Strict value is not equal to itself.") | |
775 | 777 | } | |
776 | 778 | else throw("Strict value is not equal to itself.") | |
777 | 779 | } | |
778 | 780 | ||
779 | 781 | ||
780 | - | func | |
781 | - | let | |
782 | - | if (( | |
782 | + | func dv (dh,di,dj,dw,dx,dy,dz,dA,dB,dq) = { | |
783 | + | let dr = an(aR(dh)) | |
784 | + | if ((dr == dr)) | |
783 | 785 | then { | |
784 | - | let | |
785 | - | if (( | |
786 | - | then ( | |
786 | + | let bU = invoke(ac, "swopfiSwap", [dw, dx, dy, dz, dA, dB, dq], [AttachedPayment(dj, di)]) | |
787 | + | if ((bU == bU)) | |
788 | + | then (an(aR(dh)) - dr) | |
787 | 789 | else throw("Strict value is not equal to itself.") | |
788 | 790 | } | |
789 | 791 | else throw("Strict value is not equal to itself.") | |
790 | 792 | } | |
791 | 793 | ||
792 | 794 | ||
793 | - | func | |
794 | - | let | |
795 | - | let | |
796 | - | let | |
797 | - | let | |
798 | - | let | |
799 | - | let | |
800 | - | let | |
801 | - | if (if (( | |
802 | - | then ( | |
795 | + | func dC (aG,bi,dD,dE) = { | |
796 | + | let at = Address(fromBase58String(aG)) | |
797 | + | let dF = aC(at, bi) | |
798 | + | let dG = dF._1 | |
799 | + | let dH = dF._2 | |
800 | + | let aA = dF._3 | |
801 | + | let aB = dF._4 | |
802 | + | let az = dF._5 | |
803 | + | if (if ((dD != dG)) | |
804 | + | then (dD != dH) | |
803 | 805 | else false) | |
804 | 806 | then throw("Wrong asset") | |
805 | 807 | else { | |
806 | - | let | |
807 | - | then $Tuple2( | |
808 | - | else $Tuple2(0, | |
809 | - | let | |
810 | - | let | |
811 | - | let | |
812 | - | let | |
813 | - | let | |
814 | - | let | |
815 | - | let | |
816 | - | let | |
817 | - | let | |
818 | - | let | |
819 | - | let | |
820 | - | let | |
821 | - | let | |
822 | - | then ( | |
808 | + | let dI = if ((dD == dG)) | |
809 | + | then $Tuple2(dE, 0) | |
810 | + | else $Tuple2(0, dE) | |
811 | + | let bA = dI._1 | |
812 | + | let bB = dI._2 | |
813 | + | let dJ = cN(bi, aG, i, bA, dG, bB, dH, aA, aB, az) | |
814 | + | let cY = dJ._1 | |
815 | + | let dK = dJ._2 | |
816 | + | let dL = valueOrElse(getInteger(this, (aG + C)), 0) | |
817 | + | let dM = valueOrElse(getInteger(this, (aG + D)), 0) | |
818 | + | let dN = aF(aG) | |
819 | + | let dO = aH(aG) | |
820 | + | let dP = fraction(dO, j, dN) | |
821 | + | let dQ = fraction(cY, dP, j) | |
822 | + | let dR = (cY - dQ) | |
823 | + | let dS = if ((dO > 0)) | |
824 | + | then (dL + fraction(dQ, k, dO)) | |
823 | 825 | else 0 | |
824 | - | let | |
825 | - | then ( | |
826 | + | let dT = if (((dN - dO) > 0)) | |
827 | + | then (dM + fraction(dR, k, (dN - dO))) | |
826 | 828 | else 0 | |
827 | - | let | |
828 | - | let | |
829 | - | let | |
830 | - | if (( | |
831 | - | then ([IntegerEntry(( | |
829 | + | let dU = fraction(dQ, aK(aG, d), m) | |
830 | + | let dV = fraction(dR, aK(aG, c), m) | |
831 | + | let dW = bP(aG, bi, az, (dU + dV)) | |
832 | + | if ((dW == dW)) | |
833 | + | then ([IntegerEntry((aG + C), dS), IntegerEntry((aG + D), dT), IntegerEntry((aG + A), ((dN + cY) - dW)), IntegerEntry((aG + B), ((dO + dQ) - dU)), ScriptTransfer(ab, (dU + dV), fromBase58String(az))] ++ bv(dG, dH, az)) | |
832 | 834 | else throw("Strict value is not equal to itself.") | |
833 | 835 | } | |
834 | 836 | } | |
835 | 837 | ||
836 | 838 | ||
837 | - | func | |
838 | - | let | |
839 | - | let | |
840 | - | let | |
841 | - | let | |
842 | - | let | |
843 | - | let | |
844 | - | let | |
845 | - | let | |
846 | - | let | |
847 | - | if (( | |
839 | + | func dX (aG,dY,dZ,ea) = { | |
840 | + | let at = Address(fromBase58String(aG)) | |
841 | + | let bi = valueOrErrorMessage(getString(this, (N + aG)), "Unknown pool") | |
842 | + | let eb = aC(at, bi) | |
843 | + | let bW = eb._1 | |
844 | + | let bX = eb._2 | |
845 | + | let aA = eb._3 | |
846 | + | let aB = eb._4 | |
847 | + | let az = eb._5 | |
848 | + | let ec = an(aR(bW)) | |
849 | + | if ((ec == ec)) | |
848 | 850 | then { | |
849 | - | let | |
850 | - | if (( | |
851 | + | let ed = an(aR(bX)) | |
852 | + | if ((ed == ed)) | |
851 | 853 | then { | |
852 | - | let | |
853 | - | then invoke( | |
854 | + | let bU = if ((bi == a)) | |
855 | + | then invoke(at, "callFunction", ["withdraw", [toString(dY)]], nil) | |
854 | 856 | else { | |
855 | - | let | |
856 | - | if (( | |
857 | - | then invoke( | |
857 | + | let bU = bP(aG, bi, az, dY) | |
858 | + | if ((bU == bU)) | |
859 | + | then invoke(at, "get", nil, [AttachedPayment(aR(az), dY)]) | |
858 | 860 | else throw("Strict value is not equal to itself.") | |
859 | 861 | } | |
860 | - | if (( | |
862 | + | if ((bU == bU)) | |
861 | 863 | then { | |
862 | - | let | |
863 | - | let | |
864 | - | let | |
865 | - | let | |
866 | - | let | |
867 | - | let | |
864 | + | let ee = an(aR(bW)) | |
865 | + | let ef = an(aR(bX)) | |
866 | + | let eg = $Tuple2((ee - ec), (ef - ed)) | |
867 | + | let eh = eg._1 | |
868 | + | let ei = eg._2 | |
869 | + | let ej = if ((dZ > 0)) | |
868 | 870 | then { | |
869 | - | let | |
870 | - | then ( | |
871 | + | let cI = if (if ((ea == bW)) | |
872 | + | then (dZ > eh) | |
871 | 873 | else false) | |
872 | - | then ( | |
873 | - | else if (if (( | |
874 | - | then ( | |
874 | + | then (dZ - eh) | |
875 | + | else if (if ((ea == bX)) | |
876 | + | then (dZ > ei) | |
875 | 877 | else false) | |
876 | - | then ( | |
878 | + | then (dZ - ei) | |
877 | 879 | else 0 | |
878 | - | let | |
879 | - | then | |
880 | + | let ek = if ((cI > 0)) | |
881 | + | then cm(bi, aG, bW, bX, aA, aB, cI, ea) | |
880 | 882 | else 0 | |
881 | - | if (( | |
883 | + | if ((ek == ek)) | |
882 | 884 | then { | |
883 | - | let | |
884 | - | let | |
885 | - | if (( | |
886 | - | then $Tuple2((( | |
887 | - | else $Tuple2(( | |
885 | + | let el = an(aR(bW)) | |
886 | + | let em = an(aR(bX)) | |
887 | + | if ((ea == bW)) | |
888 | + | then $Tuple2(((el - ec) - dZ), (em - ed)) | |
889 | + | else $Tuple2((el - ec), ((em - ed) - dZ)) | |
888 | 890 | } | |
889 | 891 | else throw("Strict value is not equal to itself.") | |
890 | 892 | } | |
891 | - | else $Tuple2( | |
892 | - | let | |
893 | - | let | |
894 | - | $Tuple7( | |
893 | + | else $Tuple2(eh, ei) | |
894 | + | let en = ej._1 | |
895 | + | let eo = ej._2 | |
896 | + | $Tuple7(en, bW, eo, bX, ee, ef, az) | |
895 | 897 | } | |
896 | 898 | else throw("Strict value is not equal to itself.") | |
897 | 899 | } | |
898 | 900 | else throw("Strict value is not equal to itself.") | |
899 | 901 | } | |
900 | 902 | else throw("Strict value is not equal to itself.") | |
901 | 903 | } | |
902 | 904 | ||
903 | 905 | ||
904 | - | func | |
905 | - | let | |
906 | - | let | |
907 | - | let | |
908 | - | then getIntegerValue(this, ( | |
909 | - | else getIntegerValue(this, ( | |
910 | - | ( | |
906 | + | func ep (aJ,aG,eq,er) = { | |
907 | + | let es = valueOrErrorMessage(getInteger(this, (((((aG + "_") + aJ) + "_") + eq) + u)), "Unknown position") | |
908 | + | let et = getIntegerValue(this, (((((aG + "_") + aJ) + "_") + eq) + z)) | |
909 | + | let eu = if (er) | |
910 | + | then getIntegerValue(this, (aG + C)) | |
911 | + | else getIntegerValue(this, (aG + D)) | |
912 | + | (es + fraction(es, (eu - et), k)) | |
911 | 913 | } | |
912 | 914 | ||
913 | 915 | ||
914 | - | func | |
915 | - | let | |
916 | - | let | |
917 | - | let | |
918 | - | let | |
919 | - | let | |
920 | - | let | |
921 | - | let | |
916 | + | func ev (aJ,aG,eq,ew) = { | |
917 | + | let es = valueOrErrorMessage(getInteger(this, (((((aG + "_") + aJ) + "_") + eq) + u)), "Unknown position") | |
918 | + | let cC = valueOrElse(getInteger(this, (((((aG + "_") + aJ) + "_") + eq) + w)), 0) | |
919 | + | let dY = ep(aJ, aG, eq, (cC > 0)) | |
920 | + | let ex = aF(aG) | |
921 | + | let ey = Address(fromBase58String(aJ)) | |
922 | + | let ea = valueOrElse(getString(this, (((((aG + "_") + aJ) + "_") + eq) + x)), "") | |
923 | + | let dZ = if ((cC > 0)) | |
922 | 924 | then { | |
923 | - | let | |
924 | - | if ($isInstanceOf( | |
925 | - | then | |
926 | - | else throw(($getType( | |
925 | + | let aw = invoke(ah(), "getAssetDebt", [false, ((aJ + "_") + eq), ea], nil) | |
926 | + | if ($isInstanceOf(aw, "Int")) | |
927 | + | then aw | |
928 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
927 | 929 | } | |
928 | 930 | else 0 | |
929 | - | let | |
930 | - | if (( | |
931 | + | let ez = dX(aG, dY, dZ, ea) | |
932 | + | if ((ez == ez)) | |
931 | 933 | then { | |
932 | - | let | |
933 | - | let | |
934 | - | let | |
935 | - | let | |
936 | - | let | |
937 | - | let | |
938 | - | let | |
939 | - | let | |
940 | - | then invoke( | |
934 | + | let az = ez._7 | |
935 | + | let ef = ez._6 | |
936 | + | let ee = ez._5 | |
937 | + | let bX = ez._4 | |
938 | + | let eA = ez._3 | |
939 | + | let bW = ez._2 | |
940 | + | let eB = ez._1 | |
941 | + | let eC = if ((dZ > 0)) | |
942 | + | then invoke(ah(), "repayFor", [((aJ + "_") + eq)], [AttachedPayment(aR(ea), dZ)]) | |
941 | 943 | else 0 | |
942 | - | if (( | |
943 | - | then ([DeleteEntry(((((( | |
944 | + | if ((eC == eC)) | |
945 | + | then ([DeleteEntry((((((aG + "_") + aJ) + "_") + eq) + u)), DeleteEntry((((((aG + "_") + aJ) + "_") + eq) + z)), IntegerEntry((aG + A), (ex - dY)), ScriptTransfer(ey, eB, aR(bW)), ScriptTransfer(ey, eA, aR(bX))] ++ bv(bW, bX, az)) | |
944 | 946 | else throw("Strict value is not equal to itself.") | |
945 | 947 | } | |
946 | 948 | else throw("Strict value is not equal to itself.") | |
947 | 949 | } | |
948 | 950 | ||
949 | 951 | ||
950 | - | func | |
951 | - | let | |
952 | - | let | |
953 | - | let | |
954 | - | let | |
955 | - | let | |
956 | - | let | |
957 | - | let | |
958 | - | let | |
959 | - | let | |
960 | - | let | |
961 | - | let | |
962 | - | let | |
963 | - | $Tuple11( | |
952 | + | func eD (eE) = { | |
953 | + | let eF = split(valueOrErrorMessage(getString(this, (eE + L)), ("No request with id " + eE)), ",") | |
954 | + | let aJ = eF[0] | |
955 | + | let aG = eF[1] | |
956 | + | let bA = parseIntValue(eF[2]) | |
957 | + | let dG = eF[3] | |
958 | + | let bB = parseIntValue(eF[4]) | |
959 | + | let dH = eF[5] | |
960 | + | let aA = parseIntValue(eF[6]) | |
961 | + | let aB = parseIntValue(eF[7]) | |
962 | + | let az = eF[8] | |
963 | + | let eG = eF[9] | |
964 | + | let eH = parseIntValue(eF[10]) | |
965 | + | $Tuple11(aJ, aG, bA, dG, bB, dH, aA, aB, az, eG, eH) | |
964 | 966 | } | |
965 | 967 | ||
966 | 968 | ||
967 | - | func | |
968 | - | let | |
969 | - | if ($isInstanceOf( | |
970 | - | then | |
971 | - | else throw(($getType( | |
972 | - | let | |
973 | - | if ($isInstanceOf( | |
974 | - | then | |
975 | - | else throw(($getType( | |
976 | - | let | |
977 | - | let | |
978 | - | let | |
979 | - | let | |
980 | - | then $Tuple2( | |
981 | - | else $Tuple2( | |
982 | - | let | |
983 | - | let | |
984 | - | fraction(fraction( | |
969 | + | func eI (bA,bB,ax,ay,eJ,eK) = { | |
970 | + | let bm = ( let aw = invoke(ad, "getTWAP60", [ax, false], nil) | |
971 | + | if ($isInstanceOf(aw, "(Int, Int)")) | |
972 | + | then aw | |
973 | + | else throw(($getType(aw) + " couldn't be cast to (Int, Int)")))._2 | |
974 | + | let bn = ( let aw = invoke(ad, "getTWAP60", [ay, false], nil) | |
975 | + | if ($isInstanceOf(aw, "(Int, Int)")) | |
976 | + | then aw | |
977 | + | else throw(($getType(aw) + " couldn't be cast to (Int, Int)")))._2 | |
978 | + | let eL = pow(10, 0, aS(ax), 0, 0, DOWN) | |
979 | + | let eM = pow(10, 0, aS(ay), 0, 0, DOWN) | |
980 | + | let eN = (fraction(bm, bA, eL) + fraction(bn, bB, eM)) | |
981 | + | let eO = if ((eK == ax)) | |
982 | + | then $Tuple2(bm, eL) | |
983 | + | else $Tuple2(bn, eM) | |
984 | + | let eP = eO._1 | |
985 | + | let eQ = eO._2 | |
986 | + | fraction(fraction(eN, (eJ - 100), 100), eQ, eP) | |
985 | 987 | } | |
986 | 988 | ||
987 | 989 | ||
988 | - | @Callable( | |
989 | - | func calcPriceImpactEVALONLY ( | |
990 | + | @Callable(ak) | |
991 | + | func calcPriceImpactEVALONLY (aG,eJ,eK,bA,bB) = if (if ((100 > eJ)) | |
990 | 992 | then true | |
991 | - | else ( | |
993 | + | else (eJ > 300)) | |
992 | 994 | then throw("Leverage can't be <100 and >300") | |
993 | 995 | else { | |
994 | - | let | |
995 | - | let | |
996 | - | let | |
997 | - | let | |
998 | - | let | |
999 | - | let | |
1000 | - | let | |
1001 | - | let | |
1002 | - | then | |
996 | + | let bi = valueOrErrorMessage(getString(this, (N + aG)), "Pool is not inited") | |
997 | + | let eR = aC(Address(fromBase58String(aG)), bi) | |
998 | + | let dG = eR._1 | |
999 | + | let dH = eR._2 | |
1000 | + | let aA = eR._3 | |
1001 | + | let aB = eR._4 | |
1002 | + | let az = eR._5 | |
1003 | + | let cC = if ((eJ > 100)) | |
1004 | + | then eI(bA, bB, dG, dH, eJ, eK) | |
1003 | 1005 | else 0 | |
1004 | - | let | |
1005 | - | then $Tuple2(( | |
1006 | - | else $Tuple2( | |
1007 | - | let | |
1008 | - | let | |
1009 | - | let | |
1010 | - | let | |
1011 | - | let | |
1012 | - | let | |
1013 | - | then ( | |
1014 | - | else | |
1015 | - | $Tuple2(nil, [ | |
1006 | + | let eS = if ((eK == dG)) | |
1007 | + | then $Tuple2((bA + cC), bB) | |
1008 | + | else $Tuple2(bA, (bB + cC)) | |
1009 | + | let eT = eS._1 | |
1010 | + | let eU = eS._2 | |
1011 | + | let eV = cp(bi, aG, eT, dG, eU, dH, aA, aB) | |
1012 | + | let cw = eV._1 | |
1013 | + | let cA = eV._2 | |
1014 | + | let eW = if ((0 > cA)) | |
1015 | + | then (cA * -1) | |
1016 | + | else cA | |
1017 | + | $Tuple2(nil, [eW]) | |
1016 | 1018 | } | |
1017 | 1019 | ||
1018 | 1020 | ||
1019 | 1021 | ||
1020 | - | @Callable( | |
1021 | - | func getShareAssetPriceREADONLY ( | |
1022 | - | let | |
1023 | - | $Tuple2(nil, | |
1022 | + | @Callable(ak) | |
1023 | + | func getShareAssetPriceREADONLY (az) = { | |
1024 | + | let eX = bh(az) | |
1025 | + | $Tuple2(nil, eX) | |
1024 | 1026 | } | |
1025 | 1027 | ||
1026 | 1028 | ||
1027 | 1029 | ||
1028 | - | @Callable( | |
1029 | - | func getUserPositionShareAmountREADONLY ( | |
1030 | - | let | |
1031 | - | let | |
1032 | - | let | |
1033 | - | $Tuple2(nil, | |
1030 | + | @Callable(ak) | |
1031 | + | func getUserPositionShareAmountREADONLY (aJ,cZ) = { | |
1032 | + | let aG = valueOrErrorMessage(getString(this, (((aJ + "_") + cZ) + v)), "Unknown position") | |
1033 | + | let cC = getIntegerValue(this, (((((aG + "_") + aJ) + "_") + cZ) + w)) | |
1034 | + | let dY = ep(aJ, aG, cZ, (cC > 0)) | |
1035 | + | $Tuple2(nil, dY) | |
1034 | 1036 | } | |
1035 | 1037 | ||
1036 | 1038 | ||
1037 | 1039 | ||
1038 | - | @Callable( | |
1039 | - | func getUserPositionInDollarsREADONLY ( | |
1040 | - | func | |
1041 | - | let | |
1042 | - | let | |
1043 | - | let | |
1044 | - | let | |
1045 | - | let | |
1046 | - | let | |
1047 | - | let | |
1048 | - | let | |
1049 | - | let | |
1050 | - | let | |
1051 | - | let | |
1052 | - | let | |
1053 | - | let | |
1054 | - | let | |
1055 | - | let | |
1056 | - | let | |
1057 | - | if (( | |
1058 | - | then $Tuple3(( | |
1040 | + | @Callable(ak) | |
1041 | + | func getUserPositionInDollarsREADONLY (aJ,eY,cZ) = { | |
1042 | + | func eZ (aY,aG) = { | |
1043 | + | let fa = aY | |
1044 | + | let fb = fa._1 | |
1045 | + | let fc = fa._2 | |
1046 | + | let fd = fa._3 | |
1047 | + | let bi = valueOrErrorMessage(getString(this, (N + aG)), "Pool is not inited") | |
1048 | + | let fe = aC(Address(fromBase58String(aG)), bi) | |
1049 | + | let dG = fe._1 | |
1050 | + | let dH = fe._2 | |
1051 | + | let aA = fe._3 | |
1052 | + | let aB = fe._4 | |
1053 | + | let az = fe._5 | |
1054 | + | let cC = valueOrElse(getInteger(this, (((((aG + "_") + aJ) + "_") + cZ[fd]) + w)), 0) | |
1055 | + | let dY = ep(aJ, aG, cZ[fd], (cC > 0)) | |
1056 | + | let eX = bh(az) | |
1057 | + | let ff = pow(10, 0, aS(az), 0, 0, DOWN) | |
1058 | + | let fg = fraction(dY, eX, ff) | |
1059 | + | if ((cC == 0)) | |
1060 | + | then $Tuple3((fb :+ fg), (fc :+ 0), (fd + 1)) | |
1059 | 1061 | else { | |
1060 | - | let | |
1061 | - | let | |
1062 | - | let | |
1063 | - | if ($isInstanceOf( | |
1064 | - | then | |
1065 | - | else throw(($getType( | |
1062 | + | let ea = getStringValue(this, (((((aG + "_") + aJ) + "_") + cZ[fd]) + x)) | |
1063 | + | let dZ = { | |
1064 | + | let aw = invoke(ah(), "getAssetDebt", [false, ((aJ + "_") + cZ[fd]), ea], nil) | |
1065 | + | if ($isInstanceOf(aw, "Int")) | |
1066 | + | then aw | |
1067 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
1066 | 1068 | } | |
1067 | - | let | |
1068 | - | if ($isInstanceOf( | |
1069 | - | then | |
1070 | - | else throw(($getType( | |
1071 | - | let | |
1072 | - | let | |
1073 | - | $Tuple3(( | |
1069 | + | let fh = ( let aw = invoke(ad, "getTWAP60", [ea, false], nil) | |
1070 | + | if ($isInstanceOf(aw, "(Int, Int)")) | |
1071 | + | then aw | |
1072 | + | else throw(($getType(aw) + " couldn't be cast to (Int, Int)")))._1 | |
1073 | + | let fi = pow(10, 0, aS(ea), 0, 0, DOWN) | |
1074 | + | let fj = fraction(dZ, fh, fi) | |
1075 | + | $Tuple3((fb :+ fg), (fc :+ fj), (fd + 1)) | |
1074 | 1076 | } | |
1075 | 1077 | } | |
1076 | 1078 | ||
1077 | - | let | |
1078 | - | let | |
1079 | - | let | |
1080 | - | let | |
1081 | - | func | |
1082 | - | then | |
1083 | - | else | |
1079 | + | let fk = { | |
1080 | + | let ba = eY | |
1081 | + | let bb = size(ba) | |
1082 | + | let bc = $Tuple3(nil, nil, 0) | |
1083 | + | func bd (be,bf) = if ((bf >= bb)) | |
1084 | + | then be | |
1085 | + | else eZ(be, ba[bf]) | |
1084 | 1086 | ||
1085 | - | func | |
1086 | - | then | |
1087 | + | func bg (be,bf) = if ((bf >= bb)) | |
1088 | + | then be | |
1087 | 1089 | else throw("List size exceeds 20") | |
1088 | 1090 | ||
1089 | - | | |
1091 | + | bg(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bd(bc, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20) | |
1090 | 1092 | } | |
1091 | - | let | |
1092 | - | let | |
1093 | - | $Tuple2(nil, $Tuple2( | |
1093 | + | let fl = fk._1 | |
1094 | + | let dZ = fk._2 | |
1095 | + | $Tuple2(nil, $Tuple2(fl, dZ)) | |
1094 | 1096 | } | |
1095 | 1097 | ||
1096 | 1098 | ||
1097 | 1099 | ||
1098 | - | @Callable( | |
1099 | - | func replenish ( | |
1100 | + | @Callable(ak) | |
1101 | + | func replenish (aG,eJ,eK) = if (if ((100 > eJ)) | |
1100 | 1102 | then true | |
1101 | - | else ( | |
1103 | + | else (eJ > 300)) | |
1102 | 1104 | then throw("Leverage can't be <100 and >300") | |
1103 | - | else { | |
1104 | - | let bh = valueOrErrorMessage(getString(this, (M + aF)), "Pool is not inited") | |
1105 | - | let fl = aB(Address(fromBase58String(aF)), bh) | |
1106 | - | let dF = fl._1 | |
1107 | - | let dG = fl._2 | |
1108 | - | let az = fl._3 | |
1109 | - | let aA = fl._4 | |
1110 | - | let ay = fl._5 | |
1111 | - | let fm = if ((size(aj.payments) == 2)) | |
1112 | - | then if ((aP(aj.payments[0].assetId) != dF)) | |
1113 | - | then throw("Wrong payment asset A") | |
1114 | - | else if ((aP(aj.payments[1].assetId) != dG)) | |
1115 | - | then throw("Wrong payment asset B") | |
1116 | - | else $Tuple4(aj.payments[0].amount, dF, aj.payments[1].amount, dG) | |
1117 | - | else if ((size(aj.payments) == 1)) | |
1118 | - | then if ((aP(aj.payments[0].assetId) == dF)) | |
1119 | - | then $Tuple4(aj.payments[0].amount, dF, 0, dG) | |
1120 | - | else if ((aP(aj.payments[0].assetId) == dG)) | |
1121 | - | then $Tuple4(0, dF, aj.payments[0].amount, dG) | |
1122 | - | else throw("Wrong payment") | |
1123 | - | else throw("One or two payments expected") | |
1124 | - | let bz = fm._1 | |
1125 | - | let fn = fm._2 | |
1126 | - | let bA = fm._3 | |
1127 | - | let fo = fm._4 | |
1128 | - | let fp = aH(toString(aj.caller)) | |
1129 | - | if ((eI > 100)) | |
1130 | - | then { | |
1131 | - | let cB = eH(bz, bA, fn, fo, eI, eJ) | |
1132 | - | let eE = makeString([toString(aj.caller), aF, toString(bz), fn, toString(bA), fo, toString(az), toString(aA), ay, eJ, toString(cB)], ",") | |
1133 | - | let fq = { | |
1134 | - | let av = invoke(this, "createNewRequest", [eE], nil) | |
1135 | - | if ($isInstanceOf(av, "Int")) | |
1136 | - | then av | |
1137 | - | else throw(($getType(av) + " couldn't be cast to Int")) | |
1105 | + | else if (if (!(getBooleanValue(this, (aG + E)))) | |
1106 | + | then (eJ > 100) | |
1107 | + | else false) | |
1108 | + | then throw("You can't borrow in this pool") | |
1109 | + | else { | |
1110 | + | let bi = valueOrErrorMessage(getString(this, (N + aG)), "Pool is not inited") | |
1111 | + | let fm = aC(Address(fromBase58String(aG)), bi) | |
1112 | + | let dG = fm._1 | |
1113 | + | let dH = fm._2 | |
1114 | + | let aA = fm._3 | |
1115 | + | let aB = fm._4 | |
1116 | + | let az = fm._5 | |
1117 | + | let fn = if ((size(ak.payments) == 2)) | |
1118 | + | then if ((aQ(ak.payments[0].assetId) != dG)) | |
1119 | + | then throw("Wrong payment asset A") | |
1120 | + | else if ((aQ(ak.payments[1].assetId) != dH)) | |
1121 | + | then throw("Wrong payment asset B") | |
1122 | + | else $Tuple4(ak.payments[0].amount, dG, ak.payments[1].amount, dH) | |
1123 | + | else if ((size(ak.payments) == 1)) | |
1124 | + | then if ((aQ(ak.payments[0].assetId) == dG)) | |
1125 | + | then $Tuple4(ak.payments[0].amount, dG, 0, dH) | |
1126 | + | else if ((aQ(ak.payments[0].assetId) == dH)) | |
1127 | + | then $Tuple4(0, dG, ak.payments[0].amount, dH) | |
1128 | + | else throw("Wrong payment") | |
1129 | + | else throw("One or two payments expected") | |
1130 | + | let bA = fn._1 | |
1131 | + | let fo = fn._2 | |
1132 | + | let bB = fn._3 | |
1133 | + | let fp = fn._4 | |
1134 | + | let fq = aI(toString(ak.caller)) | |
1135 | + | if ((eJ > 100)) | |
1136 | + | then { | |
1137 | + | let cC = eI(bA, bB, fo, fp, eJ, eK) | |
1138 | + | let eF = makeString([toString(ak.caller), aG, toString(bA), fo, toString(bB), fp, toString(aA), toString(aB), az, eK, toString(cC)], ",") | |
1139 | + | let fr = { | |
1140 | + | let aw = invoke(this, "createNewRequest", [eF], nil) | |
1141 | + | if ($isInstanceOf(aw, "Int")) | |
1142 | + | then aw | |
1143 | + | else throw(($getType(aw) + " couldn't be cast to Int")) | |
1144 | + | } | |
1145 | + | if ((fr == fr)) | |
1146 | + | then { | |
1147 | + | let fs = [((toString(ak.caller) + "_") + toString(fq)), az, eK, cC, toString(this), "replenishFromLand", toString(valueOrErrorMessage(fr, "Can't create new request"))] | |
1148 | + | let bU = reentrantInvoke(ah(), "flashPosition", fs, nil) | |
1149 | + | if ((bU == bU)) | |
1150 | + | then nil | |
1151 | + | else throw("Strict value is not equal to itself.") | |
1152 | + | } | |
1153 | + | else throw("Strict value is not equal to itself.") | |
1138 | 1154 | } | |
1139 | - | if ((fq == fq)) | |
1140 | - | then { | |
1141 | - | let fr = [((toString(aj.caller) + "_") + toString(fp)), ay, eJ, cB, toString(this), "replenishFromLand", toString(valueOrErrorMessage(fq, "Can't create new request"))] | |
1142 | - | let bT = reentrantInvoke(ag(), "flashPosition", fr, nil) | |
1143 | - | if ((bT == bT)) | |
1144 | - | then nil | |
1145 | - | else throw("Strict value is not equal to itself.") | |
1146 | - | } | |
1147 | - | else throw("Strict value is not equal to itself.") | |
1148 | - | } | |
1149 | - | else { | |
1150 | - | let fs = cM(bh, aF, h, bz, dF, bA, dG, az, aA, ay) | |
1151 | - | let ft = fs._1 | |
1152 | - | let dV = fs._2 | |
1153 | - | (cW(aF, toString(aj.caller), ft, dV, fp, ay, bh, false) ++ bu(dF, dG, ay)) | |
1154 | - | } | |
1155 | - | } | |
1155 | + | else { | |
1156 | + | let ft = cN(bi, aG, h, bA, dG, bB, dH, aA, aB, az) | |
1157 | + | let fu = ft._1 | |
1158 | + | let dW = ft._2 | |
1159 | + | (cX(aG, toString(ak.caller), fu, dW, fq, az, bi, false) ++ bv(dG, dH, az)) | |
1160 | + | } | |
1161 | + | } | |
1156 | 1162 | ||
1157 | 1163 | ||
1158 | 1164 | ||
1159 | - | @Callable( | |
1160 | - | func withdraw ( | |
1165 | + | @Callable(ak) | |
1166 | + | func withdraw (aG,eq) = ev(toString(ak.caller), aG, toString(eq), false) | |
1161 | 1167 | ||
1162 | 1168 | ||
1163 | 1169 | ||
1164 | - | @Callable( | |
1165 | - | func createUpdateStopLoss ( | |
1166 | - | let | |
1167 | - | if ($isInstanceOf( | |
1168 | - | then | |
1169 | - | else throw(($getType( | |
1170 | - | if (!(isDefined(getInteger(this, ((((( | |
1170 | + | @Callable(ak) | |
1171 | + | func createUpdateStopLoss (eq,fv,ao,fw) = { | |
1172 | + | let fx = ( let aw = invoke(ad, "getTWAP60", [ao, false], nil) | |
1173 | + | if ($isInstanceOf(aw, "(Int, Int)")) | |
1174 | + | then aw | |
1175 | + | else throw(($getType(aw) + " couldn't be cast to (Int, Int)")))._1 | |
1176 | + | if (!(isDefined(getInteger(this, (((((fv + "_") + toString(ak.caller)) + "_") + toString(eq)) + u))))) | |
1171 | 1177 | then throw("There are no user position") | |
1172 | - | else if ((0 >= | |
1178 | + | else if ((0 >= fw)) | |
1173 | 1179 | then throw("Price must be greater than 0") | |
1174 | - | else if (( | |
1180 | + | else if ((fw > fx)) | |
1175 | 1181 | then throw("Price must be less than current token price") | |
1176 | - | else [IntegerEntry((((((((toString( | |
1182 | + | else [IntegerEntry((((((((toString(ak.caller) + "_") + toString(eq)) + "_") + fv) + "_") + ao) + R), fw)] | |
1177 | 1183 | } | |
1178 | 1184 | ||
1179 | 1185 | ||
1180 | 1186 | ||
1181 | - | @Callable( | |
1182 | - | func deleteStopLoss ( | |
1187 | + | @Callable(ak) | |
1188 | + | func deleteStopLoss (eq,fv,ao) = if (!(isDefined(getInteger(this, (((((((toString(ak.caller) + "_") + toString(eq)) + "_") + fv) + "_") + ao) + R))))) | |
1183 | 1189 | then throw("No entry") | |
1184 | - | else [DeleteEntry((((((((toString( | |
1190 | + | else [DeleteEntry((((((((toString(ak.caller) + "_") + toString(eq)) + "_") + fv) + "_") + ao) + R))] | |
1185 | 1191 | ||
1186 | 1192 | ||
1187 | 1193 | ||
1188 | - | @Callable( | |
1189 | - | func init ( | |
1194 | + | @Callable(ak) | |
1195 | + | func init (fy,fz,fA,ad,fB,ae,fC,fD,fE) = if (isDefined(getString(S))) | |
1190 | 1196 | then throw("Already inited") | |
1191 | - | else [ | |
1197 | + | else [StringEntry(S, fy), StringEntry(T, fz), StringEntry(U, fA), StringEntry(W, ad), StringEntry(X, fB), StringEntry(Y, ae), StringEntry(Z, fC), StringEntry(aa, fD), StringEntry(V, fE)] | |
1192 | 1198 | ||
1193 | 1199 | ||
1194 | 1200 | ||
1195 | - | @Callable( | |
1196 | - | func createNewRequest ( | |
1197 | - | let | |
1198 | - | $Tuple2([StringEntry((toString( | |
1201 | + | @Callable(ak) | |
1202 | + | func createNewRequest (bT) = valueOrElse(al(ak), { | |
1203 | + | let fr = (valueOrElse(getInteger(this, M), 0) + 1) | |
1204 | + | $Tuple2([StringEntry((toString(fr) + L), bT), IntegerEntry(M, fr)], fr) | |
1199 | 1205 | }) | |
1200 | 1206 | ||
1201 | 1207 | ||
1202 | 1208 | ||
1203 | - | @Callable( | |
1204 | - | func replenishFromLand ( | |
1205 | - | let | |
1206 | - | let | |
1207 | - | let | |
1208 | - | let | |
1209 | - | let | |
1210 | - | let | |
1211 | - | let | |
1212 | - | let | |
1213 | - | let | |
1214 | - | let | |
1215 | - | let | |
1216 | - | let | |
1217 | - | if ((size( | |
1209 | + | @Callable(ak) | |
1210 | + | func replenishFromLand (eE) = valueOrElse(am(ak), { | |
1211 | + | let fF = eD(eE) | |
1212 | + | let aJ = fF._1 | |
1213 | + | let aG = fF._2 | |
1214 | + | let bA = fF._3 | |
1215 | + | let dG = fF._4 | |
1216 | + | let bB = fF._5 | |
1217 | + | let dH = fF._6 | |
1218 | + | let aA = fF._7 | |
1219 | + | let aB = fF._8 | |
1220 | + | let az = fF._9 | |
1221 | + | let eG = fF._10 | |
1222 | + | let eH = fF._11 | |
1223 | + | if ((size(ak.payments) != 1)) | |
1218 | 1224 | then throw("Wrong payment size") | |
1219 | - | else if (if (( | |
1225 | + | else if (if ((aQ(ak.payments[0].assetId) != eG)) | |
1220 | 1226 | then true | |
1221 | - | else ( | |
1227 | + | else (ak.payments[0].amount != eH)) | |
1222 | 1228 | then throw("Wrong payment") | |
1223 | 1229 | else { | |
1224 | - | let | |
1225 | - | then $Tuple2(( | |
1226 | - | else $Tuple2( | |
1227 | - | let | |
1228 | - | let | |
1229 | - | let | |
1230 | - | let | |
1231 | - | let | |
1232 | - | let | |
1233 | - | let | |
1234 | - | let | |
1235 | - | let | |
1236 | - | $Tuple2(((( | |
1230 | + | let fG = if ((dG == eG)) | |
1231 | + | then $Tuple2((bA + ak.payments[0].amount), bB) | |
1232 | + | else $Tuple2(bA, (bB + ak.payments[0].amount)) | |
1233 | + | let fH = fG._1 | |
1234 | + | let fI = fG._2 | |
1235 | + | let bi = valueOrErrorMessage(getString(this, (N + aG)), "Unknown pool") | |
1236 | + | let fJ = cN(bi, aG, g, fH, dG, fI, dH, aA, aB, az) | |
1237 | + | let fu = fJ._1 | |
1238 | + | let dW = fJ._2 | |
1239 | + | let cZ = aI(aJ) | |
1240 | + | let fK = [IntegerEntry((((((aG + "_") + aJ) + "_") + toString(cZ)) + w), eH), StringEntry((((((aG + "_") + aJ) + "_") + toString(cZ)) + x), eG)] | |
1241 | + | let fL = cX(aG, aJ, fu, dW, cZ, az, bi, true) | |
1242 | + | $Tuple2((((fL ++ bv(dG, dH, az)) ++ fK) :+ DeleteEntry((eE + L))), fu) | |
1237 | 1243 | } | |
1238 | 1244 | }) | |
1239 | 1245 | ||
1240 | 1246 | ||
1241 | 1247 | ||
1242 | - | @Callable( | |
1243 | - | func liquidate ( | |
1244 | - | let | |
1245 | - | let | |
1246 | - | let | |
1247 | - | let | |
1248 | - | let | |
1249 | - | let | |
1250 | - | let | |
1251 | - | let | |
1252 | - | let | |
1253 | - | let | |
1254 | - | let | |
1255 | - | let | |
1256 | - | if (( | |
1248 | + | @Callable(ak) | |
1249 | + | func liquidate (aJ,eq,fM) = valueOrElse(am(ak), { | |
1250 | + | let aG = valueOrErrorMessage(getString(this, (((aJ + "_") + eq) + v)), "no position") | |
1251 | + | let bi = valueOrErrorMessage(getString(this, (N + aG)), "Pool is not inited") | |
1252 | + | let fN = aC(Address(fromBase58String(aG)), bi) | |
1253 | + | let dG = fN._1 | |
1254 | + | let dH = fN._2 | |
1255 | + | let aA = fN._3 | |
1256 | + | let aB = fN._4 | |
1257 | + | let az = fN._5 | |
1258 | + | let bO = bP(aG, bi, az, fM) | |
1259 | + | let cC = getIntegerValue(this, (((((aG + "_") + aJ) + "_") + eq) + w)) | |
1260 | + | let ea = getStringValue(this, (((((aG + "_") + aJ) + "_") + eq) + x)) | |
1261 | + | let dY = ep(aJ, aG, eq, (cC > 0)) | |
1262 | + | if ((cC == 0)) | |
1257 | 1263 | then throw("You can't liquidate position without borrow") | |
1258 | - | else [IntegerEntry(((((( | |
1264 | + | else [IntegerEntry((((((aG + "_") + aJ) + "_") + eq) + z), getIntegerValue(this, (aG + C))), IntegerEntry((aG + B), (aH(aG) - fM)), IntegerEntry((aG + A), (aF(aG) - fM)), IntegerEntry((((((aG + "_") + aJ) + "_") + eq) + u), (dY - fM)), ScriptTransfer(ak.caller, bO, fromBase58String(az))] | |
1259 | 1265 | }) | |
1260 | 1266 | ||
1261 | 1267 | ||
1262 | 1268 | ||
1263 | - | @Callable( | |
1264 | - | func stopLoss ( | |
1265 | - | let | |
1266 | - | if ($isInstanceOf( | |
1267 | - | then | |
1268 | - | else throw(($getType( | |
1269 | - | if (!(isDefined(getInteger(this, ((((((( | |
1269 | + | @Callable(ak) | |
1270 | + | func stopLoss (aJ,eq,aG,ao) = valueOrElse(aj(ak), { | |
1271 | + | let fx = ( let aw = invoke(ad, "getTWAP60", [ao, false], nil) | |
1272 | + | if ($isInstanceOf(aw, "(Int, Int)")) | |
1273 | + | then aw | |
1274 | + | else throw(($getType(aw) + " couldn't be cast to (Int, Int)")))._1 | |
1275 | + | if (!(isDefined(getInteger(this, (((((((aJ + "_") + toString(eq)) + "_") + aG) + "_") + ao) + R))))) | |
1270 | 1276 | then throw("No entry") | |
1271 | - | else ( | |
1277 | + | else (ev(toString(ak.caller), aG, toString(eq), true) :+ DeleteEntry((((((((aJ + "_") + toString(eq)) + "_") + aG) + "_") + ao) + R))) | |
1272 | 1278 | }) | |
1273 | 1279 | ||
1274 | 1280 | ||
1275 | 1281 | ||
1276 | - | @Callable( | |
1277 | - | func capitalizeExKeeper ( | |
1278 | - | let | |
1279 | - | then | |
1282 | + | @Callable(ak) | |
1283 | + | func capitalizeExKeeper (aG,aD,fO,fP,fQ,dk,dl,dm,dn,do,dp,dq) = valueOrElse(aj(ak), { | |
1284 | + | let fR = if (fQ) | |
1285 | + | then cK(aD, aG) | |
1280 | 1286 | else { | |
1281 | - | let | |
1282 | - | then | |
1283 | - | else | |
1284 | - | $Tuple2( | |
1287 | + | let fS = if ((aD == a)) | |
1288 | + | then af | |
1289 | + | else ag | |
1290 | + | $Tuple2(fP, fS) | |
1285 | 1291 | } | |
1286 | - | let | |
1287 | - | let | |
1288 | - | let | |
1289 | - | let | |
1290 | - | let | |
1291 | - | then [IntegerEntry(( | |
1292 | + | let fT = fR._1 | |
1293 | + | let fS = fR._2 | |
1294 | + | let fU = dg(fO, fP, fS, dk, dl, dm, dn, do, dp, dq) | |
1295 | + | let cu = (fT - fP) | |
1296 | + | let fV = if ((cu > 0)) | |
1297 | + | then [IntegerEntry((aG + P), (cu + valueOrElse(getInteger(this, (aG + P)), 0)))] | |
1292 | 1298 | else nil | |
1293 | - | ( | |
1299 | + | (dC(aG, aD, fO, fU) ++ fV) | |
1294 | 1300 | }) | |
1295 | 1301 | ||
1296 | 1302 | ||
1297 | 1303 | ||
1298 | - | @Callable( | |
1299 | - | func capitalizeExPuzzle ( | |
1300 | - | let | |
1301 | - | then | |
1304 | + | @Callable(ak) | |
1305 | + | func capitalizeExPuzzle (aG,aD,fO,fP,fQ,dt,du,dq) = valueOrElse(aj(ak), { | |
1306 | + | let fW = if (fQ) | |
1307 | + | then cK(aD, aG) | |
1302 | 1308 | else { | |
1303 | - | let | |
1304 | - | then | |
1305 | - | else | |
1306 | - | $Tuple2( | |
1309 | + | let fS = if ((aD == a)) | |
1310 | + | then af | |
1311 | + | else ag | |
1312 | + | $Tuple2(fP, fS) | |
1307 | 1313 | } | |
1308 | - | let | |
1309 | - | let | |
1310 | - | let | |
1311 | - | let | |
1312 | - | let | |
1313 | - | then [IntegerEntry(( | |
1314 | + | let fT = fW._1 | |
1315 | + | let fS = fW._2 | |
1316 | + | let fU = ds(fO, fP, fS, dt, du, dq) | |
1317 | + | let cu = (fT - fP) | |
1318 | + | let fV = if ((cu > 0)) | |
1319 | + | then [IntegerEntry((aG + P), (cu + valueOrElse(getInteger(this, (aG + P)), 0)))] | |
1314 | 1320 | else nil | |
1315 | - | ( | |
1321 | + | (dC(aG, aD, fO, fU) ++ fV) | |
1316 | 1322 | }) | |
1317 | 1323 | ||
1318 | 1324 | ||
1319 | 1325 | ||
1320 | - | @Callable( | |
1321 | - | func capitalizeExSwopFi ( | |
1322 | - | let | |
1323 | - | then | |
1326 | + | @Callable(ak) | |
1327 | + | func capitalizeExSwopFi (aG,aD,fO,fP,fQ,dw,dx,dy,dz,dA,dB,dq) = valueOrElse(aj(ak), { | |
1328 | + | let fX = if (fQ) | |
1329 | + | then cK(aD, aG) | |
1324 | 1330 | else { | |
1325 | - | let | |
1326 | - | then | |
1327 | - | else | |
1328 | - | $Tuple2( | |
1331 | + | let fS = if ((aD == a)) | |
1332 | + | then af | |
1333 | + | else ag | |
1334 | + | $Tuple2(fP, fS) | |
1329 | 1335 | } | |
1330 | - | let | |
1331 | - | let | |
1332 | - | let | |
1333 | - | let | |
1334 | - | let | |
1335 | - | then [IntegerEntry(( | |
1336 | + | let fT = fX._1 | |
1337 | + | let fS = fX._2 | |
1338 | + | let fU = dv(fO, fP, fS, dw, dx, dy, dz, dA, dB, dq) | |
1339 | + | let cu = (fT - fP) | |
1340 | + | let fV = if ((cu > 0)) | |
1341 | + | then [IntegerEntry((aG + P), (cu + valueOrElse(getInteger(this, (aG + P)), 0)))] | |
1336 | 1342 | else nil | |
1337 | - | ( | |
1343 | + | (dC(aG, aD, fO, fU) ++ fV) | |
1338 | 1344 | }) | |
1339 | 1345 | ||
1340 | 1346 | ||
1341 | 1347 | ||
1342 | - | @Callable( | |
1343 | - | func initNewPool ( | |
1344 | - | then ( | |
1348 | + | @Callable(ak) | |
1349 | + | func initNewPool (aD,at,fY,fZ,ga,gb,gc,gd,ge) = valueOrElse(aj(ak), if (if ((aD != a)) | |
1350 | + | then (aD != b) | |
1345 | 1351 | else false) | |
1346 | 1352 | then throw("Wrong type") | |
1347 | 1353 | else { | |
1348 | - | let | |
1349 | - | let | |
1350 | - | let | |
1351 | - | let | |
1352 | - | let | |
1353 | - | let | |
1354 | - | [IntegerEntry(( | |
1354 | + | let gf = aC(Address(fromBase58String(at)), aD) | |
1355 | + | let ax = gf._1 | |
1356 | + | let ay = gf._2 | |
1357 | + | let gg = gf._3 | |
1358 | + | let gh = gf._4 | |
1359 | + | let az = gf._5 | |
1360 | + | [IntegerEntry((at + F), fY), IntegerEntry((at + G), fZ), IntegerEntry((at + H), ga), IntegerEntry((at + I), gb), IntegerEntry((at + J), gc), IntegerEntry((at + K), gd), IntegerEntry((at + C), 0), IntegerEntry((at + D), 0), StringEntry((N + at), aD), StringEntry((az + O), at), BooleanEntry((at + E), ge)] | |
1355 | 1361 | }) | |
1356 | 1362 | ||
1357 | 1363 | ||
1358 | - | @Verifier( | |
1359 | - | func | |
1364 | + | @Verifier(gi) | |
1365 | + | func gj () = sigVerify(gi.bodyBytes, gi.proofs[0], gi.senderPublicKey) | |
1360 | 1366 |
github/deemru/w8io/169f3d6 547.27 ms ◑![]()