tx · MKVGba9sen5yMEmFZwnYPjKw6jrWayBc21yHXCrWDL1

3MvRWw2FPEimFCTGtK7qY9uAJbM7XJ4ZfJS:  -0.04500000 Waves

2023.06.16 11:44 [2624965] smart account 3MvRWw2FPEimFCTGtK7qY9uAJbM7XJ4ZfJS > SELF 0.00000000 Waves

{ "type": 13, "id": "MKVGba9sen5yMEmFZwnYPjKw6jrWayBc21yHXCrWDL1", "fee": 4500000, "feeAssetId": null, "timestamp": 1686905116011, "version": 2, "chainId": 84, "sender": "3MvRWw2FPEimFCTGtK7qY9uAJbM7XJ4ZfJS", "senderPublicKey": "HP8sssVq1866F7CaPQJwgFrt6fsqhQjKwM84cL1wjD2a", "proofs": [ "2SUMmbjZwGLrQo8uQAsDYe8ameUMESs5vphqtDU9MwrHTGCRfUYegXqQU6Lbqy3KtvJL59VnQ1PQNya3eDsh42vn" ], "script": "base64:BgKKAQgCEgcKBQgBCAEBEgMKAQgSBAoCCAgSBQoDCBgYEgUKAwgBCBIECgIIARIGCgQBCAgBEgUKAwEICBIDCgEIEgMKAQgSBQoDCAgBEgYKBAgBCAgSDgoMCAgIAQQRGBgRAQEYEgoKCAgICAEECAEYEg4KDAgICAEEGBgYGBgBGBIKCggICAEBAQEBAWUAB1NGX1BPT0wCAlNGAAdXWF9QT09MAgJXWAAPQ0FQX0ZFRV9OT19MT0FOAgljYXBOb0xvYW4ADENBUF9GRUVfTE9BTgIHY2FwTG9hbgAUU1RPUExPU1NfRkVFX05PX0xPQU4CDnN0b3BMb3NzTm9Mb2FuAA1TVE9QTE9TU19MT0FOAgxzdG9wTG9zc0xvYW4ACExPQU5fRkVFAgRsb2FuAAtOT19MT0FOX0ZFRQIGbm9Mb2FuAAZOT19GRUUCBW5vRmVlAAZTQ0FMRTgAgMLXLwAHU0NBTEUxMACAyK+gJQAKRkVFX1NDQUxFNgDAhD0AFGtTRlBvb2xBQXNzZXRCYWxhbmNlAg9BX2Fzc2V0X2JhbGFuY2UAFGtTRlBvb2xCQXNzZXRCYWxhbmNlAg9CX2Fzc2V0X2JhbGFuY2UAD2tTRlBvb2xBQXNzZXRJZAIKQV9hc3NldF9pZAAPa1NGUG9vbEJBc3NldElkAgpCX2Fzc2V0X2lkAA5rU0ZQb29sU2hhcmVJZAIOc2hhcmVfYXNzZXRfaWQAEmtTRlBvb2xTaGFyZVN1cHBseQISc2hhcmVfYXNzZXRfc3VwcGx5AAprU0ZQb29sRmVlAgpjb21taXNzaW9uAA1rVXNlclBvc2l0aW9uAg5fdXNlcl9wb3NpdGlvbgARa1VzZXJQb3NpdGlvblBvb2wCE191c2VyX3Bvc2l0aW9uX3Bvb2wAEWtVc2VyQm9ycm93QW1vdW50AhxfdXNlcl9wb3NpdGlvbl9ib3Jyb3dfYW1vdW50ABJrVXNlckJvcnJvd0Fzc2V0SWQCHl91c2VyX3Bvc2l0aW9uX2JvcnJvd19hc3NldF9pZAAQa1VzZXJQb3NpdGlvbk51bQIVX3VzZXJfcG9zaXRpb25fbnVtYmVyABVrVXNlclBvc2l0aW9uSW50ZXJlc3QCF191c2VyX3Bvc2l0aW9uX2ludGVyZXN0AAprUG9vbFRvdGFsAgtfcG9vbF90b3RhbAAOa1Bvb2xUb3RhbExvYW4CEF9wb29sX3RvdGFsX2xvYW4AEWtQb29sSW50ZXJlc3RMb2FuAhNfcG9vbF9pbnRlcmVzdF9sb2FuABNrUG9vbEludGVyZXN0Tm9Mb2FuAhZfcG9vbF9pbnRlcmVzdF9ub19sb2FuABVrQXhseUluRmVlV2l0aG91dExvYW4CFl9heGx5X2ZlZV93aXRob3V0X2xvYW4AEmtBeGx5SW5GZWVXaXRoTG9hbgITX2F4bHlfZmVlX3dpdGhfbG9hbgARa0F4bHlOb0xvYW5DYXBGZWUCF19heGx5X2ZlZV9jYXBfd2l0aF9sb2FuABNrQXhseVdpdGhMb2FuQ2FwRmVlAhVfYXhseV9mZWVfY2FwX25vX2xvYW4AFmtBeGx5U3RvcExvc3NOb0xvYW5GZWUCHF9heGx5X2ZlZV9zdG9wbG9zc193aXRoX2xvYW4AFGtBeGx5U3RvcExvc3NMb2FuRmVlAhpfYXhseV9mZWVfc3RvcGxvc3Nfbm9fbG9hbgAKa1JlcXVlc3RJZAILX3JlcXVlc3RfaWQADGtSZXF1ZXN0SXRlcgINcmVxdWVzdHNfaXRlcgAFa1Bvb2wCBXBvb2xfAAprU2hhcmVQb29sAg5fcG9vbF9zaGFyZV9pZAAOa1Bvb2xDYXBDaGFuZ2UCEF9wb29sX2NhcF9jaGFuZ2UAD2tUb2tlbkxhc3RQcmljZQIKbGFzdF9wcmljZQANa1VzZXJTdG9wTG9zcwIKX3N0b3BfbG9zcwAJa01vbmV5Qm94Ag5heGx5X21vbmV5X2JveAAOa1NGRmFybWluZ0FkZHICE3N3b3BmaV9mYXJtaW5nX2FkZHIADGtMZW5kU2VydmljZQIRbGVuZF9zZXJ2aWNlX2FkZHIADGtBZG1pbkNhbGxQSwISYWRtaW5fY2FsbF9wdWJfa2V5AAxrUHJpY2VPcmFjbGUCDHByaWNlX29yYWNsZQALa0V4Q29udHJhY3QCEWV4Y2hhbmdlX2NvbnRyYWN0AA9rV3hTd2FwQ29udHJhY3QCEHd4X3N3YXBfY29udHJhY3QACG1vbmV5Qm94CQEHQWRkcmVzcwEJANkEAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMFCWtNb25leUJveAIYTm8gYXhseSBtb25leUJveCBhZGRyZXNzAApleENvbnRyYWN0CQEHQWRkcmVzcwEJANkEAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMFC2tFeENvbnRyYWN0AhxObyBleGNoYW5nZSBjb250cmFjdCBhZGRyZXNzAA9wcmljZU9yYWNsZUFkZHIJAQdBZGRyZXNzAQkA2QQBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwUMa1ByaWNlT3JhY2xlAhdObyBwcmljZSBvcmFjbGUgYWRkcmVzcwAOd3hTd2FwQ29udHJhY3QJAQdBZGRyZXNzAQkA2QQBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwUPa1d4U3dhcENvbnRyYWN0AhJObyB3eCBzd2FwIGFkZHJlc3MABlNXT1BJRAEgNAETVo5gRuJ+W6m4AUeC57EAJhKbduROS6KgfJxt7oEABFdYSUQBIMZSHoFO6m7jPMCXsA5fLPJq6e2dsobRmkJ4qGB9PhuxAQ5nZXRMZW5kU3J2QWRkcgAJAQdBZGRyZXNzAQkA2QQBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwUMa0xlbmRTZXJ2aWNlAhtDYW4ndCBnZXQgbGVuZCBzZXJ2aWNlIGFkZHIBEGdldEFkbWluQ2FsbEFkZHIACQCnCAEJANkEAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMFDGtBZG1pbkNhbGxQSwIbQ2FuJ3QgZ2V0IGxlbmQgc2VydmljZSBhZGRyAQtpc0FkbWluQ2FsbAEBaQMJAAACCAUBaQZjYWxsZXIJARBnZXRBZG1pbkNhbGxBZGRyAAUEdW5pdAkAAgECIU9ubHkgYWRtaW4gY2FuIGNhbGwgdGhpcyBmdW5jdGlvbgEKaXNTZWxmQ2FsbAEBaQMJAAACCAUBaQZjYWxsZXIFBHRoaXMFBHVuaXQJAAIBAitPbmx5IGNvbnRyYWN0IGl0c2VsZiBjYW4gY2FsbCB0aGlzIGZ1bmN0aW9uAQppc0xhbmRDYWxsAQFpAwkAAAIIBQFpBmNhbGxlcgkBDmdldExlbmRTcnZBZGRyAAUEdW5pdAkAAgECKU9ubHkgbGFuZCBjb250cmFjdCBjYW4gY2FsbCB0aGlzIGZ1bmN0aW9uAQ5hY2NvdW50QmFsYW5jZQEHYXNzZXRJZAQHJG1hdGNoMAUHYXNzZXRJZAMJAAECBQckbWF0Y2gwAgpCeXRlVmVjdG9yBAJpZAUHJG1hdGNoMAkA8AcCBQR0aGlzBQJpZAMJAAECBQckbWF0Y2gwAgRVbml0BAV3YXZlcwUHJG1hdGNoMAgJAO8HAQUEdGhpcwlhdmFpbGFibGUJAAIBAgtNYXRjaCBlcnJvcgENZ2V0U0ZQb29sRGF0YQEIcG9vbEFkZHIJAJcKBQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFCHBvb2xBZGRyBQ9rU0ZQb29sQUFzc2V0SWQCGUNhbid0IGdldCBwb29sIEEgYXNzZXQgaWQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQhwb29sQWRkcgUPa1NGUG9vbEJBc3NldElkAhlDYW4ndCBnZXQgcG9vbCBCIGFzc2V0IGlkCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUIcG9vbEFkZHIFFGtTRlBvb2xBQXNzZXRCYWxhbmNlAh5DYW4ndCBnZXQgcG9vbCBBIGFzc2V0IGJhbGFuY2UJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQhwb29sQWRkcgUUa1NGUG9vbEJBc3NldEJhbGFuY2UCHkNhbid0IGdldCBwb29sIEIgYXNzZXQgYmFsYW5jZQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFCHBvb2xBZGRyBQ5rU0ZQb29sU2hhcmVJZAIYQ2FuJ3QgZ2V0IHNoYXJlIGFzc2V0IGlkAQ1nZXRXWFBvb2xEYXRhAQhwb29sQWRkcgQDY2ZnCgABQAkA/AcEBQhwb29sQWRkcgIcZ2V0UG9vbENvbmZpZ1dyYXBwZXJSRUFET05MWQUDbmlsBQNuaWwDCQABAgUBQAIJTGlzdFtBbnldBQFACQACAQkArAICCQADAQUBQAIeIGNvdWxkbid0IGJlIGNhc3QgdG8gTGlzdFtBbnldAwkAAAIFA2NmZwUDY2ZnBANhSWQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgoAAUAJAJEDAgUDY2ZnAAQDCQABAgUBQAIGU3RyaW5nBQFABQR1bml0AhlDYW4ndCBnZXQgcG9vbCBBIGFzc2V0IGlkBANiSWQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgoAAUAJAJEDAgUDY2ZnAAUDCQABAgUBQAIGU3RyaW5nBQFABQR1bml0AhlDYW4ndCBnZXQgcG9vbCBCIGFzc2V0IGlkBAdzaGFyZUlkCQETdmFsdWVPckVycm9yTWVzc2FnZQIKAAFACQCRAwIFA2NmZwADAwkAAQIFAUACBlN0cmluZwUBQAUEdW5pdAIaQ2FuJ3QgZ2V0IHBvb2wgTFAgYXNzZXQgaWQEBGJhbEEKAAFACQD8BwQFCHBvb2xBZGRyAhxnZXRBY2NCYWxhbmNlV3JhcHBlclJFQURPTkxZCQDMCAIFA2FJZAUDbmlsBQNuaWwDCQABAgUBQAIDSW50BQFACQACAQkArAICCQADAQUBQAIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50AwkAAAIFBGJhbEEFBGJhbEEEBGJhbEIKAAFACQD8BwQFCHBvb2xBZGRyAhxnZXRBY2NCYWxhbmNlV3JhcHBlclJFQURPTkxZCQDMCAIFA2JJZAUDbmlsBQNuaWwDCQABAgUBQAIDSW50BQFACQACAQkArAICCQADAQUBQAIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50AwkAAAIFBGJhbEIFBGJhbEIJAJcKBQUDYUlkBQNiSWQFBGJhbEEFBGJhbEIFB3NoYXJlSWQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BC2dldFBvb2xEYXRhAghwb29sQWRkcgR0eXBlAwkAAAIFBHR5cGUFB1NGX1BPT0wJAQ1nZXRTRlBvb2xEYXRhAQUIcG9vbEFkZHIDCQAAAgUEdHlwZQUHV1hfUE9PTAkBDWdldFdYUG9vbERhdGEBBQhwb29sQWRkcgkAAgECD1dyb25nIHBvb2wgdHlwZQEOZ2V0U2hhcmVTdXBwbHkDCHBvb2xBZGRyBHR5cGUHc2hhcmVJZAMJAAACBQR0eXBlBQdTRl9QT09MCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUIcG9vbEFkZHIFEmtTRlBvb2xTaGFyZVN1cHBseQIcQ2FuJ3QgZ2V0IHNoYXJlIGFzc2V0IHN1cHBseQMJAAACBQR0eXBlBQdXWF9QT09MCAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQDsBwEJANkEAQUHc2hhcmVJZAINV3JvbmcgU2hhcmVJZAhxdWFudGl0eQkAAgECD1dyb25nIHBvb2wgdHlwZQERZ2V0UG9vbFRvdGFsU2hhcmUBBHBvb2wJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkArAICBQRwb29sBQprUG9vbFRvdGFsAAABGWdldFBvb2xUb3RhbFNoYXJlV2l0aExvYW4BBHBvb2wJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkArAICBQRwb29sBQ5rUG9vbFRvdGFsTG9hbgAAARhnZXROZXdVc2VyUG9zaXRpb25OdW1iZXIBBHVzZXIJAGQCCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAKwCAgUEdXNlcgUQa1VzZXJQb3NpdGlvbk51bQAAAAEBCmdldEF4bHlGZWUCBHBvb2wHZmVlVHlwZQMJAAACBQdmZWVUeXBlBQxDQVBfRkVFX0xPQU4JARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAKwCAgUEcG9vbAUTa0F4bHlXaXRoTG9hbkNhcEZlZQMJAAACBQdmZWVUeXBlBQ9DQVBfRkVFX05PX0xPQU4JARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAKwCAgUEcG9vbAURa0F4bHlOb0xvYW5DYXBGZWUDCQAAAgUHZmVlVHlwZQUITE9BTl9GRUUJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAKwCAgUEcG9vbAUSa0F4bHlJbkZlZVdpdGhMb2FuAwkAAAIFB2ZlZVR5cGUFC05PX0xPQU5fRkVFCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzCQCsAgIFBHBvb2wFFWtBeGx5SW5GZWVXaXRob3V0TG9hbgMJAAACBQdmZWVUeXBlBQZOT19GRUUAAAkAAgECDldyb25nIGZlZSB0eXBlARBnZXRTRkZhcm1pbmdBZGRyAAkBB0FkZHJlc3MBCQDZBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzBQ5rU0ZGYXJtaW5nQWRkcgIdQ2FuJ3QgZ2V0IHN3b3BmaSBmYXJtaW5nIGFkZHIBEGdldFdYRmFybWluZ0FkZHIBCHBvb2xBZGRyBAlmQ29udHJhY3QJAQdBZGRyZXNzAQkA2QQBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUIcG9vbEFkZHICEyVzX19mYWN0b3J5Q29udHJhY3QCIkNhbid0IGdldCBXWCBmYWN0b3J5IGNvbnRyYWN0IGFkZHIECmZhY3Ryb3lDZmcJALUJAgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFCWZDb250cmFjdAIRJXNfX2ZhY3RvcnlDb25maWcCGENhbid0IGdldCBXWCBmYWN0b3J5IGNmZwICX18JAQdBZGRyZXNzAQkA2QQBCQCRAwIFCmZhY3Ryb3lDZmcAAQEMYXNzZXRJZFRvU3RyAQdhc3NldElkBAckbWF0Y2gwBQdhc3NldElkAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEAmlkBQckbWF0Y2gwCQDYBAEFAmlkAwkAAQIFByRtYXRjaDACBFVuaXQEBXdhdmVzBQckbWF0Y2gwAgVXQVZFUwkAAgECC01hdGNoIGVycm9yAQ5hc3NldElkRnJvbVN0cgEHYXNzZXRJZAMJAAACBQdhc3NldElkAgVXQVZFUwUEdW5pdAkA2QQBBQdhc3NldElkARBnZXRBc3NldERlY2ltYWxzAQdhc3NldElkAwkAAAIFB2Fzc2V0SWQCBVdBVkVTAAgEByRtYXRjaDAJAOwHAQkA2QQBBQdhc3NldElkAwkAAQIFByRtYXRjaDACBUFzc2V0BAVhc3NldAUHJG1hdGNoMAgFBWFzc2V0CGRlY2ltYWxzCQACAQIQQ2FuJ3QgZmluZCBhc3NldAERZ2V0QXNzZXRQcmVjaXRpb24BB2Fzc2V0SWQJAGwGAAoAAAkBEGdldEFzc2V0RGVjaW1hbHMBBQdhc3NldElkAAAAAAUERE9XTgEOZ2V0QXNzZXRzUHJpY2UBCGFzc2V0SWRzCgEJZ2V0UHJpY2VzAgFhB2Fzc2V0SWQECmFzc2V0UHJpY2UICgABQAkA/AcEBQ9wcmljZU9yYWNsZUFkZHICCWdldFRXQVA2MAkAzAgCBQdh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YmFsQgQNJHQwMTAxMDMxMDQwOAMJAAACBQVwVHlwZQUHU0ZfUE9PTAkAlAoCBQNuaWwFA25pbAkAlAoCCQC1CQIKAAFACQD8BwQFCHBvb2xBZGRyAiBldmFsdWF0ZVB1dEJ5QW1vdW50QXNzZXRSRUFET05MWQkAzAgCBQRwbXRBBQNuaWwFA25pbAMJAAECBQFAAgZTdHJpbmcFAUAJAAIBCQCsAgIJAAMBBQFAAhsgY291bGRuJ3QgYmUgY2FzdCB0byBTdHJpbmcCAl9fCQC1CQIKAAFACQD8BwQFCHBvb2xBZGRyAh9ldmFsdWF0ZVB1dEJ5UHJpY2VBc3NldFJFQURPTkxZCQDMCAIFBHBtdEIFA25pbAUDbmlsAwkAAQIFAUACBlN0cmluZwUBQAkAAgEJAKwCAgkAAwEFAUACGyBjb3VsZG4ndCBiZSBjYXN0IHRvIFN0cmluZwICX18DCQAAAgUNJHQwMTAxMDMxMDQwOAUNJHQwMTAxMDMxMDQwOAQKZXZhbFB1dEluQggFDSR0MDEwMTAzMTA0MDgCXzIECmV2YWxQdXRJbkEIBQ0kdDAxMDEwMzEwNDA4Al8xBA0kdDAxMDQxODEwNjE0AwkAAAIFBXBUeXBlBQdTRl9QT09MCQCUCgIJAGsDBQZTQ0FMRTgFBHBtdEEFBGJhbEEJAGsDBQZTQ0FMRTgFBHBtdEIFBGJhbEIJAJQKAgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCmV2YWxQdXRJbkEAAQkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCmV2YWxQdXRJbkIAAQQGcmF0aW9BCAUNJHQwMTA0MTgxMDYxNAJfMQQGcmF0aW9CCAUNJHQwMTA0MTgxMDYxNAJfMgQNJHQwMTA2MjAxMTEwMgMJAGYCBQZyYXRpb0IFBnJhdGlvQQQDcG10AwkAAAIFBXBUeXBlBQdTRl9QT09MCQBuBAUEYmFsQgUGcmF0aW9BBQZTQ0FMRTgFB0NFSUxJTkcJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQpldmFsUHV0SW5BAAgJAJcKBQUEcG10QQUDcG10CQBlAgUEcG10QgUDcG10BQNiSWQFBnJhdGlvQgQDcG10AwkAAAIFBXBUeXBlBQdTRl9QT09MCQBuBAUEYmFsQQUGcmF0aW9CBQZTQ0FMRTgFB0NFSUxJTkcJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQpldmFsUHV0SW5CAAcJAJcKBQUDcG10BQRwbXRCCQBlAgUEcG10QQUDcG10BQNhSWQFBnJhdGlvQQQGcG10SW5BCAUNJHQwMTA2MjAxMTEwMgJfMQQGcG10SW5CCAUNJHQwMTA2MjAxMTEwMgJfMgQGY2hhbmdlCAUNJHQwMTA2MjAxMTEwMgJfMwQNY2hhbmdlQXNzZXRJZAgFDSR0MDEwNjIwMTExMDICXzQEAmxwCAUNJHQwMTA2MjAxMTEwMgJfNQkAlwoFBQZwbXRJbkEFBnBtdEluQgUGY2hhbmdlBQ1jaGFuZ2VBc3NldElkBQJscAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgEYcmVwbGVuaXNoVHdvVG9rZW5zQnlUeXBlBghwb29sQWRkcgVwVHlwZQRwbXRBA2FJZARwbXRCA2JJZAQIcGF5bWVudHMJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJAQ5hc3NldElkRnJvbVN0cgEFA2FJZAUEcG10QQkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkBDmFzc2V0SWRGcm9tU3RyAQUDYklkBQRwbXRCBQNuaWwDCQAAAgUFcFR5cGUFB1NGX1BPT0wJAPwHBAUIcG9vbEFkZHICDGNhbGxGdW5jdGlvbgkAzAgCAhZyZXBsZW5pc2hXaXRoVHdvVG9rZW5zCQDMCAIJAMwIAgIFZmFsc2UJAMwIAgIBMAUDbmlsBQNuaWwFCHBheW1lbnRzCQD8BwQFCHBvb2xBZGRyAgNwdXQJAMwIAgDAhD0JAMwIAgcFA25pbAUIcGF5bWVudHMBF3JlcGxlbmlzaE9uZVRva2VuQnlUeXBlBAhwb29sQWRkcgVwVHlwZQNwbXQFcG10SWQECHBheW1lbnRzCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQEOYXNzZXRJZEZyb21TdHIBBQVwbXRJZAUDcG10BQNuaWwDCQAAAgUFcFR5cGUFB1NGX1BPT0wJAPwHBAUIcG9vbEFkZHICDGNhbGxGdW5jdGlvbgkAzAgCAhVyZXBsZW5pc2hXaXRoT25lVG9rZW4JAMwIAgkAzAgCAgEwCQDMCAICBWZhbHNlCQDMCAICATAFA25pbAUDbmlsBQhwYXltZW50cwkA/AcEBQhwb29sQWRkcgIJcHV0T25lVGtuCQDMCAIAAAkAzAgCBwUDbmlsBQhwYXltZW50cwEHc3Rha2VMUAQEcG9vbAVwVHlwZQdzaGFyZUlkBmFtb3VudAQIcGF5bWVudHMJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJANkEAQUHc2hhcmVJZAUGYW1vdW50BQNuaWwDCQAAAgUFcFR5cGUFB1NGX1BPT0wJAPwHBAkBEGdldFNGRmFybWluZ0FkZHIAAg9sb2NrU2hhcmVUb2tlbnMJAMwIAgUEcG9vbAkAzAgCAAAFA25pbAUIcGF5bWVudHMJAPwHBAkBEGdldFdYRmFybWluZ0FkZHIBCQERQGV4dHJOYXRpdmUoMTA2MikBBQRwb29sAgVzdGFrZQUDbmlsBQhwYXltZW50cwEJdW5zdGFrZUxQBARwb29sBXBUeXBlB3NoYXJlSWQGYW1vdW50BA0kdDAxMjMzMjEyNjg5AwkAAAIFBXBUeXBlBQdTRl9QT09MCQCVCgMJARBnZXRTRkZhcm1pbmdBZGRyAAITd2l0aGRyYXdTaGFyZVRva2VucwkAzAgCBQRwb29sCQDMCAIFBmFtb3VudAUDbmlsAwkAAAIFBXBUeXBlBQdXWF9QT09MCQCVCgMJARBnZXRXWEZhcm1pbmdBZGRyAQkBB0FkZHJlc3MBCQDZBAEFBHBvb2wCB3Vuc3Rha2UJAMwIAgUHc2hhcmVJZAkAzAgCBQZhbW91bnQFA25pbAkAAgECD1dyb25nIHBvb2wgdHlwZQQIZmFybUFkZHIIBQ0kdDAxMjMzMjEyNjg5Al8xBAVmTmFtZQgFDSR0MDEyMzMyMTI2ODkCXzIEBnBhcmFtcwgFDSR0MDEyMzMyMTI2ODkCXzMEA2ludgkA/AcEBQhmYXJtQWRkcgUFZk5hbWUFBnBhcmFtcwUDbmlsAwkAAAIFA2ludgUDaW52BQZhbW91bnQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BEWNhbGNBbW91bnRUb1BheVNGBwRwb29sCGFzc2V0SWRBCGFzc2V0SWRCBGJhbEEEYmFsQhBhbW91bnRUb2tlblRvR2V0D2Fzc2V0VG9rZW5Ub0dldAQIcG9vbEFkZHIJAQdBZGRyZXNzAQkA2QQBBQRwb29sBAlmZWVTY2FsZTYAwIQ9BANmZWUJARFAZXh0ck5hdGl2ZSgxMDUwKQIFCHBvb2xBZGRyBQprU0ZQb29sRmVlBAxhbW50R2V0Tm9GZWUJAGsDBRBhbW91bnRUb2tlblRvR2V0BQlmZWVTY2FsZTYJAGUCBQlmZWVTY2FsZTYFA2ZlZQQNJHQwMTMxMDIxMzM5MAMJAAACBQ9hc3NldFRva2VuVG9HZXQFCGFzc2V0SWRBBAthbW91bnRUb1BheQkAawMFBGJhbEEFDGFtbnRHZXROb0ZlZQkAZQIFBGJhbEIFDGFtbnRHZXROb0ZlZQkAlAoCBQthbW91bnRUb1BheQUIYXNzZXRJZEIEC2Ftb3VudFRvUGF5CQBrAwUEYmFsQgUMYW1udEdldE5vRmVlCQBlAgUEYmFsQQUMYW1udEdldE5vRmVlCQCUCgIFC2Ftb3VudFRvUGF5BQhhc3NldElkQQQLYW1vdW50VG9QYXkIBQ0kdDAxMzEwMjEzMzkwAl8xBAphc3NldFRvUGF5CAUNJHQwMTMxMDIxMzM5MAJfMgkAlAoCBQphc3NldFRvUGF5BQthbW91bnRUb1BheQERY2FsY0Ftb3VudFRvUGF5V1gHBHBvb2wIYXNzZXRJZEEIYXNzZXRJZEIEYmFsQQRiYWxCEGFtb3VudFRva2VuVG9HZXQPYXNzZXRUb2tlblRvR2V0BAVwckZlZQkBEUBleHRyTmF0aXZlKDEwNTApAgUOd3hTd2FwQ29udHJhY3QCDyVzX19wcm90b2NvbEZlZQQEcEZlZQkBEUBleHRyTmF0aXZlKDEwNTApAgUOd3hTd2FwQ29udHJhY3QCCyVzX19wb29sRmVlBAhmZWVTY2FsZQkAtgIBAIDC1y8EDSR0MDEzNzI5MTQwMzcDCQAAAgUPYXNzZXRUb2tlblRvR2V0BQhhc3NldElkQQQLYW1vdW50VG9QYXkJAGsDBQRiYWxBBRBhbW91bnRUb2tlblRvR2V0CQBlAgUEYmFsQgUQYW1vdW50VG9rZW5Ub0dldAkAlAoCBQthbW91bnRUb1BheQUIYXNzZXRJZEIEC2Ftb3VudFRvUGF5CQBrAwUEYmFsQgUQYW1vdW50VG9rZW5Ub0dldAkAZQIFBGJhbEEFEGFtb3VudFRva2VuVG9HZXQJAJQKAgULYW1vdW50VG9QYXkFCGFzc2V0SWRBBAthbW91bnRUb1BheQgFDSR0MDEzNzI5MTQwMzcCXzEECmFzc2V0VG9QYXkIBQ0kdDAxMzcyOTE0MDM3Al8yBBJhbW91bnRUb1BheVdpdGhGZWUJAKADAQkAvAIDCQC2AgEFC2Ftb3VudFRvUGF5BQhmZWVTY2FsZQkAuAICBQhmZWVTY2FsZQkAtgIBCQBkAgUFcHJGZWUFBHBGZWUJAJQKAgUKYXNzZXRUb1BheQUSYW1vdW50VG9QYXlXaXRoRmVlARBleGNoYW5nZURpcmVjdGx5CAR0eXBlBHBvb2wIYXNzZXRJZEEIYXNzZXRJZEIEYmFsQQRiYWxCEGFtb3VudFRva2VuVG9HZXQPYXNzZXRUb2tlblRvR2V0AwkAAAIFBHR5cGUFB1NGX1BPT0wEDSR0MDE0Mzc1MTQ0OTcJARFjYWxjQW1vdW50VG9QYXlTRgcFBHBvb2wFCGFzc2V0SWRBBQhhc3NldElkQgUEYmFsQQUEYmFsQgUQYW1vdW50VG9rZW5Ub0dldAUPYXNzZXRUb2tlblRvR2V0BAphc3NldFRvUGF5CAUNJHQwMTQzNzUxNDQ5NwJfMQQLYW1vdW50VG9QYXkIBQ0kdDAxNDM3NTE0NDk3Al8yCQD8BwQJARFAZXh0ck5hdGl2ZSgxMDYyKQEFBHBvb2wCDGNhbGxGdW5jdGlvbgkAzAgCAghleGNoYW5nZQkAzAgCCQDMCAICATEFA25pbAUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQEOYXNzZXRJZEZyb21TdHIBBQphc3NldFRvUGF5BQthbW91bnRUb1BheQUDbmlsBA0kdDAxNDY0ODE0NzcwCQERY2FsY0Ftb3VudFRvUGF5V1gHBQRwb29sBQhhc3NldElkQQUIYXNzZXRJZEIFBGJhbEEFBGJhbEIFEGFtb3VudFRva2VuVG9HZXQFD2Fzc2V0VG9rZW5Ub0dldAQKYXNzZXRUb1BheQgFDSR0MDE0NjQ4MTQ3NzACXzEEC2Ftb3VudFRvUGF5CAUNJHQwMTQ2NDgxNDc3MAJfMgkA/AcEBQ53eFN3YXBDb250cmFjdAIEc3dhcAkAzAgCAAEJAMwIAgUPYXNzZXRUb2tlblRvR2V0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T0wJARFjYWxjQW1vdW50VG9QYXlTRgcFBHBvb2wFA2FJZAUDYklkBQRiYWxBBQRiYWxCBQ1hbW91bnRUb0dldEV4BQ1ib3Jyb3dBc3NldElkCQERY2FsY0Ftb3VudFRvUGF5V1gHBQRwb29sBQNhSWQFA2JJZAUEYmFsQQUEYmFsQgUNYW1vdW50VG9HZXRFeAUNYm9ycm93QXNzZXRJZAkAlAoCAgAAAAQKYXNzZXRUb1BheQgFDSR0MDE2OTk0MTcyOTcCXzEEC2Ftb3VudFRvUGF5CAUNJHQwMTY5OTQxNzI5NwJfMgMJAAACBQ1ib3Jyb3dBc3NldElkBQNhSWQJAJQKAgkAZQIJAGQCBQpnZXRBbW91bnRBBQ1hbW91bnRUb0dldEV4BQxib3Jyb3dBbW91bnQJAGUCBQpnZXRBbW91bnRCBQthbW91bnRUb1BheQkAlAoCCQBlAgUKZ2V0QW1vdW50QQULYW1vdW50VG9QYXkJAGUCCQBkAgUKZ2V0QW1vdW50QgUNYW1vdW50VG9HZXRFeAUMYm9ycm93QW1vdW50CQCUCgIFCmdldEFtb3VudEEFCmdldEFtb3VudEIBC2NsYWltRmFybWVkAgR0eXBlBHBvb2wDCQAAAgUEdHlwZQUHU0ZfUE9PTAQJYmFsQmVmb3JlCQEOYWNjb3VudEJhbGFuY2UBBQZTV09QSUQDCQAAAgUJYmFsQmVmb3JlBQliYWxCZWZvcmUEA2ludgkA/AcECQEQZ2V0U0ZGYXJtaW5nQWRkcgACBWNsYWltCQDMCAIFBHBvb2wFA25pbAUDbmlsAwkAAAIFA2ludgUDaW52BAhiYWxBZnRlcgkBDmFjY291bnRCYWxhbmNlAQUGU1dPUElECQCUCgIJAGUCBQhiYWxBZnRlcgUJYmFsQmVmb3JlBQZTV09QSUQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4DCQAAAgUEdHlwZQUHV1hfUE9PTAQJYmFsQmVmb3JlCQEOYWNjb3VudEJhbGFuY2UBBQRXWElEAwkAAAIFCWJhbEJlZm9yZQUJYmFsQmVmb3JlBANpbnYJAPwHBAkBEGdldFdYRmFybWluZ0FkZHIBCQEHQWRkcmVzcwEJANkEAQUEcG9vbAIHY2xhaW1XWAkAzAgCBQRwb29sBQNuaWwFA25pbAMJAAACBQNpbnYFA2ludgQIYmFsQWZ0ZXIJAQ5hY2NvdW50QmFsYW5jZQEFBFdYSUQJAJQKAgkAZQIFCGJhbEFmdGVyBQliYWxCZWZvcmUFBFdYSUQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAg9Xcm9uZyBwb29sIHR5cGUBD3JlcGxlbmlzaEJ5VHlwZQoFcFR5cGUEcG9vbAdmZWVUeXBlBHBtdEEDYUlkBHBtdEIDYklkBGJhbEEEYmFsQgRMUElkBA9scEJhbGFuY2VCZWZvcmUJAQ5hY2NvdW50QmFsYW5jZQEJANkEAQUETFBJZAMJAAACBQ9scEJhbGFuY2VCZWZvcmUFD2xwQmFsYW5jZUJlZm9yZQQIcG9vbEFkZHIJARFAZXh0ck5hdGl2ZSgxMDYyKQEFBHBvb2wEDSR0MDE4NDk0MTg5MTADAwkAZgIFBHBtdEEAAAkAZgIFBHBtdEIAAAcEDSR0MDE4NTYwMTg2NzYJARhjYWxjUmVwbGVuaXNoQnlUd29Ub2tlbnMIBQVwVHlwZQUIcG9vbEFkZHIFBHBtdEEFA2FJZAUEcG10QgUDYklkBQRiYWxBBQRiYWxCBAZwbXRJbkEIBQ0kdDAxODU2MDE4Njc2Al8xBAZwbXRJbkIIBQ0kdDAxODU2MDE4Njc2Al8yBAZjaGFuZ2UIBQ0kdDAxODU2MDE4Njc2Al8zBAhjaGFuZ2VJZAgFDSR0MDE4NTYwMTg2NzYCXzQEA2ludgkBGHJlcGxlbmlzaFR3b1Rva2Vuc0J5VHlwZQYFCHBvb2xBZGRyBQVwVHlwZQUGcG10SW5BBQNhSWQFBnBtdEluQgUDYklkAwkAAAIFA2ludgUDaW52CQCUCgIFBmNoYW5nZQUIY2hhbmdlSWQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4DCQBmAgUEcG10QQAACQCUCgIFBHBtdEEFA2FJZAMJAGYCBQRwbXRCAAAJAJQKAgUEcG10QgUDYklkCQACAQIQcG10cyBtdXN0IGJlID4gMAQGY2hhbmdlCAUNJHQwMTg0OTQxODkxMAJfMQQIY2hhbmdlSWQIBQ0kdDAxODQ5NDE4OTEwAl8yBANpbnYDCQBmAgUGY2hhbmdlAAAJARdyZXBsZW5pc2hPbmVUb2tlbkJ5VHlwZQQFCHBvb2xBZGRyBQVwVHlwZQUGY2hhbmdlBQhjaGFuZ2VJZAUDbmlsAwkAAAIFA2ludgUDaW52BA5scEJhbGFuY2VBZnRlcgkBDmFjY291bnRCYWxhbmNlAQkA2QQBBQRMUElkBAt0b3RhbFN0YWtlZAkAZQIFDmxwQmFsYW5jZUFmdGVyBQ9scEJhbGFuY2VCZWZvcmUEDWF4bHlGZWVBbW91bnQJAGsDBQt0b3RhbFN0YWtlZAkBCmdldEF4bHlGZWUCBQRwb29sBQdmZWVUeXBlBQpGRUVfU0NBTEU2BBF1c2VyU2hhcmVGb3JTdGFrZQkAZQIFC3RvdGFsU3Rha2VkBQ1heGx5RmVlQW1vdW50AwkAZwIAAAURdXNlclNoYXJlRm9yU3Rha2UJAAIBAihhbW91bnQgb2Ygc3Rha2VkIHNoYXJldG9rZW5zIG11c3QgYmUgPiAwBAVpbnZMUAkBB3N0YWtlTFAEBQRwb29sBQVwVHlwZQUETFBJZAURdXNlclNoYXJlRm9yU3Rha2UDCQAAAgUFaW52TFAFBWludkxQCQCUCgIFEXVzZXJTaGFyZUZvclN0YWtlBQ1heGx5RmVlQW1vdW50CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuARByZXBsZW5pc2hFbnRyaWVzCARwb29sBHVzZXIMc3Rha2VkQW1vdW50DWF4bHlGZWVBbW91bnQGcG9zTnVtB3NoYXJlSWQEdHlwZQh3aXRoTG9hbgQLdG90YWxBbW91bnQJARFnZXRQb29sVG90YWxTaGFyZQEFBHBvb2wED3RvdGFsQW1vdW50TG9hbgkBGWdldFBvb2xUb3RhbFNoYXJlV2l0aExvYW4BBQRwb29sBA0kdDAxOTc2ODIwMDA2AwUId2l0aExvYW4JAJQKAgkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwkArAICBQRwb29sBRFrUG9vbEludGVyZXN0TG9hbgkAZAIFD3RvdGFsQW1vdW50TG9hbgUMc3Rha2VkQW1vdW50CQCUCgIJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAKwCAgUEcG9vbAUTa1Bvb2xJbnRlcmVzdE5vTG9hbgUPdG90YWxBbW91bnRMb2FuBA9jdXJQb29sSW50ZXJlc3QIBQ0kdDAxOTc2ODIwMDA2Al8xBBN0b3RhbFN0YWtlZFdpdGhMb2FuCAUNJHQwMTk3NjgyMDAwNgJfMgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQRwb29sBQprUG9vbFRvdGFsCQBkAgULdG90YWxBbW91bnQFDHN0YWtlZEFtb3VudAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQRwb29sBQ5rUG9vbFRvdGFsTG9hbgUTdG90YWxTdGFrZWRXaXRoTG9hbgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBHBvb2wCAV8FBHVzZXICAV8JAKQDAQUGcG9zTnVtBQ1rVXNlclBvc2l0aW9uBQxzdGFrZWRBbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfCQCkAwEFBnBvc051bQUVa1VzZXJQb3NpdGlvbkludGVyZXN0BQ9jdXJQb29sSW50ZXJlc3QJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgIJAKwCAgUEdXNlcgIBXwkApAMBBQZwb3NOdW0FEWtVc2VyUG9zaXRpb25Qb29sBQRwb29sCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFBHVzZXIFEGtVc2VyUG9zaXRpb25OdW0FBnBvc051bQkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQhtb25leUJveAUNYXhseUZlZUFtb3VudAkA2QQBBQdzaGFyZUlkBQNuaWwBDmV4Y2hhbmdlS2VlcGVyCgd0b1Rva2VuCXBtdEFtb3VudAhwbXRBc3NldAlhbW91bnRzSW4JYWRkcmVzc2VzD2Fzc2V0c1RvUmVjZWl2ZQtlc3RSZWNlaXZlZBFzbGlwcGFnZVRvbGVyYW5jZQttaW5SZWNlaXZlZAdvcHRpb25zBBJ0b2tlbkJhbGFuY2VCZWZvcmUJAQ5hY2NvdW50QmFsYW5jZQEJAQ5hc3NldElkRnJvbVN0cgEFB3RvVG9rZW4DCQAAAgUSdG9rZW5CYWxhbmNlQmVmb3JlBRJ0b2tlbkJhbGFuY2VCZWZvcmUEA2ludgkA/AcEBQpleENvbnRyYWN0AgRzd2FwCQDMCAIFCWFtb3VudHNJbgkAzAgCBQlhZGRyZXNzZXMJAMwIAgUPYXNzZXRzVG9SZWNlaXZlCQDMCAIFC2VzdFJlY2VpdmVkCQDMCAIFEXNsaXBwYWdlVG9sZXJhbmNlCQDMCAIFC21pblJlY2VpdmVkCQDMCAIFB29wdGlvbnMFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUIcG10QXNzZXQFCXBtdEFtb3VudAUDbmlsAwkAAAIFA2ludgUDaW52CQBlAgkBDmFjY291bnRCYWxhbmNlAQkBDmFzc2V0SWRGcm9tU3RyAQUHdG9Ub2tlbgUSdG9rZW5CYWxhbmNlQmVmb3JlCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQ5leGNoYW5nZVB1enpsZQYHdG9Ub2tlbglwbXRBbW91bnQIcG10QXNzZXQJcm91dGVzU3RyDG1pblRvUmVjZWl2ZQdvcHRpb25zBBJ0b2tlbkJhbGFuY2VCZWZvcmUJAQ5hY2NvdW50QmFsYW5jZQEJAQ5hc3NldElkRnJvbVN0cgEFB3RvVG9rZW4DCQAAAgUSdG9rZW5CYWxhbmNlQmVmb3JlBRJ0b2tlbkJhbGFuY2VCZWZvcmUEA2ludgkA/AcEBQpleENvbnRyYWN0AgpwdXp6bGVTd2FwCQDMCAIFCXJvdXRlc1N0cgkAzAgCBQxtaW5Ub1JlY2VpdmUJAMwIAgUHb3B0aW9ucwUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQhwbXRBc3NldAUJcG10QW1vdW50BQNuaWwDCQAAAgUDaW52BQNpbnYJAGUCCQEOYWNjb3VudEJhbGFuY2UBCQEOYXNzZXRJZEZyb21TdHIBBQd0b1Rva2VuBRJ0b2tlbkJhbGFuY2VCZWZvcmUJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BDmV4Y2hhbmdlU3dvcEZpCgd0b1Rva2VuCXBtdEFtb3VudAhwbXRBc3NldApleGNoYW5nZXJzDmV4Y2hhbmdlcnNUeXBlBWFyZ3MxBWFyZ3MyEXJvdXRpbmdBc3NldHNLZXlzEm1pbkFtb3VudFRvUmVjZWl2ZQdvcHRpb25zBBJ0b2tlbkJhbGFuY2VCZWZvcmUJAQ5hY2NvdW50QmFsYW5jZQEJAQ5hc3NldElkRnJvbVN0cgEFB3RvVG9rZW4DCQAAAgUSdG9rZW5CYWxhbmNlQmVmb3JlBRJ0b2tlbkJhbGFuY2VCZWZvcmUEA2ludgkA/AcEBQpleENvbnRyYWN0Agpzd29wZmlTd2FwCQDMCAIFCmV4Y2hhbmdlcnMJAMwIAgUOZXhjaGFuZ2Vyc1R5cGUJAMwIAgUFYXJnczEJAMwIAgUFYXJnczIJAMwIAgURcm91dGluZ0Fzc2V0c0tleXMJAMwIAgUSbWluQW1vdW50VG9SZWNlaXZlCQDMCAIFB29wdGlvbnMFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUIcG10QXNzZXQFCXBtdEFtb3VudAUDbmlsAwkAAAIFA2ludgUDaW52CQBlAgkBDmFjY291bnRCYWxhbmNlAQkBDmFzc2V0SWRGcm9tU3RyAQUHdG9Ub2tlbgUSdG9rZW5CYWxhbmNlQmVmb3JlCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQpjYXBpdGFsaXplBARwb29sBXBUeXBlB3Rva2VuSWQLdG9rZW5BbW91bnQECHBvb2xBZGRyCQEHQWRkcmVzcwEJANkEAQUEcG9vbAQNJHQwMjIzNTcyMjQyMwkBC2dldFBvb2xEYXRhAgUIcG9vbEFkZHIFBXBUeXBlBANBSWQIBQ0kdDAyMjM1NzIyNDIzAl8xBANCSWQIBQ0kdDAyMjM1NzIyNDIzAl8yBARiYWxBCAUNJHQwMjIzNTcyMjQyMwJfMwQEYmFsQggFDSR0MDIyMzU3MjI0MjMCXzQEB3NoYXJlSWQIBQ0kdDAyMjM1NzIyNDIzAl81AwMJAQIhPQIFB3Rva2VuSWQFA0FJZAkBAiE9AgUHdG9rZW5JZAUDQklkBwkAAgECC1dyb25nIGFzc2V0BA0kdDAyMjUwODIyNTg4AwkAAAIFB3Rva2VuSWQFA0FJZAkAlAoCBQt0b2tlbkFtb3VudAAACQCUCgIAAAULdG9rZW5BbW91bnQEBHBtdEEIBQ0kdDAyMjUwODIyNTg4Al8xBARwbXRCCAUNJHQwMjI1MDgyMjU4OAJfMgQNJHQwMjI1OTEyMjY5NQkBD3JlcGxlbmlzaEJ5VHlwZQoFBXBUeXBlBQRwb29sBQZOT19GRUUFBHBtdEEFA0FJZAUEcG10QgUDQklkBQRiYWxBBQRiYWxCBQdzaGFyZUlkBAxzdGFrZWRBbW91bnQIBQ0kdDAyMjU5MTIyNjk1Al8xBAJuZggFDSR0MDIyNTkxMjI2OTUCXzIEE2N1clBvb2xJbnRlcmVzdExvYW4JAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkArAICBQRwb29sBRFrUG9vbEludGVyZXN0TG9hbgAABBVjdXJQb29sSW50ZXJlc3ROb0xvYW4JAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkArAICBQRwb29sBRNrUG9vbEludGVyZXN0Tm9Mb2FuAAAEEHRvdGFsU2hhcmVBbW91bnQJARFnZXRQb29sVG90YWxTaGFyZQEFBHBvb2wEGHRvdGFsU2hhcmVBbW91bnRXaXRoTG9hbgkBGWdldFBvb2xUb3RhbFNoYXJlV2l0aExvYW4BBQRwb29sBAtsb2FuUGVyY2VudAkAawMFGHRvdGFsU2hhcmVBbW91bnRXaXRoTG9hbgUGU0NBTEU4BRB0b3RhbFNoYXJlQW1vdW50BApzdGFrZWRMb2FuCQBrAwUMc3Rha2VkQW1vdW50BQtsb2FuUGVyY2VudAUGU0NBTEU4BAxzdGFrZWROb0xvYW4JAGUCBQxzdGFrZWRBbW91bnQFCnN0YWtlZExvYW4ED25ld0ludGVyZXN0TG9hbgMJAGYCBRh0b3RhbFNoYXJlQW1vdW50V2l0aExvYW4AAAkAZAIFE2N1clBvb2xJbnRlcmVzdExvYW4JAGsDBQpzdGFrZWRMb2FuBQdTQ0FMRTEwBRh0b3RhbFNoYXJlQW1vdW50V2l0aExvYW4AAAQRbmV3SW50ZXJlc3ROb0xvYW4DCQBmAgkAZQIFEHRvdGFsU2hhcmVBbW91bnQFGHRvdGFsU2hhcmVBbW91bnRXaXRoTG9hbgAACQBkAgUVY3VyUG9vbEludGVyZXN0Tm9Mb2FuCQBrAwUMc3Rha2VkTm9Mb2FuBQdTQ0FMRTEwCQBlAgUQdG90YWxTaGFyZUFtb3VudAUYdG90YWxTaGFyZUFtb3VudFdpdGhMb2FuAAAEC2F4bHlGZWVMb2FuCQBrAwUKc3Rha2VkTG9hbgkBCmdldEF4bHlGZWUCBQRwb29sBQxDQVBfRkVFX0xPQU4FCkZFRV9TQ0FMRTYEDWF4bHlGZWVOb0xvYW4JAGsDBQxzdGFrZWROb0xvYW4JAQpnZXRBeGx5RmVlAgUEcG9vbAUPQ0FQX0ZFRV9OT19MT0FOBQpGRUVfU0NBTEU2BAdheGx5RmVlCQEJdW5zdGFrZUxQBAUEcG9vbAUFcFR5cGUFB3NoYXJlSWQJAGQCBQtheGx5RmVlTG9hbgUNYXhseUZlZU5vTG9hbgMJAAACBQdheGx5RmVlBQdheGx5RmVlCQDOCAIJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUEcG9vbAURa1Bvb2xJbnRlcmVzdExvYW4FD25ld0ludGVyZXN0TG9hbgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQRwb29sBRNrUG9vbEludGVyZXN0Tm9Mb2FuBRFuZXdJbnRlcmVzdE5vTG9hbgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQRwb29sBQprUG9vbFRvdGFsCQBlAgkAZAIFEHRvdGFsU2hhcmVBbW91bnQFDHN0YWtlZEFtb3VudAUHYXhseUZlZQkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQRwb29sBQ5rUG9vbFRvdGFsTG9hbgkAZQIJAGQCBRh0b3RhbFNoYXJlQW1vdW50V2l0aExvYW4FCnN0YWtlZExvYW4FC2F4bHlGZWVMb2FuCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFCG1vbmV5Qm94CQBkAgULYXhseUZlZUxvYW4FDWF4bHlGZWVOb0xvYW4JANkEAQUHc2hhcmVJZAUDbmlsCQEOZ2V0Q3Vyc0VudHJpZXMDBQNBSWQFA0JJZAUHc2hhcmVJZAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgESd2l0aGRyYXdBbW91bnRDYWxjBARwb29sD3VzZXJDYW5XaXRoZHJhdwRkZWJ0C2JvcnJvd0Fzc2V0BAhwb29sQWRkcgkBB0FkZHJlc3MBCQDZBAEFBHBvb2wEBXBUeXBlCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwkArAICBQVrUG9vbAUEcG9vbAIMVW5rbm93biBwb29sBA0kdDAyNDQ2MzI0NTM5CQELZ2V0UG9vbERhdGECBQhwb29sQWRkcgUFcFR5cGUECGFzc2V0SWRBCAUNJHQwMjQ0NjMyNDUzOQJfMQQIYXNzZXRJZEIIBQ0kdDAyNDQ2MzI0NTM5Al8yBARiYWxBCAUNJHQwMjQ0NjMyNDUzOQJfMwQEYmFsQggFDSR0MDI0NDYzMjQ1MzkCXzQEB3NoYXJlSWQIBQ0kdDAyNDQ2MzI0NTM5Al81BAtjQmFsQUJlZm9yZQkBDmFjY291bnRCYWxhbmNlAQkBDmFzc2V0SWRGcm9tU3RyAQUIYXNzZXRJZEEDCQAAAgULY0JhbEFCZWZvcmUFC2NCYWxBQmVmb3JlBAtjQmFsQkJlZm9yZQkBDmFjY291bnRCYWxhbmNlAQkBDmFzc2V0SWRGcm9tU3RyAQUIYXNzZXRJZEIDCQAAAgULY0JhbEJCZWZvcmUFC2NCYWxCQmVmb3JlBANpbnYDCQAAAgUFcFR5cGUFB1NGX1BPT0wJAPwHBAUIcG9vbEFkZHICDGNhbGxGdW5jdGlvbgkAzAgCAgh3aXRoZHJhdwkAzAgCCQDMCAIJAKQDAQUPdXNlckNhbldpdGhkcmF3BQNuaWwFA25pbAUDbmlsBANpbnYJAQl1bnN0YWtlTFAEBQRwb29sBQVwVHlwZQUHc2hhcmVJZAUPdXNlckNhbldpdGhkcmF3AwkAAAIFA2ludgUDaW52CQD8BwQFCHBvb2xBZGRyAgNnZXQFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkBDmFzc2V0SWRGcm9tU3RyAQUHc2hhcmVJZAUPdXNlckNhbldpdGhkcmF3BQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4DCQAAAgUDaW52BQNpbnYECmNCYWxBQWZ0ZXIJAQ5hY2NvdW50QmFsYW5jZQEJAQ5hc3NldElkRnJvbVN0cgEFCGFzc2V0SWRBBApjQmFsQkFmdGVyCQEOYWNjb3VudEJhbGFuY2UBCQEOYXNzZXRJZEZyb21TdHIBBQhhc3NldElkQgQNJHQwMjUxMDIyNTE5MQkAlAoCCQBlAgUKY0JhbEFBZnRlcgULY0JhbEFCZWZvcmUJAGUCBQpjQmFsQkFmdGVyBQtjQmFsQkJlZm9yZQQNdG9rZW5zQW1vdW50QQgFDSR0MDI1MTAyMjUxOTECXzEEDXRva2Vuc0Ftb3VudEIIBQ0kdDAyNTEwMjI1MTkxAl8yBA0kdDAyNTE5NDI1ODkwAwkAZgIFBGRlYnQAAAQNYW1vdW50VG9HZXRFeAMDCQAAAgULYm9ycm93QXNzZXQFCGFzc2V0SWRBCQBmAgUEZGVidAUNdG9rZW5zQW1vdW50QQcJAGUCBQRkZWJ0BQ10b2tlbnNBbW91bnRBAwMJAAACBQtib3Jyb3dBc3NldAUIYXNzZXRJZEIJAGYCBQRkZWJ0BQ10b2tlbnNBbW91bnRCBwkAZQIFBGRlYnQFDXRva2Vuc0Ftb3VudEIAAAQFZXhJbnYDCQBmAgUNYW1vdW50VG9HZXRFeAAACQEQZXhjaGFuZ2VEaXJlY3RseQgFBXBUeXBlBQRwb29sBQhhc3NldElkQQUIYXNzZXRJZEIFBGJhbEEFBGJhbEIFDWFtb3VudFRvR2V0RXgFC2JvcnJvd0Fzc2V0AAADCQAAAgUFZXhJbnYFBWV4SW52BA9jQmFsQUFmdGVyUmVwYXkJAQ5hY2NvdW50QmFsYW5jZQEJAQ5hc3NldElkRnJvbVN0cgEFCGFzc2V0SWRBBA9jQmFsQkFmdGVyUmVwYXkJAQ5hY2NvdW50QmFsYW5jZQEJAQ5hc3NldElkRnJvbVN0cgEFCGFzc2V0SWRCCQCUCgIJAGUCBQ9jQmFsQUFmdGVyUmVwYXkFC2NCYWxBQmVmb3JlCQBlAgUPY0JhbEJBZnRlclJlcGF5BQtjQmFsQkJlZm9yZQkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAlAoCBQ10b2tlbnNBbW91bnRBBQ10b2tlbnNBbW91bnRCBA10b1VzZXJBbW91bnRBCAUNJHQwMjUxOTQyNTg5MAJfMQQNdG9Vc2VyQW1vdW50QggFDSR0MDI1MTk0MjU4OTACXzIJAJkKBwUNdG9Vc2VyQW1vdW50QQUIYXNzZXRJZEEFDXRvVXNlckFtb3VudEIFCGFzc2V0SWRCBQpjQmFsQUFmdGVyBQpjQmFsQkFmdGVyBQdzaGFyZUlkCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuARh1c2VyQ2FuV2l0aGRyYXdTaGFyZUNhbGMEBHVzZXIEcG9vbAVwb3NJZAhib3Jyb3dlZAQHcEFtb3VudAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFBHRoaXMJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfBQVwb3NJZAUNa1VzZXJQb3NpdGlvbgIQVW5rbm93biBwb3NpdGlvbgQMdXNlckludGVyZXN0CQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUEcG9vbAIBXwUEdXNlcgIBXwUFcG9zSWQFFWtVc2VyUG9zaXRpb25JbnRlcmVzdAQMcG9vbEludGVyZXN0AwUIYm9ycm93ZWQJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAKwCAgUEcG9vbAURa1Bvb2xJbnRlcmVzdExvYW4JARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAKwCAgUEcG9vbAUTa1Bvb2xJbnRlcmVzdE5vTG9hbgkAZAIFB3BBbW91bnQJAGsDBQdwQW1vdW50CQBlAgUMcG9vbEludGVyZXN0BQx1c2VySW50ZXJlc3QFB1NDQUxFMTABDndpdGhkcmF3VG9Vc2VyBAR1c2VyBHBvb2wFcG9zSWQIc3RvcExvc3MEB3BBbW91bnQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQR0aGlzCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUEcG9vbAIBXwUEdXNlcgIBXwUFcG9zSWQFDWtVc2VyUG9zaXRpb24CEFVua25vd24gcG9zaXRpb24EDHVzZXJJbnRlcmVzdAkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBHBvb2wCAV8FBHVzZXICAV8FBXBvc0lkBRVrVXNlclBvc2l0aW9uSW50ZXJlc3QEDGJvcnJvd0Ftb3VudAkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUEcG9vbAIBXwUEdXNlcgIBXwUFcG9zSWQFEWtVc2VyQm9ycm93QW1vdW50AAAED3VzZXJDYW5XaXRoZHJhdwkBGHVzZXJDYW5XaXRoZHJhd1NoYXJlQ2FsYwQFBHVzZXIFBHBvb2wFBXBvc0lkCQBmAgUMYm9ycm93QW1vdW50AAAEDnBvb2xUb3RhbFNoYXJlCQERZ2V0UG9vbFRvdGFsU2hhcmUBBQRwb29sBAh1c2VyQWRkcgkBB0FkZHJlc3MBCQDZBAEFBHVzZXIEC2JvcnJvd0Fzc2V0CQELdmFsdWVPckVsc2UCCQCdCAIFBHRoaXMJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfBQVwb3NJZAUSa1VzZXJCb3Jyb3dBc3NldElkAgAEBGRlYnQDCQBmAgUMYm9ycm93QW1vdW50AAAKAAFACQD8BwQJAQ5nZXRMZW5kU3J2QWRkcgACDGdldEFzc2V0RGVidAkAzAgCBwkAzAgCCQCsAgIJAKwCAgUEdXNlcgIBXwUFcG9zSWQJAMwIAgULYm9ycm93QXNzZXQFA25pbAUDbmlsAwkAAQIFAUACA0ludAUBQAkAAgEJAKwCAgkAAwEFAUACGCBjb3VsZG4ndCBiZSBjYXN0IHRvIEludAAABA0kdDAyNzM4OTI3NTQyCQESd2l0aGRyYXdBbW91bnRDYWxjBAUEcG9vbAUPdXNlckNhbldpdGhkcmF3BQRkZWJ0BQtib3Jyb3dBc3NldAMJAAACBQ0kdDAyNzM4OTI3NTQyBQ0kdDAyNzM4OTI3NTQyBAdzaGFyZUlkCAUNJHQwMjczODkyNzU0MgJfNwQKY0JhbEJBZnRlcggFDSR0MDI3Mzg5Mjc1NDICXzYECmNCYWxBQWZ0ZXIIBQ0kdDAyNzM4OTI3NTQyAl81BAhhc3NldElkQggFDSR0MDI3Mzg5Mjc1NDICXzQEDXRvVXNlckFtb3VudEIIBQ0kdDAyNzM4OTI3NTQyAl8zBAhhc3NldElkQQgFDSR0MDI3Mzg5Mjc1NDICXzIEDXRvVXNlckFtb3VudEEIBQ0kdDAyNzM4OTI3NTQyAl8xBAtjbG9zZURidEludgMJAGYCBQRkZWJ0AAAJAPwHBAkBDmdldExlbmRTcnZBZGRyAAIIcmVwYXlGb3IJAMwIAgkArAICCQCsAgIFBHVzZXICAV8FBXBvc0lkBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJAQ5hc3NldElkRnJvbVN0cgEFC2JvcnJvd0Fzc2V0BQRkZWJ0BQNuaWwAAAMJAAACBQtjbG9zZURidEludgULY2xvc2VEYnRJbnYJAM4IAgkAzAgCCQELRGVsZXRlRW50cnkBCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUEcG9vbAIBXwUEdXNlcgIBXwUFcG9zSWQFDWtVc2VyUG9zaXRpb24JAMwIAgkBC0RlbGV0ZUVudHJ5AQkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBHBvb2wCAV8FBHVzZXICAV8FBXBvc0lkBRVrVXNlclBvc2l0aW9uSW50ZXJlc3QJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUEcG9vbAUKa1Bvb2xUb3RhbAkAZQIFDnBvb2xUb3RhbFNoYXJlBQ91c2VyQ2FuV2l0aGRyYXcJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUIdXNlckFkZHIFDXRvVXNlckFtb3VudEEJAQ5hc3NldElkRnJvbVN0cgEFCGFzc2V0SWRBCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFCHVzZXJBZGRyBQ10b1VzZXJBbW91bnRCCQEOYXNzZXRJZEZyb21TdHIBBQhhc3NldElkQgUDbmlsCQEOZ2V0Q3Vyc0VudHJpZXMDBQhhc3NldElkQQUIYXNzZXRJZEIFB3NoYXJlSWQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BDHBhcnNlUmVxdWVzdAEJcmVxdWVzdElkBAdyZXF1ZXN0CQC1CQIJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzCQCsAgIFCXJlcXVlc3RJZAUKa1JlcXVlc3RJZAkArAICAhNObyByZXF1ZXN0IHdpdGggaWQgBQlyZXF1ZXN0SWQCASwEBHVzZXIJAJEDAgUHcmVxdWVzdAAABARwb29sCQCRAwIFB3JlcXVlc3QAAQQEcG10QQkBDXBhcnNlSW50VmFsdWUBCQCRAwIFB3JlcXVlc3QAAgQDQUlkCQCRAwIFB3JlcXVlc3QAAwQEcG10QgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFB3JlcXVlc3QABAQDQklkCQCRAwIFB3JlcXVlc3QABQQEYmFsQQkBDXBhcnNlSW50VmFsdWUBCQCRAwIFB3JlcXVlc3QABgQEYmFsQgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFB3JlcXVlc3QABwQHc2hhcmVJZAkAkQMCBQdyZXF1ZXN0AAgEB2J3QXNzZXQJAJEDAgUHcmVxdWVzdAAJBAhid0Ftb3VudAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFB3JlcXVlc3QACgkAnQoLBQR1c2VyBQRwb29sBQRwbXRBBQNBSWQFBHBtdEIFA0JJZAUEYmFsQQUEYmFsQgUHc2hhcmVJZAUHYndBc3NldAUIYndBbW91bnQBEGNhbGNCb3Jyb3dBbW91bnQGBHBtdEEEcG10QgNhSWQDYklkCGxldmVyYWdlCGJvcnJvd0lkBAdkUHJpY2VBCAoAAUAJAPwHBAUPcHJpY2VPcmFjbGVBZGRyAglnZXRUV0FQNjAJAMwIAgUDYUlkCQDMCAIHBQNuaWwFA25pbAMJAAECBQFAAgooSW50LCBJbnQpBQFACQACAQkArAICCQADAQUBQAIfIGNvdWxkbid0IGJlIGNhc3QgdG8gKEludCwgSW50KQJfMgQHZFByaWNlQggKAAFACQD8BwQFD3ByaWNlT3JhY2xlQWRkcgIJZ2V0VFdBUDYwCQDMCAIFA2JJZAkAzAgCBwUDbmlsBQNuaWwDCQABAgUBQAIKKEludCwgSW50KQUBQAkAAgEJAKwCAgkAAwEFAUACHyBjb3VsZG4ndCBiZSBjYXN0IHRvIChJbnQsIEludCkCXzIEBmRlY1ByQQkAbAYACgAACQEQZ2V0QXNzZXREZWNpbWFscwEFA2FJZAAAAAAFBERPV04EBmRlY1ByQgkAbAYACgAACQEQZ2V0QXNzZXREZWNpbWFscwEFA2JJZAAAAAAFBERPV04EDHBheWRJbkRvbGxhcgkAZAIJAGsDBQdkUHJpY2VBBQRwbXRBBQZkZWNQckEJAGsDBQdkUHJpY2VCBQRwbXRCBQZkZWNQckIEDSR0MDI5MjI4MjkzMjUDCQAAAgUIYm9ycm93SWQFA2FJZAkAlAoCBQdkUHJpY2VBBQZkZWNQckEJAJQKAgUHZFByaWNlQgUGZGVjUHJCBAtib3Jyb3dQcmljZQgFDSR0MDI5MjI4MjkzMjUCXzEEC2JvcnJvd0RlY1ByCAUNJHQwMjkyMjgyOTMyNQJfMgkAawMJAGsDBQxwYXlkSW5Eb2xsYXIJAGUCBQhsZXZlcmFnZQBkAGQFC2JvcnJvd0RlY1ByBQtib3Jyb3dQcmljZRABaQEXY2FsY1ByaWNlSW1wYWN0RVZBTE9OTFkFBHBvb2wIbGV2ZXJhZ2UIYm9ycm93SWQEcG10QQRwbXRCAwMJAGYCAGQFCGxldmVyYWdlBgkAZgIFCGxldmVyYWdlAKwCCQACAQIfTGV2ZXJhZ2UgY2FuJ3QgYmUgPDEwMCBhbmQgPjMwMAQFcFR5cGUJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzCQCsAgIFBWtQb29sBQRwb29sAhJQb29sIGlzIG5vdCBpbml0ZWQEDSR0MDI5NzQzMjk4MzMJAQtnZXRQb29sRGF0YQIJAQdBZGRyZXNzAQkA2QQBBQRwb29sBQVwVHlwZQQDQUlkCAUNJHQwMjk3NDMyOTgzMwJfMQQDQklkCAUNJHQwMjk3NDMyOTgzMwJfMgQEYmFsQQgFDSR0MDI5NzQzMjk4MzMCXzMEBGJhbEIIBQ0kdDAyOTc0MzI5ODMzAl80BAdzaGFyZUlkCAUNJHQwMjk3NDMyOTgzMwJfNQQMYm9ycm93QW1vdW50AwkAZgIFCGxldmVyYWdlAGQJARBjYWxjQm9ycm93QW1vdW50BgUEcG10QQUEcG10QgUDQUlkBQNCSWQFCGxldmVyYWdlBQhib3Jyb3dJZAAABA0kdDAyOTk2ODMwMDc1AwkAAAIFCGJvcnJvd0lkBQNBSWQJAJQKAgkAZAIFBHBtdEEFDGJvcnJvd0Ftb3VudAUEcG10QgkAlAoCBQRwbXRBCQBkAgUEcG10QgUMYm9ycm93QW1vdW50BAZwYXlJbkEIBQ0kdDAyOTk2ODMwMDc1Al8xBAZwYXlJbkIIBQ0kdDAyOTk2ODMwMDc1Al8yBA0kdDAzMDA3ODMwMTcxCQETY2FsY1JlcGxlbmlzaExQVmlydAgFBXBUeXBlBQRwb29sBQZwYXlJbkEFA0FJZAUGcGF5SW5CBQNCSWQFBGJhbEEFBGJhbEIECGxwQW1vdW50CAUNJHQwMzAwNzgzMDE3MQJfMQQEbG9zcwgFDSR0MDMwMDc4MzAxNzECXzIECWltcGFjdE1vZAMJAGYCAAAFBGxvc3MJAGgCBQRsb3NzAP///////////wEFBGxvc3MJAJQKAgUDbmlsCQDMCAIFCWltcGFjdE1vZAUDbmlsAWkBGmdldFNoYXJlQXNzZXRQcmljZVJFQURPTkxZAQdzaGFyZUlkBAtzaGFyZVByaWNlcwkBDWdldFNoYXJlUHJpY2UBBQdzaGFyZUlkCQCUCgIFA25pbAULc2hhcmVQcmljZXMBaQEiZ2V0VXNlclBvc2l0aW9uU2hhcmVBbW91bnRSRUFET05MWQIEdXNlcgZwb3NOdW0EBHBvb2wJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzCQCsAgIJAKwCAgkArAICBQR1c2VyAgFfBQZwb3NOdW0FEWtVc2VyUG9zaXRpb25Qb29sAhBVbmtub3duIHBvc2l0aW9uBAxib3Jyb3dBbW91bnQJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfBQZwb3NOdW0FEWtVc2VyQm9ycm93QW1vdW50BA91c2VyQ2FuV2l0aGRyYXcJARh1c2VyQ2FuV2l0aGRyYXdTaGFyZUNhbGMEBQR1c2VyBQRwb29sBQZwb3NOdW0JAGYCBQxib3Jyb3dBbW91bnQAAAkAlAoCBQNuaWwFD3VzZXJDYW5XaXRoZHJhdwFpASBnZXRVc2VyUG9zaXRpb25JbkRvbGxhcnNSRUFET05MWQMEdXNlcgVwb29scwZwb3NOdW0KAQd1c2VyUG9zAgFhBHBvb2wEDSR0MDMwOTg0MzEwMTgFAWEECHRvdGFsUG9zCAUNJHQwMzA5ODQzMTAxOAJfMQQHcG9zRGVidAgFDSR0MDMwOTg0MzEwMTgCXzIEBWluZGV4CAUNJHQwMzA5ODQzMTAxOAJfMwQFcFR5cGUJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzCQCsAgIFBWtQb29sBQRwb29sAhJQb29sIGlzIG5vdCBpbml0ZWQEDSR0MDMxMTEwMzEyMDAJAQtnZXRQb29sRGF0YQIJAQdBZGRyZXNzAQkA2QQBBQRwb29sBQVwVHlwZQQDQUlkCAUNJHQwMzExMTAzMTIwMAJfMQQDQklkCAUNJHQwMzExMTAzMTIwMAJfMgQEYmFsQQgFDSR0MDMxMTEwMzEyMDACXzMEBGJhbEIIBQ0kdDAzMTExMDMxMjAwAl80BAdzaGFyZUlkCAUNJHQwMzExMTAzMTIwMAJfNQQMYm9ycm93QW1vdW50CQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfCQCRAwIFBnBvc051bQUFaW5kZXgFEWtVc2VyQm9ycm93QW1vdW50AAAED3VzZXJDYW5XaXRoZHJhdwkBGHVzZXJDYW5XaXRoZHJhd1NoYXJlQ2FsYwQFBHVzZXIFBHBvb2wJAJEDAgUGcG9zTnVtBQVpbmRleAkAZgIFDGJvcnJvd0Ftb3VudAAABAtzaGFyZVByaWNlcwkBDWdldFNoYXJlUHJpY2UBBQdzaGFyZUlkBApkZWNQclNoYXJlCQBsBgAKAAAJARBnZXRBc3NldERlY2ltYWxzAQUHc2hhcmVJZAAAAAAFBERPV04EBnNoYXJlRAkAawMFD3VzZXJDYW5XaXRoZHJhdwULc2hhcmVQcmljZXMFCmRlY1ByU2hhcmUDCQAAAgUMYm9y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BAgJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQFA0FJZAgJAJEDAggFAWkIcGF5bWVudHMAAQZhbW91bnQFA0JJZAMJAAACCQCQAwEIBQFpCHBheW1lbnRzAAEDCQAAAgkBDGFzc2V0SWRUb1N0cgEICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAUDQUlkCQCWCgQICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50BQNBSWQAAAUDQklkAwkAAAIJAQxhc3NldElkVG9TdHIBCAkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQFA0JJZAkAlgoEAAAFA0FJZAgJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQFA0JJZAkAAgECDVdyb25nIHBheW1lbnQJAAIBAhxPbmUgb3IgdHdvIHBheW1lbnRzIGV4cGVjdGVkBARwbXRBCAUNJHQwMzI3MTQzMzM1MQJfMQQJcG10QXNzZXRBCAUNJHQwMzI3MTQzMzM1MQJfMgQEcG10QggFDSR0MDMyNzE0MzMzNTECXzMECXBtdEFzc2V0QggFDSR0MDMyNzE0MzMzNTECXzQECW5ld1Bvc051bQkBGGdldE5ld1VzZXJQb3NpdGlvbk51bWJlcgEJAKUIAQgFAWkGY2FsbGVyAwkAZgIFCGxldmVyYWdlAGQEDGJvcnJvd0Ftb3VudAkBEGNhbGNCb3Jyb3dBbW91bnQGBQRwbXRBBQRwbXRCBQlwbXRBc3NldEEFCXBtdEFzc2V0QgUIbGV2ZXJhZ2UFCGJvcnJvd0lkBAdyZXF1ZXN0CQC5CQIJAMwIAgkApQgBCAUBaQZjYWxsZXIJAMwIAgUEcG9vbAkAzAgCCQCkAwEFBHBtdEEJAMwIAgUJcG10QXNzZXRBCQDMCAIJAKQDAQUEcG10QgkAzAgCBQlwbXRBc3NldEIJAMwIAgkApAMBBQRiYWxBCQDMCAIJAKQDAQUEYmFsQgkAzAgCBQdzaGFyZUlkCQDMCAIFCGJvcnJvd0lkCQDMCAIJAKQDAQUMYm9ycm93QW1vdW50BQNuaWwCASwEDG5ld1JlcXVlc3RJZAoAAUAJAPwHBAUEdGhpcwIQY3JlYXRlTmV3UmVxdWVzdAkAzAgCBQdyZXF1ZXN0BQNuaWwFA25pbAMJAAECBQFAAgNJbnQFAUAJAAIBCQCsAgIJAAMBBQFAAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQDCQAAAgUMbmV3UmVxdWVzdElkBQxuZXdSZXF1ZXN0SWQEBGFyZ3MJAMwIAgkArAICCQCsAgIJAKUIAQgFAWkGY2FsbGVyAgFfCQCkAwEFCW5ld1Bvc051bQkAzAgCBQdzaGFyZUlkCQDMCAIFCGJvcnJvd0lkCQDMCAIFDGJvcnJvd0Ftb3VudAkAzAgCCQClCAEFBHRoaXMJAMwIAgIRcmVwbGVuaXNoRnJvbUxhbmQJAMwIAgkApAMBCQETdmFsdWVPckVycm9yTWVzc2FnZQIFDG5ld1JlcXVlc3RJZAIYQ2FuJ3QgY3JlYXRlIG5ldyByZXF1ZXN0BQNuaWwEA2ludgkA/QcECQEOZ2V0TGVuZFNydkFkZHIAAg1mbGFzaFBvc2l0aW9uBQRhcmdzBQNuaWwDCQAAAgUDaW52BQNpbnYFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgQNJHQwMzQyNzkzNDM5MQkBD3JlcGxlbmlzaEJ5VHlwZQoFBXBUeXBlBQRwb29sBQtOT19MT0FOX0ZFRQUEcG10QQUDQUlkBQRwbXRCBQNCSWQFBGJhbEEFBGJhbEIFB3NoYXJlSWQECnVzZXJTdGFrZWQIBQ0kdDAzNDI3OTM0MzkxAl8xBAdheGx5RmVlCAUNJHQwMzQyNzkzNDM5MQJfMgkAzggCCQEQcmVwbGVuaXNoRW50cmllcwgFBHBvb2wJAKUIAQgFAWkGY2FsbGVyBQp1c2VyU3Rha2VkBQdheGx5RmVlBQluZXdQb3NOdW0FB3NoYXJlSWQFBXBUeXBlBwkBDmdldEN1cnNFbnRyaWVzAwUDQUlkBQNCSWQFB3NoYXJlSWQBaQEId2l0aGRyYXcCBHBvb2wFcG9zSWQJAQ53aXRoZHJhd1RvVXNlcgQJAKUIAQgFAWkGY2FsbGVyBQRwb29sCQCkAwEFBXBvc0lkBwFpARRjcmVhdGVVcGRhdGVTdG9wTG9zcwQFcG9zSWQGcG9vbElkB2Fzc2V0SWQFcHJpY2UEEHRva2VuT3JhY2xlUHJpY2UICgABQAkA/AcEBQ9wcmljZU9yYWNsZUFkZHICCWdldFRXQVA2MAkAzAgCBQdhc3NldElkCQDMCAIHBQNuaWwFA25pbAMJAAECBQFAAgooSW50LCBJbnQpBQFACQACAQkArAICCQADAQUBQAIfIGNvdWxkbid0IGJlIGNhc3QgdG8gKEludCwgSW50KQJfMQMJAQEhAQkBCWlzRGVmaW5lZAEJAJoIAgUEdGhpcwkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBnBvb2xJZAIBXwkApQgBCAUBaQZjYWxsZXICAV8JAKQDAQUFcG9zSWQFDWtVc2VyUG9zaXRpb24JAAIBAhpUaGVyZSBhcmUgbm8gdXNlciBwb3NpdGlvbgMJAGcCAAAFBXByaWNlCQACAQIcUHJpY2UgbXVzdCBiZSBncmVhdGVyIHRoYW4gMAMJAGYCBQVwcmljZQUQdG9rZW5PcmFjbGVQcmljZQkAAgECK1ByaWNlIG11c3QgYmUgbGVzcyB0aGFuIGN1cnJlbnQgdG9rZW4gcHJpY2UJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkApQgBCAUBaQZjYWxsZXICAV8JAKQDAQUFcG9zSWQCAV8FBnBvb2xJZAIBXwUHYXNzZXRJZAUNa1VzZXJTdG9wTG9zcwUFcHJpY2UFA25pbAFpAQ5kZWxldGVTdG9wTG9zcwMFcG9zSWQGcG9vbElkB2Fzc2V0SWQDCQEBIQEJAQlpc0RlZmluZWQBCQCaCAIFBHRoaXMJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkApQgBCAUBaQZjYWxsZXICAV8JAKQDAQUFcG9zSWQCAV8FBnBvb2xJZAIBXwUHYXNzZXRJZAUNa1VzZXJTdG9wTG9zcwkAAgECCE5vIGVudHJ5CQDMCAIJAQtEZWxldGVFbnRyeQEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkApQgBCAUBaQZjYWxsZXICAV8JAKQDAQUFcG9zSWQCAV8FBnBvb2xJZAIBXwUHYXNzZXRJZAUNa1VzZXJTdG9wTG9zcwUDbmlsAWkBEGNyZWF0ZU5ld1JlcXVlc3QBBnBhcmFtcwkBC3ZhbHVlT3JFbHNlAgkBCmlzU2VsZkNhbGwBBQFpBAxuZXdSZXF1ZXN0SWQJAGQCCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMFDGtSZXF1ZXN0SXRlcgAAAAEJAJQKAgkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIJAKQDAQUMbmV3UmVxdWVzdElkBQprUmVxdWVzdElkBQZwYXJhbXMJAMwIAgkBDEludGVnZXJFbnRyeQIFDGtSZXF1ZXN0SXRlcgUMbmV3UmVxdWVzdElkBQNuaWwFDG5ld1JlcXVlc3RJZAFpARFyZXBsZW5pc2hGcm9tTGFuZAEJcmVxdWVzdElkCQELdmFsdWVPckVsc2UCCQEKaXNMYW5kQ2FsbAEFAWkEDSR0MDM2MTQ0MzYyNDgJAQxwYXJzZVJlcXVlc3QBBQlyZXF1ZXN0SWQEBHVzZXIIBQ0kdDAzNjE0NDM2MjQ4Al8xBARwb29sCAUNJHQwMzYxNDQzNjI0OAJfMgQEcG10QQgFDSR0MDM2MTQ0MzYyNDgCXzMEA0FJZAgFDSR0MDM2MTQ0MzYyNDgCXzQEBHBtdEIIBQ0kdDAzNjE0NDM2MjQ4Al81BANCSWQIBQ0kdDAzNjE0NDM2MjQ4Al82BARiYWxBCAUNJHQwMzYxNDQzNjI0OAJfNwQEYmFsQggFDSR0MDM2MTQ0MzYyNDgCXzgEB3NoYXJlSWQIBQ0kdDAzNjE0NDM2MjQ4Al85BAdid0Fzc2V0CAUNJHQwMzYxNDQzNjI0OANfMTAECGJ3QW1vdW50CAUNJHQwMzYxNDQzNjI0OANfMTEDCQECIT0CCQCQAwEIBQFpCHBheW1lbnRzAAEJAAIBAhJXcm9uZyBwYXltZW50IHNpemUDAwkBAiE9AgkBDGFzc2V0SWRUb1N0cgEICQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAUHYndBc3NldAYJAQIhPQIICQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50BQhid0Ftb3VudAkAAgECDVdyb25nIHBheW1lbnQEDSR0MDM2NDM4MzY1NjIDCQAAAgUDQUlkBQdid0Fzc2V0CQCUCgIJAGQCBQRwbXRBCAkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAUEcG10QgkAlAoCBQRwbXRBCQBkAgUEcG10QggJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQEB3BtdEFsbEEIBQ0kdDAzNjQzODM2NTYyAl8xBAdwbXRBbGxCCAUNJHQwMzY0MzgzNjU2MgJfMgQFcFR5cGUJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzCQCsAgIFBWtQb29sBQRwb29sAgxVbmtub3duIHBvb2wEDSR0MDM2NjQ0MzY3NTMJAQ9yZXBsZW5pc2hCeVR5cGUKBQVwVHlwZQUEcG9vbAUITE9BTl9GRUUFBHBtdEEFA0FJZAUEcG10QgUDQklkBQRiYWxBBQRiYWxCBQdzaGFyZUlkBAp1c2VyU3Rha2VkCAUNJHQwMzY2NDQzNjc1MwJfMQQHYXhseUZlZQgFDSR0MDM2NjQ0MzY3NTMCXzIEBnBvc051bQkBGGdldE5ld1VzZXJQb3NpdGlvbk51bWJlcgEFBHVzZXIEDWJvcnJvd0VudHJpZXMJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfCQCkAwEFBnBvc051bQURa1VzZXJCb3Jyb3dBbW91bnQFCGJ3QW1vdW50CQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfCQCkAwEFBnBvc051bQUSa1VzZXJCb3Jyb3dBc3NldElkBQdid0Fzc2V0BQNuaWwEB2VudHJpZXMJARByZXBsZW5pc2hFbnRyaWVzCAUEcG9vbAUEdXNlcgUKdXNlclN0YWtlZAUHYXhseUZlZQUGcG9zTnVtBQdzaGFyZUlkBQVwVHlwZQYJAJQKAgkAzQgCCQDOCAIJAM4IAgUHZW50cmllcwkBDmdldEN1cnNFbnRyaWVzAwUDQUlkBQNCSWQFB3NoYXJlSWQFDWJvcnJvd0VudHJpZXMJAQtEZWxldGVFbnRyeQEJAKwCAgUJcmVxdWVzdElkBQprUmVxdWVzdElkBQp1c2VyU3Rha2VkAWkBCWxpcXVpZGF0ZQMEdXNlcgVwb3NJZA9saXF1aWRhdGVBbW91bnQJAQt2YWx1ZU9yRWxzZQIJAQppc0xhbmRDYWxsAQUBaQQEcG9vbAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMJAKwCAgkArAICCQCsAgIFBHVzZXICAV8FBXBvc0lkBRFrVXNlclBvc2l0aW9uUG9vbAILbm8gcG9zaXRpb24EBXBUeXBlCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwkArAICBQVrUG9vbAUEcG9vbAISUG9vbCBpcyBub3QgaW5pdGVkBA0kdDAzNzUzMjM3NjIyCQELZ2V0UG9vbERhdGECCQEHQWRkcmVzcwEJANkEAQUEcG9vbAUFcFR5cGUEA0FJZAgFDSR0MDM3NTMyMzc2MjICXzEEA0JJZAgFDSR0MDM3NTMyMzc2MjICXzIEBGJhbEEIBQ0kdDAzNzUzMjM3NjIyAl8zBARiYWxCCAUNJHQwMzc1MzIzNzYyMgJfNAQHc2hhcmVJZAgFDSR0MDM3NTMyMzc2MjICXzUEBmFtb3VudAkBCXVuc3Rha2VMUAQFBHBvb2wFBXBUeXBlBQdzaGFyZUlkBQ9saXF1aWRhdGVBbW91bnQEDGJvcnJvd0Ftb3VudAkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBHBvb2wCAV8FBHVzZXICAV8FBXBvc0lkBRFrVXNlckJvcnJvd0Ftb3VudAQLYm9ycm93QXNzZXQJARFAZXh0ck5hdGl2ZSgxMDUzKQIFBHRoaXMJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfBQVwb3NJZAUSa1VzZXJCb3Jyb3dBc3NldElkBA91c2VyQ2FuV2l0aGRyYXcJARh1c2VyQ2FuV2l0aGRyYXdTaGFyZUNhbGMEBQR1c2VyBQRwb29sBQVwb3NJZAkAZgIFDGJvcnJvd0Ftb3VudAAAAwkAAAIFDGJvcnJvd0Ftb3VudAAACQACAQIrWW91IGNhbid0IGxpcXVpZGF0ZSBwb3NpdGlvbiB3aXRob3V0IGJvcnJvdwkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBHBvb2wCAV8FBHVzZXICAV8FBXBvc0lkBRVrVXNlclBvc2l0aW9uSW50ZXJlc3QJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAKwCAgUEcG9vbAURa1Bvb2xJbnRlcmVzdExvYW4JAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUEcG9vbAUOa1Bvb2xUb3RhbExvYW4JAGUCCQEZZ2V0UG9vbFRvdGFsU2hhcmVXaXRoTG9hbgEFBHBvb2wFD2xpcXVpZGF0ZUFtb3VudAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQRwb29sBQprUG9vbFRvdGFsCQBlAgkBEWdldFBvb2xUb3RhbFNoYXJlAQUEcG9vbAUPbGlxdWlkYXRlQW1vdW50CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUEcG9vbAIBXwUEdXNlcgIBXwUFcG9zSWQFDWtVc2VyUG9zaXRpb24JAGUCBQ91c2VyQ2FuV2l0aGRyYXcFD2xpcXVpZGF0ZUFtb3VudAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDCAUBaQZjYWxsZXIFBmFtb3VudAkA2QQBBQdzaGFyZUlkBQNuaWwBaQEIc3RvcExvc3MEBHVzZXIFcG9zSWQEcG9vbAdhc3NldElkCQELdmFsdWVPckVsc2UCCQELaXNBZG1pbkNhbGwBBQFpBBB0b2tlbk9yYWNsZVByaWNlCAoAAUAJAPwHBAUPcHJpY2VPcmFjbGVBZGRyAglnZXRUV0FQNjAJAMwIAgUHYXNzZXRJZAkAzAgCBwUDbmlsBQNuaWwDCQABAgUBQAIKKEludCwgSW50KQUBQAkAAgEJAKwCAgkAAwEFAUACHyBjb3VsZG4ndCBiZSBjYXN0IHRvIChJbnQsIEludCkCXzEDCQEBIQEJAQlpc0RlZmluZWQBCQCaCAIFBHRoaXMJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUEdXNlcgIBXwkApAMBBQVwb3NJZAIBXwUEcG9vbAIBXwUHYXNzZXRJZAUNa1VzZXJTdG9wTG9zcwkAAgECCE5vIGVudHJ5CQDNCAIJAQ53aXRoZHJhd1RvVXNlcgQJAKUIAQgFAWkGY2FsbGVyBQRwb29sCQCkAwEFBXBvc0lkBgkBC0RlbGV0ZUVudHJ5AQkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQR1c2VyAgFfCQCkAwEFBXBvc0lkAgFfBQRwb29sAgFfBQdhc3NldElkBQ1rVXNlclN0b3BMb3NzAWkBEmNhcGl0YWxpemVFeEtlZXBlcgwEcG9vbAR0eXBlCXRva2VuVG9JZBBhbW91bnRUb0V4Y2hhbmdlBWNsYWltCWFtb3VudHNJbglhZGRyZXNzZXMPYXNzZXRzVG9SZWNlaXZlC2VzdFJlY2VpdmVkEXNsaXBwYWdlVG9sZXJhbmNlC21pblJlY2VpdmVkB29wdGlvbnMJAQt2YWx1ZU9yRWxzZQIJAQtpc0FkbWluQ2FsbAEFAWkEDSR0MDM5NDA3Mzk2MDEDBQVjbGFpbQkBC2NsYWltRmFybWVkAgUEdHlwZQUEcG9vbAQMY2xhaW1lZEFzc2V0AwkAAAIFBHR5cGUFB1NGX1BPT0wFBlNXT1BJRAUEV1hJRAkAlAoCBRBhbW91bnRUb0V4Y2hhbmdlBQxjbGFpbWVkQXNzZXQEDWNsYWltZWRBbW91bnQIBQ0kdDAzOTQwNzM5NjAxAl8xBAxjbGFpbWVkQXNzZXQIBQ0kdDAzOTQwNzM5NjAxAl8yBA9leGNoYW5nZWRBbW91bnQJAQ5leGNoYW5nZUtlZXBlcgoFCXRva2VuVG9JZAUQYW1vdW50VG9FeGNoYW5nZQUMY2xhaW1lZEFzc2V0BQlhbW91bnRzSW4FCWFkZHJlc3NlcwUPYXNzZXRzVG9SZWNlaXZlBQtlc3RSZWNlaXZlZAURc2xpcHBhZ2VUb2xlcmFuY2UFC21pblJlY2VpdmVkBQdvcHRpb25zBAZjaGFuZ2UJAGUCBQ1jbGFpbWVkQW1vdW50BRBhbW91bnRUb0V4Y2hhbmdlBAtjaGFuZ2VFbnRyeQMJAGYCBQZjaGFuZ2UAAAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQRwb29sBQ5rUG9vbENhcENoYW5nZQkAZAIFBmNoYW5nZQkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQCsAgIFBHBvb2wFDmtQb29sQ2FwQ2hhbmdlAAAFA25pbAUDbmlsCQDOCAIJAQpjYXBpdGFsaXplBAUEcG9vbAUEdHlwZQUJdG9rZW5Ub0lkBQ9leGNoYW5nZWRBbW91bnQFC2NoYW5nZUVudHJ5AWkBEmNhcGl0YWxpemVFeFB1enpsZQgEcG9vbAR0eXBlCXRva2VuVG9JZBBhbW91bnRUb0V4Y2hhbmdlBWNsYWltCXJvdXRlc1N0cgxtaW5Ub1JlY2VpdmUHb3B0aW9ucwkBC3ZhbHVlT3JFbHNlAgkBC2lzQWRtaW5DYWxsAQUBaQQNJHQwNDAyODY0MDQ4MAMFBWNsYWltCQELY2xhaW1GYXJtZWQCBQR0eXBlBQRwb29sBAxjbGFpbWVkQXNzZXQDCQAAAgUEdHlwZQUHU0ZfUE9PTAUGU1dPUElEBQRXWElECQCUCgIFEGFtb3VudFRvRXhjaGFuZ2UFDGNsYWltZWRBc3NldAQNY2xhaW1lZEFtb3VudAgFDSR0MDQwMjg2NDA0ODACXzEEDGNsYWltZWRBc3NldAgFDSR0MDQwMjg2NDA0ODACXzIED2V4Y2hhbmdlZEFtb3VudAkBDmV4Y2hhbmdlUHV6emxlBgUJdG9rZW5Ub0lkBRBhbW91bnRUb0V4Y2hhbmdlBQxjbGFpbWVkQXNzZXQFCXJvdXRlc1N0cgUMbWluVG9SZWNlaXZlBQdvcHRpb25zBAZjaGFuZ2UJAGUCBQ1jbGFpbWVkQW1vdW50BRBhbW91bnRUb0V4Y2hhbmdlBAtjaGFuZ2VFbnRyeQMJAGYCBQZjaGFuZ2UAAAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQRwb29sBQ5rUG9vbENhcENoYW5nZQkAZAIFBmNoYW5nZQkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQCsAgIFBHBvb2wFDmtQb29sQ2FwQ2hhbmdlAAAFA25pbAUDbmlsCQDOCAIJAQpjYXBpdGFsaXplBAUEcG9vbAUEdHlwZQUJdG9rZW5Ub0lkBQ9leGNoYW5nZWRBbW91bnQFC2NoYW5nZUVudHJ5AWkBEmNhcGl0YWxpemVFeFN3b3BGaQwEcG9vbAR0eXBlCXRva2VuVG9JZBBhbW91bnRUb0V4Y2hhbmdlBWNsYWltCmV4Y2hhbmdlcnMOZXhjaGFuZ2Vyc1R5cGUFYXJnczEFYXJnczIRcm91dGluZ0Fzc2V0c0tleXMSbWluQW1vdW50VG9SZWNlaXZlB29wdGlvbnMJAQt2YWx1ZU9yRWxzZQIJAQtpc0FkbWluQ2FsbAEFAWkEDSR0MDQxMjMxNDE0MjUDBQVjbGFpbQkBC2NsYWltRmFybWVkAgUEdHlwZQUEcG9vbAQMY2xhaW1lZEFzc2V0AwkAAAIFBHR5cGUFB1NGX1BPT0wFBlNXT1BJRAUEV1hJRAkAlAoCBRBhbW91bnRUb0V4Y2hhbmdlBQxjbGFpbWVkQXNzZXQEDWNsYWltZWRBbW91bnQIBQ0kdDA0MTIzMTQxNDI1Al8xBAxjbGFpbWVkQXNzZXQIBQ0kdDA0MTIzMTQxNDI1Al8yBA9leGNoYW5nZWRBbW91bnQJAQ5leGNoYW5nZVN3b3BGaQoFCXRva2VuVG9JZAUQYW1vdW50VG9FeGNoYW5nZQUMY2xhaW1lZEFzc2V0BQpleGNoYW5nZXJzBQ5leGNoYW5nZXJzVHlwZQUFYXJnczEFBWFyZ3MyBRFyb3V0aW5nQXNzZXRzS2V5cwUSbWluQW1vdW50VG9SZWNlaXZlBQdvcHRpb25zBAZjaGFuZ2UJAGUCBQ1jbGFpbWVkQW1vdW50BRBhbW91bnRUb0V4Y2hhbmdlBAtjaGFuZ2VFbnRyeQMJAGYCBQZjaGFuZ2UAAAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQRwb29sBQ5rUG9vbENhcENoYW5nZQkAZAIFBmNoYW5nZQkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQCsAgIFBHBvb2wFDmtQb29sQ2FwQ2hhbmdlAAAFA25pbAUDbmlsCQDOCAIJAQpjYXBpdGFsaXplBAUEcG9vbAUEdHlwZQUJdG9rZW5Ub0lkBQ9leGNoYW5nZWRBbW91bnQFC2NoYW5nZUVudHJ5AWkBC2luaXROZXdQb29sCAR0eXBlCHBvb2xBZGRyC2luRmVlTm9Mb2FuCWluRmVlTG9hbgxjYXBGZWVOb0xvYW4OY2FwRmVlV2l0aExvYW4Rc3RvcGxvc3NGZWVOb0xvYW4Tc3RvcGxvc3NGZWVXaXRoTG9hbgkBC3ZhbHVlT3JFbHNlAgkBC2lzQWRtaW5DYWxsAQUBaQMDCQECIT0CBQR0eXBlBQdTRl9QT09MCQECIT0CBQR0eXBlBQdXWF9QT09MBwkAAgECCldyb25nIHR5cGUEDSR0MDQyMTQ2NDIyNDAJAQtnZXRQb29sRGF0YQIJAQdBZGRyZXNzAQkA2QQBBQhwb29sQWRkcgUEdHlwZQQDYUlkCAUNJHQwNDIxNDY0MjI0MAJfMQQDYklkCAUNJHQwNDIxNDY0MjI0MAJfMgQEYUJhbAgFDSR0MDQyMTQ2NDIyNDACXzMEBGJCYWwIBQ0kdDA0MjE0NjQyMjQwAl80BAdzaGFyZUlkCAUNJHQwNDIxNDY0MjI0MAJfNQkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQhwb29sQWRkcgUVa0F4bHlJbkZlZVdpdGhvdXRMb2FuBQtpbkZlZU5vTG9hbgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQhwb29sQWRkcgUSa0F4bHlJbkZlZVdpdGhMb2FuBQlpbkZlZUxvYW4JAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUIcG9vbEFkZHIFEWtBeGx5Tm9Mb2FuQ2FwRmVlBQxjYXBGZWVOb0xvYW4JAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUIcG9vbEFkZHIFE2tBeGx5V2l0aExvYW5DYXBGZWUFDmNhcEZlZVdpdGhMb2FuCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFCHBvb2xBZGRyBRZrQXhseVN0b3BMb3NzTm9Mb2FuRmVlBRFzdG9wbG9zc0ZlZU5vTG9hbgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQhwb29sQWRkcgUUa0F4bHlTdG9wTG9zc0xvYW5GZWUFE3N0b3Bsb3NzRmVlV2l0aExvYW4JAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUIcG9vbEFkZHIFEWtQb29sSW50ZXJlc3RMb2FuAAAJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUIcG9vbEFkZHIFE2tQb29sSW50ZXJlc3ROb0xvYW4AAAkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIFBWtQb29sBQhwb29sQWRkcgUEdHlwZQkAzAgCCQELU3RyaW5nRW50cnkCCQCsAgIFB3NoYXJlSWQFCmtTaGFyZVBvb2wFCHBvb2xBZGRyBQNuaWwBAnR4AQZ2ZXJpZnkACQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAACAUCdHgPc2VuZGVyUHVibGljS2V5RIzEUQ==", "height": 2624965, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: GSvPoAkKTsZ4JQwsY8qNLXYDedvh4rrdrLeZCqbYiYpp Next: 8EyLgHdrs3HwReaftE8W4z247DBBXvAfVHo3s6k8FjgU Diff:
OldNewDifferences
9191
9292 let kLendService = "lend_service_addr"
9393
94+let kAdminCallPK = "admin_call_pub_key"
95+
9496 let kPriceOracle = "price_oracle"
9597
9698 let kExContract = "exchange_contract"
109111
110112 let WXID = base58'EMAMLxDnv3xiz8RXg8Btj33jcEw3wLczL3JKYYmuubpc'
111113
114+func getLendSrvAddr () = Address(fromBase58String(valueOrErrorMessage(getString(this, kLendService), "Can't get lend service addr")))
115+
116+
117+func getAdminCallAddr () = addressFromPublicKey(fromBase58String(valueOrErrorMessage(getString(this, kAdminCallPK), "Can't get lend service addr")))
118+
119+
120+func isAdminCall (i) = if ((i.caller == getAdminCallAddr()))
121+ then unit
122+ else throw("Only admin can call this function")
123+
124+
112125 func isSelfCall (i) = if ((i.caller == this))
113126 then unit
114127 else throw("Only contract itself can call this function")
128+
129+
130+func isLandCall (i) = if ((i.caller == getLendSrvAddr()))
131+ then unit
132+ else throw("Only land contract can call this function")
115133
116134
117135 func accountBalance (assetId) = match assetId {
224242 }
225243
226244
227-func getLendSrvAddr () = Address(fromBase58String(valueOrErrorMessage(getString(this, kLendService), "Can't get lend service addr")))
228-
229-
230245 func assetIdToStr (assetId) = match assetId {
231246 case id: ByteVector =>
232247 toBase58String(id)
283298 let pool = valueOrErrorMessage(getString(this, (shareId + kSharePool)), "Can't find pool addr by share id")
284299 let poolAddr = Address(fromBase58String(pool))
285300 let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited")
286- let $t083478412 = getPoolData(poolAddr, pType)
287- let aId = $t083478412._1
288- let bId = $t083478412._2
289- let aBalance = $t083478412._3
290- let bBalance = $t083478412._4
301+ let $t088108875 = getPoolData(poolAddr, pType)
302+ let aId = $t088108875._1
303+ let bId = $t088108875._2
304+ let aBalance = $t088108875._3
305+ let bBalance = $t088108875._4
291306 let dPriceA = ( let @ = invoke(priceOracleAddr, "getTWAP60", [aId, false], nil)
292307 if ($isInstanceOf(@, "(Int, Int)"))
293308 then @
332347
333348
334349 func calcReplenishByTwoTokens (pType,poolAddr,pmtA,aId,pmtB,bId,balA,balB) = {
335- let $t096409945 = if ((pType == SF_POOL))
350+ let $t01010310408 = if ((pType == SF_POOL))
336351 then $Tuple2(nil, nil)
337352 else $Tuple2(split({
338353 let @ = invoke(poolAddr, "evaluatePutByAmountAssetREADONLY", [pmtA], nil)
345360 then @
346361 else throw(($getType(@) + " couldn't be cast to String"))
347362 }, "__"))
348- if (($t096409945 == $t096409945))
363+ if (($t01010310408 == $t01010310408))
349364 then {
350- let evalPutInB = $t096409945._2
351- let evalPutInA = $t096409945._1
352- let $t0995510151 = if ((pType == SF_POOL))
365+ let evalPutInB = $t01010310408._2
366+ let evalPutInA = $t01010310408._1
367+ let $t01041810614 = if ((pType == SF_POOL))
353368 then $Tuple2(fraction(SCALE8, pmtA, balA), fraction(SCALE8, pmtB, balB))
354369 else $Tuple2(parseIntValue(evalPutInA[1]), parseIntValue(evalPutInB[1]))
355- let ratioA = $t0995510151._1
356- let ratioB = $t0995510151._2
357- let $t01015710639 = if ((ratioB > ratioA))
370+ let ratioA = $t01041810614._1
371+ let ratioB = $t01041810614._2
372+ let $t01062011102 = if ((ratioB > ratioA))
358373 then {
359374 let pmt = if ((pType == SF_POOL))
360375 then fraction(balB, ratioA, SCALE8, CEILING)
367382 else parseIntValue(evalPutInB[7])
368383 $Tuple5(pmt, pmtB, (pmtA - pmt), aId, ratioA)
369384 }
370- let pmtInA = $t01015710639._1
371- let pmtInB = $t01015710639._2
372- let change = $t01015710639._3
373- let changeAssetId = $t01015710639._4
374- let lp = $t01015710639._5
385+ let pmtInA = $t01062011102._1
386+ let pmtInB = $t01062011102._2
387+ let change = $t01062011102._3
388+ let changeAssetId = $t01062011102._4
389+ let lp = $t01062011102._5
375390 $Tuple5(pmtInA, pmtInB, change, changeAssetId, lp)
376391 }
377392 else throw("Strict value is not equal to itself.")
403418
404419
405420 func unstakeLP (pool,pType,shareId,amount) = {
406- let $t01186912226 = if ((pType == SF_POOL))
421+ let $t01233212689 = if ((pType == SF_POOL))
407422 then $Tuple3(getSFFarmingAddr(), "withdrawShareTokens", [pool, amount])
408423 else if ((pType == WX_POOL))
409424 then $Tuple3(getWXFarmingAddr(Address(fromBase58String(pool))), "unstake", [shareId, amount])
410425 else throw("Wrong pool type")
411- let farmAddr = $t01186912226._1
412- let fName = $t01186912226._2
413- let params = $t01186912226._3
426+ let farmAddr = $t01233212689._1
427+ let fName = $t01233212689._2
428+ let params = $t01233212689._3
414429 let inv = invoke(farmAddr, fName, params, nil)
415430 if ((inv == inv))
416431 then amount
423438 let feeScale6 = 1000000
424439 let fee = getIntegerValue(poolAddr, kSFPoolFee)
425440 let amntGetNoFee = fraction(amountTokenToGet, feeScale6, (feeScale6 - fee))
426- let $t01263912927 = if ((assetTokenToGet == assetIdA))
441+ let $t01310213390 = if ((assetTokenToGet == assetIdA))
427442 then {
428443 let amountToPay = fraction(balA, amntGetNoFee, (balB - amntGetNoFee))
429444 $Tuple2(amountToPay, assetIdB)
432447 let amountToPay = fraction(balB, amntGetNoFee, (balA - amntGetNoFee))
433448 $Tuple2(amountToPay, assetIdA)
434449 }
435- let amountToPay = $t01263912927._1
436- let assetToPay = $t01263912927._2
450+ let amountToPay = $t01310213390._1
451+ let assetToPay = $t01310213390._2
437452 $Tuple2(assetToPay, amountToPay)
438453 }
439454
442457 let prFee = getIntegerValue(wxSwapContract, "%s__protocolFee")
443458 let pFee = getIntegerValue(wxSwapContract, "%s__poolFee")
444459 let feeScale = toBigInt(100000000)
445- let $t01326613574 = if ((assetTokenToGet == assetIdA))
460+ let $t01372914037 = if ((assetTokenToGet == assetIdA))
446461 then {
447462 let amountToPay = fraction(balA, amountTokenToGet, (balB - amountTokenToGet))
448463 $Tuple2(amountToPay, assetIdB)
451466 let amountToPay = fraction(balB, amountTokenToGet, (balA - amountTokenToGet))
452467 $Tuple2(amountToPay, assetIdA)
453468 }
454- let amountToPay = $t01326613574._1
455- let assetToPay = $t01326613574._2
469+ let amountToPay = $t01372914037._1
470+ let assetToPay = $t01372914037._2
456471 let amountToPayWithFee = toInt(fraction(toBigInt(amountToPay), feeScale, (feeScale - toBigInt((prFee + pFee)))))
457472 $Tuple2(assetToPay, amountToPayWithFee)
458473 }
460475
461476 func exchangeDirectly (type,pool,assetIdA,assetIdB,balA,balB,amountTokenToGet,assetTokenToGet) = if ((type == SF_POOL))
462477 then {
463- let $t01391214034 = calcAmountToPaySF(pool, assetIdA, assetIdB, balA, balB, amountTokenToGet, assetTokenToGet)
464- let assetToPay = $t01391214034._1
465- let amountToPay = $t01391214034._2
478+ let $t01437514497 = calcAmountToPaySF(pool, assetIdA, assetIdB, balA, balB, amountTokenToGet, assetTokenToGet)
479+ let assetToPay = $t01437514497._1
480+ let amountToPay = $t01437514497._2
466481 invoke(addressFromStringValue(pool), "callFunction", ["exchange", ["1"]], [AttachedPayment(assetIdFromStr(assetToPay), amountToPay)])
467482 }
468483 else {
469- let $t01418514307 = calcAmountToPayWX(pool, assetIdA, assetIdB, balA, balB, amountTokenToGet, assetTokenToGet)
470- let assetToPay = $t01418514307._1
471- let amountToPay = $t01418514307._2
484+ let $t01464814770 = calcAmountToPayWX(pool, assetIdA, assetIdB, balA, balB, amountTokenToGet, assetTokenToGet)
485+ let assetToPay = $t01464814770._1
486+ let amountToPay = $t01464814770._2
472487 invoke(wxSwapContract, "swap", [1, assetTokenToGet, toString(this)], [AttachedPayment(assetIdFromStr(assetToPay), amountToPay)])
473488 }
474489
484499 else throw(($getType(@) + " couldn't be cast to List[Any]"))
485500 }
486501 if ((inv == inv))
487- then {
502+ then $Tuple2({
488503 let @ = inv[0]
489504 if ($isInstanceOf(@, "Int"))
490505 then @
491506 else throw(($getType(@) + " couldn't be cast to Int"))
492- }
507+ }, {
508+ let @ = inv[1]
509+ if ($isInstanceOf(@, "Int"))
510+ then @
511+ else throw(($getType(@) + " couldn't be cast to Int"))
512+ })
493513 else throw("Strict value is not equal to itself.")
494514 }
495515 else if ((pType == WX_POOL))
496516 then {
497- let $t01487215213 = if (if ((pmtA > 0))
517+ let $t01535815699 = if (if ((pmtA > 0))
498518 then (pmtB > 0)
499519 else false)
500520 then {
501- let $t01495315079 = calcReplenishByTwoTokens(pType, poolAddr, pmtA, aId, pmtB, bId, balA, balB)
502- let pmtInA = $t01495315079._1
503- let pmtInB = $t01495315079._2
504- let change = $t01495315079._3
505- let changeId = $t01495315079._4
506- let lpAmount = $t01495315079._5
521+ let $t01543915565 = calcReplenishByTwoTokens(pType, poolAddr, pmtA, aId, pmtB, bId, balA, balB)
522+ let pmtInA = $t01543915565._1
523+ let pmtInB = $t01543915565._2
524+ let change = $t01543915565._3
525+ let changeId = $t01543915565._4
526+ let lpAmount = $t01543915565._5
507527 $Tuple3(change, changeId, lpAmount)
508528 }
509529 else if ((pmtA > 0))
510530 then $Tuple3(pmtA, aId, 0)
511531 else $Tuple3(pmtB, bId, 0)
512- let change = $t01487215213._1
513- let changeId = $t01487215213._2
514- let lpTwo = $t01487215213._3
515- let lpOne = if ((change > 0))
532+ let change = $t01535815699._1
533+ let changeId = $t01535815699._2
534+ let lpTwo = $t01535815699._3
535+ let $t01570615922 = if ((change > 0))
516536 then {
517537 let inv = {
518538 let @ = invoke(poolAddr, "putOneTknREADONLY", [changeId, change], nil)
521541 else throw(($getType(@) + " couldn't be cast to (Int, Int, Int)"))
522542 }
523543 if ((inv == inv))
524- then inv._1
544+ then $Tuple2(inv._1, inv._3)
525545 else throw("Strict value is not equal to itself.")
526546 }
527- else 0
528- (lpTwo + lpOne)
547+ else $Tuple2(0, 0)
548+ let lpOne = $t01570615922._1
549+ let loss = $t01570615922._2
550+ $Tuple2((lpTwo + lpOne), loss)
529551 }
530552 else throw("Wrong pool type")
531553 }
533555
534556 func calcWithdrawLPVirt (pType,pool,lpAmount,shareId,aId,bId,balA,balB,borrowAmount,borrowAssetId) = {
535557 let poolAddr = addressFromStringValue(pool)
536- let $t01569916199 = if ((pType == SF_POOL))
558+ let $t01621616716 = if ((pType == SF_POOL))
537559 then {
538560 let inv = {
539561 let @ = invoke(poolAddr, "callFunction", ["withdrawREADONLY", [toString(lpAmount), toString(balA), toString(balB)]], nil)
568590 else throw("Strict value is not equal to itself.")
569591 }
570592 else throw("Wrong pool type")
571- let getAmountA = $t01569916199._1
572- let getAmountB = $t01569916199._2
593+ let getAmountA = $t01621616716._1
594+ let getAmountB = $t01621616716._2
573595 if ((borrowAmount > 0))
574596 then {
575597 let amountToGetEx = if (if ((borrowAssetId == aId))
581603 else false)
582604 then (borrowAmount - getAmountB)
583605 else 0
584- let $t01650216817 = if ((amountToGetEx > 0))
606+ let $t01699417297 = if ((amountToGetEx > 0))
585607 then if ((pType == SF_POOL))
586608 then calcAmountToPaySF(pool, aId, bId, balA, balB, amountToGetEx, borrowAssetId)
587609 else calcAmountToPayWX(pool, aId, bId, balA, balB, amountToGetEx, borrowAssetId)
588610 else $Tuple2("", 0)
589- let assetToPay = $t01650216817._1
590- let amountToPay = $t01650216817._2
611+ let assetToPay = $t01699417297._1
612+ let amountToPay = $t01699417297._2
591613 if ((borrowAssetId == aId))
592614 then $Tuple2(((getAmountA + amountToGetEx) - borrowAmount), (getAmountB - amountToPay))
593615 else $Tuple2((getAmountA - amountToPay), ((getAmountB + amountToGetEx) - borrowAmount))
634656 if ((lpBalanceBefore == lpBalanceBefore))
635657 then {
636658 let poolAddr = addressFromStringValue(pool)
637- let $t01802618442 = if (if ((pmtA > 0))
659+ let $t01849418910 = if (if ((pmtA > 0))
638660 then (pmtB > 0)
639661 else false)
640662 then {
641- let $t01809218208 = calcReplenishByTwoTokens(pType, poolAddr, pmtA, aId, pmtB, bId, balA, balB)
642- let pmtInA = $t01809218208._1
643- let pmtInB = $t01809218208._2
644- let change = $t01809218208._3
645- let changeId = $t01809218208._4
663+ let $t01856018676 = calcReplenishByTwoTokens(pType, poolAddr, pmtA, aId, pmtB, bId, balA, balB)
664+ let pmtInA = $t01856018676._1
665+ let pmtInB = $t01856018676._2
666+ let change = $t01856018676._3
667+ let changeId = $t01856018676._4
646668 let inv = replenishTwoTokensByType(poolAddr, pType, pmtInA, aId, pmtInB, bId)
647669 if ((inv == inv))
648670 then $Tuple2(change, changeId)
653675 else if ((pmtB > 0))
654676 then $Tuple2(pmtB, bId)
655677 else throw("pmts must be > 0")
656- let change = $t01802618442._1
657- let changeId = $t01802618442._2
678+ let change = $t01849418910._1
679+ let changeId = $t01849418910._2
658680 let inv = if ((change > 0))
659681 then replenishOneTokenByType(poolAddr, pType, change, changeId)
660682 else nil
682704 func replenishEntries (pool,user,stakedAmount,axlyFeeAmount,posNum,shareId,type,withLoan) = {
683705 let totalAmount = getPoolTotalShare(pool)
684706 let totalAmountLoan = getPoolTotalShareWithLoan(pool)
685- let $t01930019538 = if (withLoan)
707+ let $t01976820006 = if (withLoan)
686708 then $Tuple2(getIntegerValue(this, (pool + kPoolInterestLoan)), (totalAmountLoan + stakedAmount))
687709 else $Tuple2(getIntegerValue(this, (pool + kPoolInterestNoLoan)), totalAmountLoan)
688- let curPoolInterest = $t01930019538._1
689- let totalStakedWithLoan = $t01930019538._2
710+ let curPoolInterest = $t01976820006._1
711+ let totalStakedWithLoan = $t01976820006._2
690712 [IntegerEntry((pool + kPoolTotal), (totalAmount + stakedAmount)), IntegerEntry((pool + kPoolTotalLoan), totalStakedWithLoan), IntegerEntry((((((pool + "_") + user) + "_") + toString(posNum)) + kUserPosition), stakedAmount), IntegerEntry((((((pool + "_") + user) + "_") + toString(posNum)) + kUserPositionInterest), curPoolInterest), StringEntry((((user + "_") + toString(posNum)) + kUserPositionPool), pool), IntegerEntry((user + kUserPositionNum), posNum), ScriptTransfer(moneyBox, axlyFeeAmount, fromBase58String(shareId))]
691713 }
692714
732754
733755 func capitalize (pool,pType,tokenId,tokenAmount) = {
734756 let poolAddr = Address(fromBase58String(pool))
735- let $t02188921955 = getPoolData(poolAddr, pType)
736- let AId = $t02188921955._1
737- let BId = $t02188921955._2
738- let balA = $t02188921955._3
739- let balB = $t02188921955._4
740- let shareId = $t02188921955._5
757+ let $t02235722423 = getPoolData(poolAddr, pType)
758+ let AId = $t02235722423._1
759+ let BId = $t02235722423._2
760+ let balA = $t02235722423._3
761+ let balB = $t02235722423._4
762+ let shareId = $t02235722423._5
741763 if (if ((tokenId != AId))
742764 then (tokenId != BId)
743765 else false)
744766 then throw("Wrong asset")
745767 else {
746- let $t02204022120 = if ((tokenId == AId))
768+ let $t02250822588 = if ((tokenId == AId))
747769 then $Tuple2(tokenAmount, 0)
748770 else $Tuple2(0, tokenAmount)
749- let pmtA = $t02204022120._1
750- let pmtB = $t02204022120._2
751- let $t02212322227 = replenishByType(pType, pool, NO_FEE, pmtA, AId, pmtB, BId, balA, balB, shareId)
752- let stakedAmount = $t02212322227._1
753- let nf = $t02212322227._2
771+ let pmtA = $t02250822588._1
772+ let pmtB = $t02250822588._2
773+ let $t02259122695 = replenishByType(pType, pool, NO_FEE, pmtA, AId, pmtB, BId, balA, balB, shareId)
774+ let stakedAmount = $t02259122695._1
775+ let nf = $t02259122695._2
754776 let curPoolInterestLoan = valueOrElse(getInteger(this, (pool + kPoolInterestLoan)), 0)
755777 let curPoolInterestNoLoan = valueOrElse(getInteger(this, (pool + kPoolInterestNoLoan)), 0)
756778 let totalShareAmount = getPoolTotalShare(pool)
777799 func withdrawAmountCalc (pool,userCanWithdraw,debt,borrowAsset) = {
778800 let poolAddr = Address(fromBase58String(pool))
779801 let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Unknown pool")
780- let $t02399524071 = getPoolData(poolAddr, pType)
781- let assetIdA = $t02399524071._1
782- let assetIdB = $t02399524071._2
783- let balA = $t02399524071._3
784- let balB = $t02399524071._4
785- let shareId = $t02399524071._5
802+ let $t02446324539 = getPoolData(poolAddr, pType)
803+ let assetIdA = $t02446324539._1
804+ let assetIdB = $t02446324539._2
805+ let balA = $t02446324539._3
806+ let balB = $t02446324539._4
807+ let shareId = $t02446324539._5
786808 let cBalABefore = accountBalance(assetIdFromStr(assetIdA))
787809 if ((cBalABefore == cBalABefore))
788810 then {
801823 then {
802824 let cBalAAfter = accountBalance(assetIdFromStr(assetIdA))
803825 let cBalBAfter = accountBalance(assetIdFromStr(assetIdB))
804- let $t02463424723 = $Tuple2((cBalAAfter - cBalABefore), (cBalBAfter - cBalBBefore))
805- let tokensAmountA = $t02463424723._1
806- let tokensAmountB = $t02463424723._2
807- let $t02472625422 = if ((debt > 0))
826+ let $t02510225191 = $Tuple2((cBalAAfter - cBalABefore), (cBalBAfter - cBalBBefore))
827+ let tokensAmountA = $t02510225191._1
828+ let tokensAmountB = $t02510225191._2
829+ let $t02519425890 = if ((debt > 0))
808830 then {
809831 let amountToGetEx = if (if ((borrowAsset == assetIdA))
810832 then (debt > tokensAmountA)
827849 else throw("Strict value is not equal to itself.")
828850 }
829851 else $Tuple2(tokensAmountA, tokensAmountB)
830- let toUserAmountA = $t02472625422._1
831- let toUserAmountB = $t02472625422._2
852+ let toUserAmountA = $t02519425890._1
853+ let toUserAmountB = $t02519425890._2
832854 $Tuple7(toUserAmountA, assetIdA, toUserAmountB, assetIdB, cBalAAfter, cBalBAfter, shareId)
833855 }
834856 else throw("Strict value is not equal to itself.")
865887 else throw(($getType(@) + " couldn't be cast to Int"))
866888 }
867889 else 0
868- let $t02692127074 = withdrawAmountCalc(pool, userCanWithdraw, debt, borrowAsset)
869- if (($t02692127074 == $t02692127074))
890+ let $t02738927542 = withdrawAmountCalc(pool, userCanWithdraw, debt, borrowAsset)
891+ if (($t02738927542 == $t02738927542))
870892 then {
871- let shareId = $t02692127074._7
872- let cBalBAfter = $t02692127074._6
873- let cBalAAfter = $t02692127074._5
874- let assetIdB = $t02692127074._4
875- let toUserAmountB = $t02692127074._3
876- let assetIdA = $t02692127074._2
877- let toUserAmountA = $t02692127074._1
893+ let shareId = $t02738927542._7
894+ let cBalBAfter = $t02738927542._6
895+ let cBalAAfter = $t02738927542._5
896+ let assetIdB = $t02738927542._4
897+ let toUserAmountB = $t02738927542._3
898+ let assetIdA = $t02738927542._2
899+ let toUserAmountA = $t02738927542._1
878900 let closeDbtInv = if ((debt > 0))
879901 then invoke(getLendSrvAddr(), "repayFor", [((user + "_") + posId)], [AttachedPayment(assetIdFromStr(borrowAsset), debt)])
880902 else 0
915937 let decPrA = pow(10, 0, getAssetDecimals(aId), 0, 0, DOWN)
916938 let decPrB = pow(10, 0, getAssetDecimals(bId), 0, 0, DOWN)
917939 let paydInDollar = (fraction(dPriceA, pmtA, decPrA) + fraction(dPriceB, pmtB, decPrB))
918- let $t02876028857 = if ((borrowId == aId))
940+ let $t02922829325 = if ((borrowId == aId))
919941 then $Tuple2(dPriceA, decPrA)
920942 else $Tuple2(dPriceB, decPrB)
921- let borrowPrice = $t02876028857._1
922- let borrowDecPr = $t02876028857._2
943+ let borrowPrice = $t02922829325._1
944+ let borrowDecPr = $t02922829325._2
923945 fraction(fraction(paydInDollar, (leverage - 100), 100), borrowDecPr, borrowPrice)
924946 }
925947
931953 then throw("Leverage can't be <100 and >300")
932954 else {
933955 let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited")
934- let $t02927529365 = getPoolData(Address(fromBase58String(pool)), pType)
935- let AId = $t02927529365._1
936- let BId = $t02927529365._2
937- let balA = $t02927529365._3
938- let balB = $t02927529365._4
939- let shareId = $t02927529365._5
956+ let $t02974329833 = getPoolData(Address(fromBase58String(pool)), pType)
957+ let AId = $t02974329833._1
958+ let BId = $t02974329833._2
959+ let balA = $t02974329833._3
960+ let balB = $t02974329833._4
961+ let shareId = $t02974329833._5
940962 let borrowAmount = if ((leverage > 100))
941963 then calcBorrowAmount(pmtA, pmtB, AId, BId, leverage, borrowId)
942964 else 0
943- let $t02950029607 = if ((borrowId == AId))
965+ let $t02996830075 = if ((borrowId == AId))
944966 then $Tuple2((pmtA + borrowAmount), pmtB)
945967 else $Tuple2(pmtA, (pmtB + borrowAmount))
946- let payInA = $t02950029607._1
947- let payInB = $t02950029607._2
948- let lpAmount = calcReplenishLPVirt(pType, pool, payInA, AId, payInB, BId, balA, balB)
949- let newBalA = (balA + payInA)
950- let newBalB = (balB + payInB)
951- let $t02976429900 = calcWithdrawLPVirt(pType, pool, lpAmount, shareId, AId, BId, newBalA, newBalB, borrowAmount, borrowId)
952- if (($t02976429900 == $t02976429900))
953- then {
954- let amountGetB = $t02976429900._2
955- let amountGetA = $t02976429900._1
956- let ratioBefore = fraction(balB, SCALE8, balA)
957- let ratioAfter = fraction((newBalB - amountGetB), SCALE8, (newBalA - amountGetA))
958- let impact = (SCALE8 - fraction(ratioBefore, SCALE8, ratioAfter))
959- let impactMod = if ((0 > impact))
960- then (impact * -1)
961- else impact
962- $Tuple2(nil, [impactMod])
963- }
964- else throw("Strict value is not equal to itself.")
968+ let payInA = $t02996830075._1
969+ let payInB = $t02996830075._2
970+ let $t03007830171 = calcReplenishLPVirt(pType, pool, payInA, AId, payInB, BId, balA, balB)
971+ let lpAmount = $t03007830171._1
972+ let loss = $t03007830171._2
973+ let impactMod = if ((0 > loss))
974+ then (loss * -1)
975+ else loss
976+ $Tuple2(nil, [impactMod])
965977 }
966978
967979
987999 @Callable(i)
9881000 func getUserPositionInDollarsREADONLY (user,pools,posNum) = {
9891001 func userPos (a,pool) = {
990- let $t03091430948 = a
991- let totalPos = $t03091430948._1
992- let posDebt = $t03091430948._2
993- let index = $t03091430948._3
1002+ let $t03098431018 = a
1003+ let totalPos = $t03098431018._1
1004+ let posDebt = $t03098431018._2
1005+ let index = $t03098431018._3
9941006 let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited")
995- let $t03104031130 = getPoolData(Address(fromBase58String(pool)), pType)
996- let AId = $t03104031130._1
997- let BId = $t03104031130._2
998- let balA = $t03104031130._3
999- let balB = $t03104031130._4
1000- let shareId = $t03104031130._5
1007+ let $t03111031200 = getPoolData(Address(fromBase58String(pool)), pType)
1008+ let AId = $t03111031200._1
1009+ let BId = $t03111031200._2
1010+ let balA = $t03111031200._3
1011+ let balB = $t03111031200._4
1012+ let shareId = $t03111031200._5
10011013 let borrowAmount = valueOrElse(getInteger(this, (((((pool + "_") + user) + "_") + posNum[index]) + kUserBorrowAmount)), 0)
10021014 let userCanWithdraw = userCanWithdrawShareCalc(user, pool, posNum[index], (borrowAmount > 0))
10031015 let sharePrices = getSharePrice(shareId)
10231035 }
10241036 }
10251037
1026- let $t03217332228 = {
1038+ let $t03224332298 = {
10271039 let $l = pools
10281040 let $s = size($l)
10291041 let $acc0 = $Tuple3(nil, nil, 0)
10371049
10381050 $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20)
10391051 }
1040- let pos = $t03217332228._1
1041- let debt = $t03217332228._2
1052+ let pos = $t03224332298._1
1053+ let debt = $t03224332298._2
10421054 $Tuple2(nil, $Tuple2(pos, debt))
10431055 }
10441056
10511063 then throw("Leverage can't be <100 and >300")
10521064 else {
10531065 let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited")
1054- let $t03255132641 = getPoolData(Address(fromBase58String(pool)), pType)
1055- let AId = $t03255132641._1
1056- let BId = $t03255132641._2
1057- let balA = $t03255132641._3
1058- let balB = $t03255132641._4
1059- let shareId = $t03255132641._5
1060- let $t03264433281 = if ((size(i.payments) == 2))
1066+ let $t03262132711 = getPoolData(Address(fromBase58String(pool)), pType)
1067+ let AId = $t03262132711._1
1068+ let BId = $t03262132711._2
1069+ let balA = $t03262132711._3
1070+ let balB = $t03262132711._4
1071+ let shareId = $t03262132711._5
1072+ let $t03271433351 = if ((size(i.payments) == 2))
10611073 then if ((assetIdToStr(i.payments[0].assetId) != AId))
10621074 then throw("Wrong payment asset A")
10631075 else if ((assetIdToStr(i.payments[1].assetId) != BId))
10701082 then $Tuple4(0, AId, i.payments[0].amount, BId)
10711083 else throw("Wrong payment")
10721084 else throw("One or two payments expected")
1073- let pmtA = $t03264433281._1
1074- let pmtAssetA = $t03264433281._2
1075- let pmtB = $t03264433281._3
1076- let pmtAssetB = $t03264433281._4
1085+ let pmtA = $t03271433351._1
1086+ let pmtAssetA = $t03271433351._2
1087+ let pmtB = $t03271433351._3
1088+ let pmtAssetB = $t03271433351._4
10771089 let newPosNum = getNewUserPositionNumber(toString(i.caller))
10781090 if ((leverage > 100))
10791091 then {
10961108 else throw("Strict value is not equal to itself.")
10971109 }
10981110 else {
1099- let $t03420934321 = replenishByType(pType, pool, NO_LOAN_FEE, pmtA, AId, pmtB, BId, balA, balB, shareId)
1100- let userStaked = $t03420934321._1
1101- let axlyFee = $t03420934321._2
1111+ let $t03427934391 = replenishByType(pType, pool, NO_LOAN_FEE, pmtA, AId, pmtB, BId, balA, balB, shareId)
1112+ let userStaked = $t03427934391._1
1113+ let axlyFee = $t03427934391._2
11021114 (replenishEntries(pool, toString(i.caller), userStaked, axlyFee, newPosNum, shareId, pType, false) ++ getCursEntries(AId, BId, shareId))
11031115 }
11041116 }
1105-
1106-
1107-
1108-@Callable(i)
1109-func replenishFromLand (requestId) = {
1110- let $t03453234636 = parseRequest(requestId)
1111- let user = $t03453234636._1
1112- let pool = $t03453234636._2
1113- let pmtA = $t03453234636._3
1114- let AId = $t03453234636._4
1115- let pmtB = $t03453234636._5
1116- let BId = $t03453234636._6
1117- let balA = $t03453234636._7
1118- let balB = $t03453234636._8
1119- let shareId = $t03453234636._9
1120- let bwAsset = $t03453234636._10
1121- let bwAmount = $t03453234636._11
1122- if ((size(i.payments) != 1))
1123- then throw("Wrong payment size")
1124- else if (if ((assetIdToStr(i.payments[0].assetId) != bwAsset))
1125- then true
1126- else (i.payments[0].amount != bwAmount))
1127- then throw("Wrong payment")
1128- else {
1129- let $t03482634950 = if ((AId == bwAsset))
1130- then $Tuple2((pmtA + i.payments[0].amount), pmtB)
1131- else $Tuple2(pmtA, (pmtB + i.payments[0].amount))
1132- let pmtAllA = $t03482634950._1
1133- let pmtAllB = $t03482634950._2
1134- let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Unknown pool")
1135- let $t03503235141 = replenishByType(pType, pool, LOAN_FEE, pmtA, AId, pmtB, BId, balA, balB, shareId)
1136- let userStaked = $t03503235141._1
1137- let axlyFee = $t03503235141._2
1138- let posNum = getNewUserPositionNumber(user)
1139- let borrowEntries = [IntegerEntry((((((pool + "_") + user) + "_") + toString(posNum)) + kUserBorrowAmount), bwAmount), StringEntry((((((pool + "_") + user) + "_") + toString(posNum)) + kUserBorrowAssetId), bwAsset)]
1140- let entries = replenishEntries(pool, user, userStaked, axlyFee, posNum, shareId, pType, true)
1141- $Tuple2((((entries ++ getCursEntries(AId, BId, shareId)) ++ borrowEntries) :+ DeleteEntry((requestId + kRequestId))), userStaked)
1142- }
1143- }
11441117
11451118
11461119
11821155
11831156
11841157 @Callable(i)
1185-func stopLoss (user,posId,pool,assetId) = {
1158+func replenishFromLand (requestId) = valueOrElse(isLandCall(i), {
1159+ let $t03614436248 = parseRequest(requestId)
1160+ let user = $t03614436248._1
1161+ let pool = $t03614436248._2
1162+ let pmtA = $t03614436248._3
1163+ let AId = $t03614436248._4
1164+ let pmtB = $t03614436248._5
1165+ let BId = $t03614436248._6
1166+ let balA = $t03614436248._7
1167+ let balB = $t03614436248._8
1168+ let shareId = $t03614436248._9
1169+ let bwAsset = $t03614436248._10
1170+ let bwAmount = $t03614436248._11
1171+ if ((size(i.payments) != 1))
1172+ then throw("Wrong payment size")
1173+ else if (if ((assetIdToStr(i.payments[0].assetId) != bwAsset))
1174+ then true
1175+ else (i.payments[0].amount != bwAmount))
1176+ then throw("Wrong payment")
1177+ else {
1178+ let $t03643836562 = if ((AId == bwAsset))
1179+ then $Tuple2((pmtA + i.payments[0].amount), pmtB)
1180+ else $Tuple2(pmtA, (pmtB + i.payments[0].amount))
1181+ let pmtAllA = $t03643836562._1
1182+ let pmtAllB = $t03643836562._2
1183+ let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Unknown pool")
1184+ let $t03664436753 = replenishByType(pType, pool, LOAN_FEE, pmtA, AId, pmtB, BId, balA, balB, shareId)
1185+ let userStaked = $t03664436753._1
1186+ let axlyFee = $t03664436753._2
1187+ let posNum = getNewUserPositionNumber(user)
1188+ let borrowEntries = [IntegerEntry((((((pool + "_") + user) + "_") + toString(posNum)) + kUserBorrowAmount), bwAmount), StringEntry((((((pool + "_") + user) + "_") + toString(posNum)) + kUserBorrowAssetId), bwAsset)]
1189+ let entries = replenishEntries(pool, user, userStaked, axlyFee, posNum, shareId, pType, true)
1190+ $Tuple2((((entries ++ getCursEntries(AId, BId, shareId)) ++ borrowEntries) :+ DeleteEntry((requestId + kRequestId))), userStaked)
1191+ }
1192+ })
1193+
1194+
1195+
1196+@Callable(i)
1197+func liquidate (user,posId,liquidateAmount) = valueOrElse(isLandCall(i), {
1198+ let pool = valueOrErrorMessage(getString(this, (((user + "_") + posId) + kUserPositionPool)), "no position")
1199+ let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited")
1200+ let $t03753237622 = getPoolData(Address(fromBase58String(pool)), pType)
1201+ let AId = $t03753237622._1
1202+ let BId = $t03753237622._2
1203+ let balA = $t03753237622._3
1204+ let balB = $t03753237622._4
1205+ let shareId = $t03753237622._5
1206+ let amount = unstakeLP(pool, pType, shareId, liquidateAmount)
1207+ let borrowAmount = getIntegerValue(this, (((((pool + "_") + user) + "_") + posId) + kUserBorrowAmount))
1208+ let borrowAsset = getStringValue(this, (((((pool + "_") + user) + "_") + posId) + kUserBorrowAssetId))
1209+ let userCanWithdraw = userCanWithdrawShareCalc(user, pool, posId, (borrowAmount > 0))
1210+ if ((borrowAmount == 0))
1211+ then throw("You can't liquidate position without borrow")
1212+ else [IntegerEntry((((((pool + "_") + user) + "_") + posId) + kUserPositionInterest), getIntegerValue(this, (pool + kPoolInterestLoan))), IntegerEntry((pool + kPoolTotalLoan), (getPoolTotalShareWithLoan(pool) - liquidateAmount)), IntegerEntry((pool + kPoolTotal), (getPoolTotalShare(pool) - liquidateAmount)), IntegerEntry((((((pool + "_") + user) + "_") + posId) + kUserPosition), (userCanWithdraw - liquidateAmount)), ScriptTransfer(i.caller, amount, fromBase58String(shareId))]
1213+ })
1214+
1215+
1216+
1217+@Callable(i)
1218+func stopLoss (user,posId,pool,assetId) = valueOrElse(isAdminCall(i), {
11861219 let tokenOraclePrice = ( let @ = invoke(priceOracleAddr, "getTWAP60", [assetId, false], nil)
11871220 if ($isInstanceOf(@, "(Int, Int)"))
11881221 then @
11901223 if (!(isDefined(getInteger(this, (((((((user + "_") + toString(posId)) + "_") + pool) + "_") + assetId) + kUserStopLoss)))))
11911224 then throw("No entry")
11921225 else (withdrawToUser(toString(i.caller), pool, toString(posId), true) :+ DeleteEntry((((((((user + "_") + toString(posId)) + "_") + pool) + "_") + assetId) + kUserStopLoss)))
1193- }
1226+ })
11941227
11951228
11961229
11971230 @Callable(i)
1198-func liquidate (user,posId,liquidateAmount) = {
1199- let pool = valueOrErrorMessage(getString(this, (((user + "_") + posId) + kUserPositionPool)), "no position")
1200- let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited")
1201- let $t03790337993 = getPoolData(Address(fromBase58String(pool)), pType)
1202- let AId = $t03790337993._1
1203- let BId = $t03790337993._2
1204- let balA = $t03790337993._3
1205- let balB = $t03790337993._4
1206- let shareId = $t03790337993._5
1207- let amount = unstakeLP(pool, pType, shareId, liquidateAmount)
1208- let borrowAmount = getIntegerValue(this, (((((pool + "_") + user) + "_") + posId) + kUserBorrowAmount))
1209- let borrowAsset = getStringValue(this, (((((pool + "_") + user) + "_") + posId) + kUserBorrowAssetId))
1210- let userCanWithdraw = userCanWithdrawShareCalc(user, pool, posId, (borrowAmount > 0))
1211- if ((borrowAmount == 0))
1212- then throw("You can't liquidate position without borrow")
1213- else [IntegerEntry((((((pool + "_") + user) + "_") + posId) + kUserPositionInterest), getIntegerValue(this, (pool + kPoolInterestLoan))), IntegerEntry((pool + kPoolTotalLoan), (getPoolTotalShareWithLoan(pool) - liquidateAmount)), IntegerEntry((pool + kPoolTotal), (getPoolTotalShare(pool) - liquidateAmount)), IntegerEntry((((((pool + "_") + user) + "_") + posId) + kUserPosition), (userCanWithdraw - liquidateAmount)), ScriptTransfer(i.caller, amount, fromBase58String(shareId))]
1214- }
1215-
1216-
1217-
1218-@Callable(i)
1219-func capitalizeExKeeper (pool,type,tokenToId,amountToExchange,claim,amountsIn,addresses,assetsToReceive,estReceived,slippageTolerance,minReceived,options) = {
1220- let $t03922839422 = if (claim)
1231+func capitalizeExKeeper (pool,type,tokenToId,amountToExchange,claim,amountsIn,addresses,assetsToReceive,estReceived,slippageTolerance,minReceived,options) = valueOrElse(isAdminCall(i), {
1232+ let $t03940739601 = if (claim)
12211233 then claimFarmed(type, pool)
12221234 else {
12231235 let claimedAsset = if ((type == SF_POOL))
12251237 else WXID
12261238 $Tuple2(amountToExchange, claimedAsset)
12271239 }
1228- let claimedAmount = $t03922839422._1
1229- let claimedAsset = $t03922839422._2
1240+ let claimedAmount = $t03940739601._1
1241+ let claimedAsset = $t03940739601._2
12301242 let exchangedAmount = exchangeKeeper(tokenToId, amountToExchange, claimedAsset, amountsIn, addresses, assetsToReceive, estReceived, slippageTolerance, minReceived, options)
12311243 let change = (claimedAmount - amountToExchange)
12321244 let changeEntry = if ((change > 0))
12331245 then [IntegerEntry((pool + kPoolCapChange), (change + valueOrElse(getInteger(this, (pool + kPoolCapChange)), 0)))]
12341246 else nil
12351247 (capitalize(pool, type, tokenToId, exchangedAmount) ++ changeEntry)
1236- }
1248+ })
12371249
12381250
12391251
12401252 @Callable(i)
1241-func capitalizeExPuzzle (pool,type,tokenToId,amountToExchange,claim,routesStr,minToReceive,options) = {
1242- let $t04007940273 = if (claim)
1253+func capitalizeExPuzzle (pool,type,tokenToId,amountToExchange,claim,routesStr,minToReceive,options) = valueOrElse(isAdminCall(i), {
1254+ let $t04028640480 = if (claim)
12431255 then claimFarmed(type, pool)
12441256 else {
12451257 let claimedAsset = if ((type == SF_POOL))
12471259 else WXID
12481260 $Tuple2(amountToExchange, claimedAsset)
12491261 }
1250- let claimedAmount = $t04007940273._1
1251- let claimedAsset = $t04007940273._2
1262+ let claimedAmount = $t04028640480._1
1263+ let claimedAsset = $t04028640480._2
12521264 let exchangedAmount = exchangePuzzle(tokenToId, amountToExchange, claimedAsset, routesStr, minToReceive, options)
12531265 let change = (claimedAmount - amountToExchange)
12541266 let changeEntry = if ((change > 0))
12551267 then [IntegerEntry((pool + kPoolCapChange), (change + valueOrElse(getInteger(this, (pool + kPoolCapChange)), 0)))]
12561268 else nil
12571269 (capitalize(pool, type, tokenToId, exchangedAmount) ++ changeEntry)
1258- }
1270+ })
12591271
12601272
12611273
12621274 @Callable(i)
1263-func capitalizeExSwopFi (pool,type,tokenToId,amountToExchange,claim,exchangers,exchangersType,args1,args2,routingAssetsKeys,minAmountToReceive,options) = {
1264- let $t04099641190 = if (claim)
1275+func capitalizeExSwopFi (pool,type,tokenToId,amountToExchange,claim,exchangers,exchangersType,args1,args2,routingAssetsKeys,minAmountToReceive,options) = valueOrElse(isAdminCall(i), {
1276+ let $t04123141425 = if (claim)
12651277 then claimFarmed(type, pool)
12661278 else {
12671279 let claimedAsset = if ((type == SF_POOL))
12691281 else WXID
12701282 $Tuple2(amountToExchange, claimedAsset)
12711283 }
1272- let claimedAmount = $t04099641190._1
1273- let claimedAsset = $t04099641190._2
1284+ let claimedAmount = $t04123141425._1
1285+ let claimedAsset = $t04123141425._2
12741286 let exchangedAmount = exchangeSwopFi(tokenToId, amountToExchange, claimedAsset, exchangers, exchangersType, args1, args2, routingAssetsKeys, minAmountToReceive, options)
12751287 let change = (claimedAmount - amountToExchange)
12761288 let changeEntry = if ((change > 0))
12771289 then [IntegerEntry((pool + kPoolCapChange), (change + valueOrElse(getInteger(this, (pool + kPoolCapChange)), 0)))]
12781290 else nil
12791291 (capitalize(pool, type, tokenToId, exchangedAmount) ++ changeEntry)
1280- }
1292+ })
12811293
12821294
12831295
12841296 @Callable(i)
1285-func initNewPool (type,poolAddr,inFeeNoLoan,inFeeLoan,capFeeNoLoan,capFeeWithLoan,stoplossFeeNoLoan,stoplossFeeWithLoan) = if (if ((type != SF_POOL))
1297+func initNewPool (type,poolAddr,inFeeNoLoan,inFeeLoan,capFeeNoLoan,capFeeWithLoan,stoplossFeeNoLoan,stoplossFeeWithLoan) = valueOrElse(isAdminCall(i), if (if ((type != SF_POOL))
12861298 then (type != WX_POOL)
12871299 else false)
12881300 then throw("Wrong type")
12891301 else {
1290- let $t04188341977 = getPoolData(Address(fromBase58String(poolAddr)), type)
1291- let aId = $t04188341977._1
1292- let bId = $t04188341977._2
1293- let aBal = $t04188341977._3
1294- let bBal = $t04188341977._4
1295- let shareId = $t04188341977._5
1302+ let $t04214642240 = getPoolData(Address(fromBase58String(poolAddr)), type)
1303+ let aId = $t04214642240._1
1304+ let bId = $t04214642240._2
1305+ let aBal = $t04214642240._3
1306+ let bBal = $t04214642240._4
1307+ let shareId = $t04214642240._5
12961308 [IntegerEntry((poolAddr + kAxlyInFeeWithoutLoan), inFeeNoLoan), IntegerEntry((poolAddr + kAxlyInFeeWithLoan), inFeeLoan), IntegerEntry((poolAddr + kAxlyNoLoanCapFee), capFeeNoLoan), IntegerEntry((poolAddr + kAxlyWithLoanCapFee), capFeeWithLoan), IntegerEntry((poolAddr + kAxlyStopLossNoLoanFee), stoplossFeeNoLoan), IntegerEntry((poolAddr + kAxlyStopLossLoanFee), stoplossFeeWithLoan), IntegerEntry((poolAddr + kPoolInterestLoan), 0), IntegerEntry((poolAddr + kPoolInterestNoLoan), 0), StringEntry((kPool + poolAddr), type), StringEntry((shareId + kSharePool), poolAddr)]
1297- }
1298-
1299-
1300-
1301-@Callable(i)
1302-func capitalizeTest (pool,pType,tokenId,tokenAmount) = {
1303- let poolAddr = Address(fromBase58String(pool))
1304- let $t04277342852 = getPoolData(poolAddr, pType)
1305- let AId = $t04277342852._1
1306- let BId = $t04277342852._2
1307- let balA = $t04277342852._3
1308- let balB = $t04277342852._4
1309- let shareId = $t04277342852._5
1310- let $t04285542935 = if ((tokenId == AId))
1311- then $Tuple2(tokenAmount, 0)
1312- else $Tuple2(0, tokenAmount)
1313- let pmtA = $t04285542935._1
1314- let pmtB = $t04285542935._2
1315- let $t04293843042 = replenishByType(pType, pool, NO_FEE, pmtA, AId, pmtB, BId, balA, balB, shareId)
1316- let stakedAmount = $t04293843042._1
1317- let nf = $t04293843042._2
1318- let curPoolInterestLoan = valueOrElse(getInteger(this, (pool + kPoolInterestLoan)), 0)
1319- let curPoolInterestNoLoan = valueOrElse(getInteger(this, (pool + kPoolInterestNoLoan)), 0)
1320- let totalShareAmount = getPoolTotalShare(pool)
1321- let totalShareAmountWithLoan = getPoolTotalShareWithLoan(pool)
1322- let loanPercent = fraction(totalShareAmountWithLoan, SCALE8, totalShareAmount)
1323- let stakedLoan = fraction(stakedAmount, loanPercent, SCALE8)
1324- let stakedNoLoan = (stakedAmount - stakedLoan)
1325- let newInterestLoan = if ((totalShareAmountWithLoan > 0))
1326- then (curPoolInterestLoan + fraction(stakedLoan, SCALE10, totalShareAmountWithLoan))
1327- else 0
1328- let newInterestNoLoan = if (((totalShareAmount - totalShareAmountWithLoan) > 0))
1329- then (curPoolInterestNoLoan + fraction(stakedNoLoan, SCALE10, (totalShareAmount - totalShareAmountWithLoan)))
1330- else 0
1331- let axlyFeeLoan = fraction(stakedLoan, getAxlyFee(pool, CAP_FEE_LOAN), FEE_SCALE6)
1332- let axlyFeeNoLoan = fraction(stakedNoLoan, getAxlyFee(pool, CAP_FEE_NO_LOAN), FEE_SCALE6)
1333- let axlyFee = unstakeLP(pool, pType, shareId, (axlyFeeLoan + axlyFeeNoLoan))
1334- if ((axlyFee == axlyFee))
1335- then ([IntegerEntry((pool + kPoolInterestLoan), newInterestLoan), IntegerEntry((pool + kPoolInterestNoLoan), newInterestNoLoan), IntegerEntry((pool + kPoolTotal), ((totalShareAmount + stakedAmount) - axlyFee)), IntegerEntry((pool + kPoolTotalLoan), ((totalShareAmountWithLoan + stakedLoan) - axlyFeeLoan)), ScriptTransfer(moneyBox, (axlyFeeLoan + axlyFeeNoLoan), fromBase58String(shareId))] ++ getCursEntries(AId, BId, shareId))
1336- else throw("Strict value is not equal to itself.")
1337- }
1338-
1339-
1340-
1341-@Callable(i)
1342-func claimFarmedTest (type,pool) = if ((type == SF_POOL))
1343- then {
1344- let balBefore = accountBalance(SWOPID)
1345- if ((balBefore == balBefore))
1346- then {
1347- let inv = invoke(getSFFarmingAddr(), "claim", [pool], nil)
1348- if ((inv == inv))
1349- then {
1350- let balAfter = accountBalance(SWOPID)
1351- $Tuple2(nil, $Tuple2((balAfter - balBefore), SWOPID))
1352- }
1353- else throw("Strict value is not equal to itself.")
1354- }
1355- else throw("Strict value is not equal to itself.")
1356- }
1357- else if ((type == WX_POOL))
1358- then {
1359- let balBefore = accountBalance(WXID)
1360- if ((balBefore == balBefore))
1361- then {
1362- let inv = invoke(getWXFarmingAddr(Address(fromBase58String(pool))), "claimWX", [pool], nil)
1363- if ((inv == inv))
1364- then {
1365- let balAfter = accountBalance(WXID)
1366- $Tuple2(nil, $Tuple2((balAfter - balBefore), WXID))
1367- }
1368- else throw("Strict value is not equal to itself.")
1369- }
1370- else throw("Strict value is not equal to itself.")
1371- }
1372- else throw("Wrong pool type")
1309+ })
13731310
13741311
13751312 @Verifier(tx)
Full:
OldNewDifferences
11 {-# STDLIB_VERSION 6 #-}
22 {-# SCRIPT_TYPE ACCOUNT #-}
33 {-# CONTENT_TYPE DAPP #-}
44 let SF_POOL = "SF"
55
66 let WX_POOL = "WX"
77
88 let CAP_FEE_NO_LOAN = "capNoLoan"
99
1010 let CAP_FEE_LOAN = "capLoan"
1111
1212 let STOPLOSS_FEE_NO_LOAN = "stopLossNoLoan"
1313
1414 let STOPLOSS_LOAN = "stopLossLoan"
1515
1616 let LOAN_FEE = "loan"
1717
1818 let NO_LOAN_FEE = "noLoan"
1919
2020 let NO_FEE = "noFee"
2121
2222 let SCALE8 = 100000000
2323
2424 let SCALE10 = 10000000000
2525
2626 let FEE_SCALE6 = 1000000
2727
2828 let kSFPoolAAssetBalance = "A_asset_balance"
2929
3030 let kSFPoolBAssetBalance = "B_asset_balance"
3131
3232 let kSFPoolAAssetId = "A_asset_id"
3333
3434 let kSFPoolBAssetId = "B_asset_id"
3535
3636 let kSFPoolShareId = "share_asset_id"
3737
3838 let kSFPoolShareSupply = "share_asset_supply"
3939
4040 let kSFPoolFee = "commission"
4141
4242 let kUserPosition = "_user_position"
4343
4444 let kUserPositionPool = "_user_position_pool"
4545
4646 let kUserBorrowAmount = "_user_position_borrow_amount"
4747
4848 let kUserBorrowAssetId = "_user_position_borrow_asset_id"
4949
5050 let kUserPositionNum = "_user_position_number"
5151
5252 let kUserPositionInterest = "_user_position_interest"
5353
5454 let kPoolTotal = "_pool_total"
5555
5656 let kPoolTotalLoan = "_pool_total_loan"
5757
5858 let kPoolInterestLoan = "_pool_interest_loan"
5959
6060 let kPoolInterestNoLoan = "_pool_interest_no_loan"
6161
6262 let kAxlyInFeeWithoutLoan = "_axly_fee_without_loan"
6363
6464 let kAxlyInFeeWithLoan = "_axly_fee_with_loan"
6565
6666 let kAxlyNoLoanCapFee = "_axly_fee_cap_with_loan"
6767
6868 let kAxlyWithLoanCapFee = "_axly_fee_cap_no_loan"
6969
7070 let kAxlyStopLossNoLoanFee = "_axly_fee_stoploss_with_loan"
7171
7272 let kAxlyStopLossLoanFee = "_axly_fee_stoploss_no_loan"
7373
7474 let kRequestId = "_request_id"
7575
7676 let kRequestIter = "requests_iter"
7777
7878 let kPool = "pool_"
7979
8080 let kSharePool = "_pool_share_id"
8181
8282 let kPoolCapChange = "_pool_cap_change"
8383
8484 let kTokenLastPrice = "last_price"
8585
8686 let kUserStopLoss = "_stop_loss"
8787
8888 let kMoneyBox = "axly_money_box"
8989
9090 let kSFFarmingAddr = "swopfi_farming_addr"
9191
9292 let kLendService = "lend_service_addr"
9393
94+let kAdminCallPK = "admin_call_pub_key"
95+
9496 let kPriceOracle = "price_oracle"
9597
9698 let kExContract = "exchange_contract"
9799
98100 let kWxSwapContract = "wx_swap_contract"
99101
100102 let moneyBox = Address(fromBase58String(valueOrErrorMessage(getString(this, kMoneyBox), "No axly moneyBox address")))
101103
102104 let exContract = Address(fromBase58String(valueOrErrorMessage(getString(this, kExContract), "No exchange contract address")))
103105
104106 let priceOracleAddr = Address(fromBase58String(valueOrErrorMessage(getString(this, kPriceOracle), "No price oracle address")))
105107
106108 let wxSwapContract = Address(fromBase58String(valueOrErrorMessage(getString(this, kWxSwapContract), "No wx swap address")))
107109
108110 let SWOPID = base58'4W19ndijcc2CsQa9HGW2dfXKTVXhnneWWttxXrtjPmEp'
109111
110112 let WXID = base58'EMAMLxDnv3xiz8RXg8Btj33jcEw3wLczL3JKYYmuubpc'
111113
114+func getLendSrvAddr () = Address(fromBase58String(valueOrErrorMessage(getString(this, kLendService), "Can't get lend service addr")))
115+
116+
117+func getAdminCallAddr () = addressFromPublicKey(fromBase58String(valueOrErrorMessage(getString(this, kAdminCallPK), "Can't get lend service addr")))
118+
119+
120+func isAdminCall (i) = if ((i.caller == getAdminCallAddr()))
121+ then unit
122+ else throw("Only admin can call this function")
123+
124+
112125 func isSelfCall (i) = if ((i.caller == this))
113126 then unit
114127 else throw("Only contract itself can call this function")
128+
129+
130+func isLandCall (i) = if ((i.caller == getLendSrvAddr()))
131+ then unit
132+ else throw("Only land contract can call this function")
115133
116134
117135 func accountBalance (assetId) = match assetId {
118136 case id: ByteVector =>
119137 assetBalance(this, id)
120138 case waves: Unit =>
121139 wavesBalance(this).available
122140 case _ =>
123141 throw("Match error")
124142 }
125143
126144
127145 func getSFPoolData (poolAddr) = $Tuple5(valueOrErrorMessage(getString(poolAddr, kSFPoolAAssetId), "Can't get pool A asset id"), valueOrErrorMessage(getString(poolAddr, kSFPoolBAssetId), "Can't get pool B asset id"), valueOrErrorMessage(getInteger(poolAddr, kSFPoolAAssetBalance), "Can't get pool A asset balance"), valueOrErrorMessage(getInteger(poolAddr, kSFPoolBAssetBalance), "Can't get pool B asset balance"), valueOrErrorMessage(getString(poolAddr, kSFPoolShareId), "Can't get share asset id"))
128146
129147
130148 func getWXPoolData (poolAddr) = {
131149 let cfg = {
132150 let @ = invoke(poolAddr, "getPoolConfigWrapperREADONLY", nil, nil)
133151 if ($isInstanceOf(@, "List[Any]"))
134152 then @
135153 else throw(($getType(@) + " couldn't be cast to List[Any]"))
136154 }
137155 if ((cfg == cfg))
138156 then {
139157 let aId = valueOrErrorMessage({
140158 let @ = cfg[4]
141159 if ($isInstanceOf(@, "String"))
142160 then @
143161 else unit
144162 }, "Can't get pool A asset id")
145163 let bId = valueOrErrorMessage({
146164 let @ = cfg[5]
147165 if ($isInstanceOf(@, "String"))
148166 then @
149167 else unit
150168 }, "Can't get pool B asset id")
151169 let shareId = valueOrErrorMessage({
152170 let @ = cfg[3]
153171 if ($isInstanceOf(@, "String"))
154172 then @
155173 else unit
156174 }, "Can't get pool LP asset id")
157175 let balA = {
158176 let @ = invoke(poolAddr, "getAccBalanceWrapperREADONLY", [aId], nil)
159177 if ($isInstanceOf(@, "Int"))
160178 then @
161179 else throw(($getType(@) + " couldn't be cast to Int"))
162180 }
163181 if ((balA == balA))
164182 then {
165183 let balB = {
166184 let @ = invoke(poolAddr, "getAccBalanceWrapperREADONLY", [bId], nil)
167185 if ($isInstanceOf(@, "Int"))
168186 then @
169187 else throw(($getType(@) + " couldn't be cast to Int"))
170188 }
171189 if ((balB == balB))
172190 then $Tuple5(aId, bId, balA, balB, shareId)
173191 else throw("Strict value is not equal to itself.")
174192 }
175193 else throw("Strict value is not equal to itself.")
176194 }
177195 else throw("Strict value is not equal to itself.")
178196 }
179197
180198
181199 func getPoolData (poolAddr,type) = if ((type == SF_POOL))
182200 then getSFPoolData(poolAddr)
183201 else if ((type == WX_POOL))
184202 then getWXPoolData(poolAddr)
185203 else throw("Wrong pool type")
186204
187205
188206 func getShareSupply (poolAddr,type,shareId) = if ((type == SF_POOL))
189207 then valueOrErrorMessage(getInteger(poolAddr, kSFPoolShareSupply), "Can't get share asset supply")
190208 else if ((type == WX_POOL))
191209 then valueOrErrorMessage(assetInfo(fromBase58String(shareId)), "Wrong ShareId").quantity
192210 else throw("Wrong pool type")
193211
194212
195213 func getPoolTotalShare (pool) = valueOrElse(getInteger(this, (pool + kPoolTotal)), 0)
196214
197215
198216 func getPoolTotalShareWithLoan (pool) = valueOrElse(getInteger(this, (pool + kPoolTotalLoan)), 0)
199217
200218
201219 func getNewUserPositionNumber (user) = (valueOrElse(getInteger(this, (user + kUserPositionNum)), 0) + 1)
202220
203221
204222 func getAxlyFee (pool,feeType) = if ((feeType == CAP_FEE_LOAN))
205223 then getIntegerValue(this, (pool + kAxlyWithLoanCapFee))
206224 else if ((feeType == CAP_FEE_NO_LOAN))
207225 then getIntegerValue(this, (pool + kAxlyNoLoanCapFee))
208226 else if ((feeType == LOAN_FEE))
209227 then getIntegerValue(this, (pool + kAxlyInFeeWithLoan))
210228 else if ((feeType == NO_LOAN_FEE))
211229 then getIntegerValue(this, (pool + kAxlyInFeeWithoutLoan))
212230 else if ((feeType == NO_FEE))
213231 then 0
214232 else throw("Wrong fee type")
215233
216234
217235 func getSFFarmingAddr () = Address(fromBase58String(valueOrErrorMessage(getString(this, kSFFarmingAddr), "Can't get swopfi farming addr")))
218236
219237
220238 func getWXFarmingAddr (poolAddr) = {
221239 let fContract = Address(fromBase58String(valueOrErrorMessage(getString(poolAddr, "%s__factoryContract"), "Can't get WX factory contract addr")))
222240 let factroyCfg = split(valueOrErrorMessage(getString(fContract, "%s__factoryConfig"), "Can't get WX factory cfg"), "__")
223241 Address(fromBase58String(factroyCfg[1]))
224242 }
225243
226244
227-func getLendSrvAddr () = Address(fromBase58String(valueOrErrorMessage(getString(this, kLendService), "Can't get lend service addr")))
228-
229-
230245 func assetIdToStr (assetId) = match assetId {
231246 case id: ByteVector =>
232247 toBase58String(id)
233248 case waves: Unit =>
234249 "WAVES"
235250 case _ =>
236251 throw("Match error")
237252 }
238253
239254
240255 func assetIdFromStr (assetId) = if ((assetId == "WAVES"))
241256 then unit
242257 else fromBase58String(assetId)
243258
244259
245260 func getAssetDecimals (assetId) = if ((assetId == "WAVES"))
246261 then 8
247262 else match assetInfo(fromBase58String(assetId)) {
248263 case asset: Asset =>
249264 asset.decimals
250265 case _ =>
251266 throw("Can't find asset")
252267 }
253268
254269
255270 func getAssetPrecition (assetId) = pow(10, 0, getAssetDecimals(assetId), 0, 0, DOWN)
256271
257272
258273 func getAssetsPrice (assetIds) = {
259274 func getPrices (a,assetId) = {
260275 let assetPrice = ( let @ = invoke(priceOracleAddr, "getTWAP60", [assetId, false], nil)
261276 if ($isInstanceOf(@, "(Int, Int)"))
262277 then @
263278 else throw(($getType(@) + " couldn't be cast to (Int, Int)")))._2
264279 (a :+ assetPrice)
265280 }
266281
267282 let $l = assetIds
268283 let $s = size($l)
269284 let $acc0 = nil
270285 func $f0_1 ($a,$i) = if (($i >= $s))
271286 then $a
272287 else getPrices($a, $l[$i])
273288
274289 func $f0_2 ($a,$i) = if (($i >= $s))
275290 then $a
276291 else throw("List size exceeds 50")
277292
278293 $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 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)
279294 }
280295
281296
282297 func getSharePrice (shareId) = {
283298 let pool = valueOrErrorMessage(getString(this, (shareId + kSharePool)), "Can't find pool addr by share id")
284299 let poolAddr = Address(fromBase58String(pool))
285300 let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited")
286- let $t083478412 = getPoolData(poolAddr, pType)
287- let aId = $t083478412._1
288- let bId = $t083478412._2
289- let aBalance = $t083478412._3
290- let bBalance = $t083478412._4
301+ let $t088108875 = getPoolData(poolAddr, pType)
302+ let aId = $t088108875._1
303+ let bId = $t088108875._2
304+ let aBalance = $t088108875._3
305+ let bBalance = $t088108875._4
291306 let dPriceA = ( let @ = invoke(priceOracleAddr, "getTWAP60", [aId, false], nil)
292307 if ($isInstanceOf(@, "(Int, Int)"))
293308 then @
294309 else throw(($getType(@) + " couldn't be cast to (Int, Int)")))._2
295310 let dPriceB = ( let @ = invoke(priceOracleAddr, "getTWAP60", [bId, false], nil)
296311 if ($isInstanceOf(@, "(Int, Int)"))
297312 then @
298313 else throw(($getType(@) + " couldn't be cast to (Int, Int)")))._2
299314 let shareSupply = getShareSupply(poolAddr, pType, shareId)
300315 let APrecision = pow(10, 0, getAssetDecimals(aId), 0, 0, DOWN)
301316 let BPrecision = pow(10, 0, getAssetDecimals(bId), 0, 0, DOWN)
302317 let sharePrecision = pow(10, 0, getAssetDecimals(shareId), 0, 0, DOWN)
303318 let sum = (fraction(aBalance, dPriceA, APrecision) + fraction(bBalance, dPriceB, BPrecision))
304319 fraction(sum, sharePrecision, shareSupply)
305320 }
306321
307322
308323 func getSharePrices (shareIds) = {
309324 func getPrices (a,shareId) = (a :+ getSharePrice(shareId))
310325
311326 let $l = shareIds
312327 let $s = size($l)
313328 let $acc0 = nil
314329 func $f0_1 ($a,$i) = if (($i >= $s))
315330 then $a
316331 else getPrices($a, $l[$i])
317332
318333 func $f0_2 ($a,$i) = if (($i >= $s))
319334 then $a
320335 else throw("List size exceeds 20")
321336
322337 $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20)
323338 }
324339
325340
326341 func getCursEntries (aId,bId,shareId) = {
327342 let assetsPrices = getAssetsPrice([aId, bId])
328343 let sharePrice = getSharePrice(shareId)
329344 let prices = [toString(assetsPrices[0]), toString(assetsPrices[1]), toString(sharePrice)]
330345 [StringEntry(kTokenLastPrice, makeString(prices, ","))]
331346 }
332347
333348
334349 func calcReplenishByTwoTokens (pType,poolAddr,pmtA,aId,pmtB,bId,balA,balB) = {
335- let $t096409945 = if ((pType == SF_POOL))
350+ let $t01010310408 = if ((pType == SF_POOL))
336351 then $Tuple2(nil, nil)
337352 else $Tuple2(split({
338353 let @ = invoke(poolAddr, "evaluatePutByAmountAssetREADONLY", [pmtA], nil)
339354 if ($isInstanceOf(@, "String"))
340355 then @
341356 else throw(($getType(@) + " couldn't be cast to String"))
342357 }, "__"), split({
343358 let @ = invoke(poolAddr, "evaluatePutByPriceAssetREADONLY", [pmtB], nil)
344359 if ($isInstanceOf(@, "String"))
345360 then @
346361 else throw(($getType(@) + " couldn't be cast to String"))
347362 }, "__"))
348- if (($t096409945 == $t096409945))
363+ if (($t01010310408 == $t01010310408))
349364 then {
350- let evalPutInB = $t096409945._2
351- let evalPutInA = $t096409945._1
352- let $t0995510151 = if ((pType == SF_POOL))
365+ let evalPutInB = $t01010310408._2
366+ let evalPutInA = $t01010310408._1
367+ let $t01041810614 = if ((pType == SF_POOL))
353368 then $Tuple2(fraction(SCALE8, pmtA, balA), fraction(SCALE8, pmtB, balB))
354369 else $Tuple2(parseIntValue(evalPutInA[1]), parseIntValue(evalPutInB[1]))
355- let ratioA = $t0995510151._1
356- let ratioB = $t0995510151._2
357- let $t01015710639 = if ((ratioB > ratioA))
370+ let ratioA = $t01041810614._1
371+ let ratioB = $t01041810614._2
372+ let $t01062011102 = if ((ratioB > ratioA))
358373 then {
359374 let pmt = if ((pType == SF_POOL))
360375 then fraction(balB, ratioA, SCALE8, CEILING)
361376 else parseIntValue(evalPutInA[8])
362377 $Tuple5(pmtA, pmt, (pmtB - pmt), bId, ratioB)
363378 }
364379 else {
365380 let pmt = if ((pType == SF_POOL))
366381 then fraction(balA, ratioB, SCALE8, CEILING)
367382 else parseIntValue(evalPutInB[7])
368383 $Tuple5(pmt, pmtB, (pmtA - pmt), aId, ratioA)
369384 }
370- let pmtInA = $t01015710639._1
371- let pmtInB = $t01015710639._2
372- let change = $t01015710639._3
373- let changeAssetId = $t01015710639._4
374- let lp = $t01015710639._5
385+ let pmtInA = $t01062011102._1
386+ let pmtInB = $t01062011102._2
387+ let change = $t01062011102._3
388+ let changeAssetId = $t01062011102._4
389+ let lp = $t01062011102._5
375390 $Tuple5(pmtInA, pmtInB, change, changeAssetId, lp)
376391 }
377392 else throw("Strict value is not equal to itself.")
378393 }
379394
380395
381396 func replenishTwoTokensByType (poolAddr,pType,pmtA,aId,pmtB,bId) = {
382397 let payments = [AttachedPayment(assetIdFromStr(aId), pmtA), AttachedPayment(assetIdFromStr(bId), pmtB)]
383398 if ((pType == SF_POOL))
384399 then invoke(poolAddr, "callFunction", ["replenishWithTwoTokens", ["false", "0"]], payments)
385400 else invoke(poolAddr, "put", [1000000, false], payments)
386401 }
387402
388403
389404 func replenishOneTokenByType (poolAddr,pType,pmt,pmtId) = {
390405 let payments = [AttachedPayment(assetIdFromStr(pmtId), pmt)]
391406 if ((pType == SF_POOL))
392407 then invoke(poolAddr, "callFunction", ["replenishWithOneToken", ["0", "false", "0"]], payments)
393408 else invoke(poolAddr, "putOneTkn", [0, false], payments)
394409 }
395410
396411
397412 func stakeLP (pool,pType,shareId,amount) = {
398413 let payments = [AttachedPayment(fromBase58String(shareId), amount)]
399414 if ((pType == SF_POOL))
400415 then invoke(getSFFarmingAddr(), "lockShareTokens", [pool, 0], payments)
401416 else invoke(getWXFarmingAddr(addressFromStringValue(pool)), "stake", nil, payments)
402417 }
403418
404419
405420 func unstakeLP (pool,pType,shareId,amount) = {
406- let $t01186912226 = if ((pType == SF_POOL))
421+ let $t01233212689 = if ((pType == SF_POOL))
407422 then $Tuple3(getSFFarmingAddr(), "withdrawShareTokens", [pool, amount])
408423 else if ((pType == WX_POOL))
409424 then $Tuple3(getWXFarmingAddr(Address(fromBase58String(pool))), "unstake", [shareId, amount])
410425 else throw("Wrong pool type")
411- let farmAddr = $t01186912226._1
412- let fName = $t01186912226._2
413- let params = $t01186912226._3
426+ let farmAddr = $t01233212689._1
427+ let fName = $t01233212689._2
428+ let params = $t01233212689._3
414429 let inv = invoke(farmAddr, fName, params, nil)
415430 if ((inv == inv))
416431 then amount
417432 else throw("Strict value is not equal to itself.")
418433 }
419434
420435
421436 func calcAmountToPaySF (pool,assetIdA,assetIdB,balA,balB,amountTokenToGet,assetTokenToGet) = {
422437 let poolAddr = Address(fromBase58String(pool))
423438 let feeScale6 = 1000000
424439 let fee = getIntegerValue(poolAddr, kSFPoolFee)
425440 let amntGetNoFee = fraction(amountTokenToGet, feeScale6, (feeScale6 - fee))
426- let $t01263912927 = if ((assetTokenToGet == assetIdA))
441+ let $t01310213390 = if ((assetTokenToGet == assetIdA))
427442 then {
428443 let amountToPay = fraction(balA, amntGetNoFee, (balB - amntGetNoFee))
429444 $Tuple2(amountToPay, assetIdB)
430445 }
431446 else {
432447 let amountToPay = fraction(balB, amntGetNoFee, (balA - amntGetNoFee))
433448 $Tuple2(amountToPay, assetIdA)
434449 }
435- let amountToPay = $t01263912927._1
436- let assetToPay = $t01263912927._2
450+ let amountToPay = $t01310213390._1
451+ let assetToPay = $t01310213390._2
437452 $Tuple2(assetToPay, amountToPay)
438453 }
439454
440455
441456 func calcAmountToPayWX (pool,assetIdA,assetIdB,balA,balB,amountTokenToGet,assetTokenToGet) = {
442457 let prFee = getIntegerValue(wxSwapContract, "%s__protocolFee")
443458 let pFee = getIntegerValue(wxSwapContract, "%s__poolFee")
444459 let feeScale = toBigInt(100000000)
445- let $t01326613574 = if ((assetTokenToGet == assetIdA))
460+ let $t01372914037 = if ((assetTokenToGet == assetIdA))
446461 then {
447462 let amountToPay = fraction(balA, amountTokenToGet, (balB - amountTokenToGet))
448463 $Tuple2(amountToPay, assetIdB)
449464 }
450465 else {
451466 let amountToPay = fraction(balB, amountTokenToGet, (balA - amountTokenToGet))
452467 $Tuple2(amountToPay, assetIdA)
453468 }
454- let amountToPay = $t01326613574._1
455- let assetToPay = $t01326613574._2
469+ let amountToPay = $t01372914037._1
470+ let assetToPay = $t01372914037._2
456471 let amountToPayWithFee = toInt(fraction(toBigInt(amountToPay), feeScale, (feeScale - toBigInt((prFee + pFee)))))
457472 $Tuple2(assetToPay, amountToPayWithFee)
458473 }
459474
460475
461476 func exchangeDirectly (type,pool,assetIdA,assetIdB,balA,balB,amountTokenToGet,assetTokenToGet) = if ((type == SF_POOL))
462477 then {
463- let $t01391214034 = calcAmountToPaySF(pool, assetIdA, assetIdB, balA, balB, amountTokenToGet, assetTokenToGet)
464- let assetToPay = $t01391214034._1
465- let amountToPay = $t01391214034._2
478+ let $t01437514497 = calcAmountToPaySF(pool, assetIdA, assetIdB, balA, balB, amountTokenToGet, assetTokenToGet)
479+ let assetToPay = $t01437514497._1
480+ let amountToPay = $t01437514497._2
466481 invoke(addressFromStringValue(pool), "callFunction", ["exchange", ["1"]], [AttachedPayment(assetIdFromStr(assetToPay), amountToPay)])
467482 }
468483 else {
469- let $t01418514307 = calcAmountToPayWX(pool, assetIdA, assetIdB, balA, balB, amountTokenToGet, assetTokenToGet)
470- let assetToPay = $t01418514307._1
471- let amountToPay = $t01418514307._2
484+ let $t01464814770 = calcAmountToPayWX(pool, assetIdA, assetIdB, balA, balB, amountTokenToGet, assetTokenToGet)
485+ let assetToPay = $t01464814770._1
486+ let amountToPay = $t01464814770._2
472487 invoke(wxSwapContract, "swap", [1, assetTokenToGet, toString(this)], [AttachedPayment(assetIdFromStr(assetToPay), amountToPay)])
473488 }
474489
475490
476491 func calcReplenishLPVirt (pType,pool,pmtA,aId,pmtB,bId,balA,balB) = {
477492 let poolAddr = addressFromStringValue(pool)
478493 if ((pType == SF_POOL))
479494 then {
480495 let inv = {
481496 let @ = invoke(poolAddr, "callFunction", ["calcLPReplenishDiffPropREADONLY", [toString(pmtA), toString(pmtB), "0"]], nil)
482497 if ($isInstanceOf(@, "List[Any]"))
483498 then @
484499 else throw(($getType(@) + " couldn't be cast to List[Any]"))
485500 }
486501 if ((inv == inv))
487- then {
502+ then $Tuple2({
488503 let @ = inv[0]
489504 if ($isInstanceOf(@, "Int"))
490505 then @
491506 else throw(($getType(@) + " couldn't be cast to Int"))
492- }
507+ }, {
508+ let @ = inv[1]
509+ if ($isInstanceOf(@, "Int"))
510+ then @
511+ else throw(($getType(@) + " couldn't be cast to Int"))
512+ })
493513 else throw("Strict value is not equal to itself.")
494514 }
495515 else if ((pType == WX_POOL))
496516 then {
497- let $t01487215213 = if (if ((pmtA > 0))
517+ let $t01535815699 = if (if ((pmtA > 0))
498518 then (pmtB > 0)
499519 else false)
500520 then {
501- let $t01495315079 = calcReplenishByTwoTokens(pType, poolAddr, pmtA, aId, pmtB, bId, balA, balB)
502- let pmtInA = $t01495315079._1
503- let pmtInB = $t01495315079._2
504- let change = $t01495315079._3
505- let changeId = $t01495315079._4
506- let lpAmount = $t01495315079._5
521+ let $t01543915565 = calcReplenishByTwoTokens(pType, poolAddr, pmtA, aId, pmtB, bId, balA, balB)
522+ let pmtInA = $t01543915565._1
523+ let pmtInB = $t01543915565._2
524+ let change = $t01543915565._3
525+ let changeId = $t01543915565._4
526+ let lpAmount = $t01543915565._5
507527 $Tuple3(change, changeId, lpAmount)
508528 }
509529 else if ((pmtA > 0))
510530 then $Tuple3(pmtA, aId, 0)
511531 else $Tuple3(pmtB, bId, 0)
512- let change = $t01487215213._1
513- let changeId = $t01487215213._2
514- let lpTwo = $t01487215213._3
515- let lpOne = if ((change > 0))
532+ let change = $t01535815699._1
533+ let changeId = $t01535815699._2
534+ let lpTwo = $t01535815699._3
535+ let $t01570615922 = if ((change > 0))
516536 then {
517537 let inv = {
518538 let @ = invoke(poolAddr, "putOneTknREADONLY", [changeId, change], nil)
519539 if ($isInstanceOf(@, "(Int, Int, Int)"))
520540 then @
521541 else throw(($getType(@) + " couldn't be cast to (Int, Int, Int)"))
522542 }
523543 if ((inv == inv))
524- then inv._1
544+ then $Tuple2(inv._1, inv._3)
525545 else throw("Strict value is not equal to itself.")
526546 }
527- else 0
528- (lpTwo + lpOne)
547+ else $Tuple2(0, 0)
548+ let lpOne = $t01570615922._1
549+ let loss = $t01570615922._2
550+ $Tuple2((lpTwo + lpOne), loss)
529551 }
530552 else throw("Wrong pool type")
531553 }
532554
533555
534556 func calcWithdrawLPVirt (pType,pool,lpAmount,shareId,aId,bId,balA,balB,borrowAmount,borrowAssetId) = {
535557 let poolAddr = addressFromStringValue(pool)
536- let $t01569916199 = if ((pType == SF_POOL))
558+ let $t01621616716 = if ((pType == SF_POOL))
537559 then {
538560 let inv = {
539561 let @ = invoke(poolAddr, "callFunction", ["withdrawREADONLY", [toString(lpAmount), toString(balA), toString(balB)]], nil)
540562 if ($isInstanceOf(@, "List[Any]"))
541563 then @
542564 else throw(($getType(@) + " couldn't be cast to List[Any]"))
543565 }
544566 if ((inv == inv))
545567 then $Tuple2({
546568 let @ = inv[0]
547569 if ($isInstanceOf(@, "Int"))
548570 then @
549571 else throw(($getType(@) + " couldn't be cast to Int"))
550572 }, {
551573 let @ = inv[1]
552574 if ($isInstanceOf(@, "Int"))
553575 then @
554576 else throw(($getType(@) + " couldn't be cast to Int"))
555577 })
556578 else throw("Strict value is not equal to itself.")
557579 }
558580 else if ((pType == WX_POOL))
559581 then {
560582 let get = split({
561583 let @ = invoke(poolAddr, "evaluateGetREADONLY", [shareId, lpAmount], nil)
562584 if ($isInstanceOf(@, "String"))
563585 then @
564586 else throw(($getType(@) + " couldn't be cast to String"))
565587 }, "__")
566588 if ((get == get))
567589 then $Tuple2(parseIntValue(get[1]), parseIntValue(get[2]))
568590 else throw("Strict value is not equal to itself.")
569591 }
570592 else throw("Wrong pool type")
571- let getAmountA = $t01569916199._1
572- let getAmountB = $t01569916199._2
593+ let getAmountA = $t01621616716._1
594+ let getAmountB = $t01621616716._2
573595 if ((borrowAmount > 0))
574596 then {
575597 let amountToGetEx = if (if ((borrowAssetId == aId))
576598 then (borrowAmount > getAmountA)
577599 else false)
578600 then (borrowAmount - getAmountA)
579601 else if (if ((borrowAssetId == bId))
580602 then (borrowAmount > getAmountB)
581603 else false)
582604 then (borrowAmount - getAmountB)
583605 else 0
584- let $t01650216817 = if ((amountToGetEx > 0))
606+ let $t01699417297 = if ((amountToGetEx > 0))
585607 then if ((pType == SF_POOL))
586608 then calcAmountToPaySF(pool, aId, bId, balA, balB, amountToGetEx, borrowAssetId)
587609 else calcAmountToPayWX(pool, aId, bId, balA, balB, amountToGetEx, borrowAssetId)
588610 else $Tuple2("", 0)
589- let assetToPay = $t01650216817._1
590- let amountToPay = $t01650216817._2
611+ let assetToPay = $t01699417297._1
612+ let amountToPay = $t01699417297._2
591613 if ((borrowAssetId == aId))
592614 then $Tuple2(((getAmountA + amountToGetEx) - borrowAmount), (getAmountB - amountToPay))
593615 else $Tuple2((getAmountA - amountToPay), ((getAmountB + amountToGetEx) - borrowAmount))
594616 }
595617 else $Tuple2(getAmountA, getAmountB)
596618 }
597619
598620
599621 func claimFarmed (type,pool) = if ((type == SF_POOL))
600622 then {
601623 let balBefore = accountBalance(SWOPID)
602624 if ((balBefore == balBefore))
603625 then {
604626 let inv = invoke(getSFFarmingAddr(), "claim", [pool], nil)
605627 if ((inv == inv))
606628 then {
607629 let balAfter = accountBalance(SWOPID)
608630 $Tuple2((balAfter - balBefore), SWOPID)
609631 }
610632 else throw("Strict value is not equal to itself.")
611633 }
612634 else throw("Strict value is not equal to itself.")
613635 }
614636 else if ((type == WX_POOL))
615637 then {
616638 let balBefore = accountBalance(WXID)
617639 if ((balBefore == balBefore))
618640 then {
619641 let inv = invoke(getWXFarmingAddr(Address(fromBase58String(pool))), "claimWX", [pool], nil)
620642 if ((inv == inv))
621643 then {
622644 let balAfter = accountBalance(WXID)
623645 $Tuple2((balAfter - balBefore), WXID)
624646 }
625647 else throw("Strict value is not equal to itself.")
626648 }
627649 else throw("Strict value is not equal to itself.")
628650 }
629651 else throw("Wrong pool type")
630652
631653
632654 func replenishByType (pType,pool,feeType,pmtA,aId,pmtB,bId,balA,balB,LPId) = {
633655 let lpBalanceBefore = accountBalance(fromBase58String(LPId))
634656 if ((lpBalanceBefore == lpBalanceBefore))
635657 then {
636658 let poolAddr = addressFromStringValue(pool)
637- let $t01802618442 = if (if ((pmtA > 0))
659+ let $t01849418910 = if (if ((pmtA > 0))
638660 then (pmtB > 0)
639661 else false)
640662 then {
641- let $t01809218208 = calcReplenishByTwoTokens(pType, poolAddr, pmtA, aId, pmtB, bId, balA, balB)
642- let pmtInA = $t01809218208._1
643- let pmtInB = $t01809218208._2
644- let change = $t01809218208._3
645- let changeId = $t01809218208._4
663+ let $t01856018676 = calcReplenishByTwoTokens(pType, poolAddr, pmtA, aId, pmtB, bId, balA, balB)
664+ let pmtInA = $t01856018676._1
665+ let pmtInB = $t01856018676._2
666+ let change = $t01856018676._3
667+ let changeId = $t01856018676._4
646668 let inv = replenishTwoTokensByType(poolAddr, pType, pmtInA, aId, pmtInB, bId)
647669 if ((inv == inv))
648670 then $Tuple2(change, changeId)
649671 else throw("Strict value is not equal to itself.")
650672 }
651673 else if ((pmtA > 0))
652674 then $Tuple2(pmtA, aId)
653675 else if ((pmtB > 0))
654676 then $Tuple2(pmtB, bId)
655677 else throw("pmts must be > 0")
656- let change = $t01802618442._1
657- let changeId = $t01802618442._2
678+ let change = $t01849418910._1
679+ let changeId = $t01849418910._2
658680 let inv = if ((change > 0))
659681 then replenishOneTokenByType(poolAddr, pType, change, changeId)
660682 else nil
661683 if ((inv == inv))
662684 then {
663685 let lpBalanceAfter = accountBalance(fromBase58String(LPId))
664686 let totalStaked = (lpBalanceAfter - lpBalanceBefore)
665687 let axlyFeeAmount = fraction(totalStaked, getAxlyFee(pool, feeType), FEE_SCALE6)
666688 let userShareForStake = (totalStaked - axlyFeeAmount)
667689 if ((0 >= userShareForStake))
668690 then throw("amount of staked sharetokens must be > 0")
669691 else {
670692 let invLP = stakeLP(pool, pType, LPId, userShareForStake)
671693 if ((invLP == invLP))
672694 then $Tuple2(userShareForStake, axlyFeeAmount)
673695 else throw("Strict value is not equal to itself.")
674696 }
675697 }
676698 else throw("Strict value is not equal to itself.")
677699 }
678700 else throw("Strict value is not equal to itself.")
679701 }
680702
681703
682704 func replenishEntries (pool,user,stakedAmount,axlyFeeAmount,posNum,shareId,type,withLoan) = {
683705 let totalAmount = getPoolTotalShare(pool)
684706 let totalAmountLoan = getPoolTotalShareWithLoan(pool)
685- let $t01930019538 = if (withLoan)
707+ let $t01976820006 = if (withLoan)
686708 then $Tuple2(getIntegerValue(this, (pool + kPoolInterestLoan)), (totalAmountLoan + stakedAmount))
687709 else $Tuple2(getIntegerValue(this, (pool + kPoolInterestNoLoan)), totalAmountLoan)
688- let curPoolInterest = $t01930019538._1
689- let totalStakedWithLoan = $t01930019538._2
710+ let curPoolInterest = $t01976820006._1
711+ let totalStakedWithLoan = $t01976820006._2
690712 [IntegerEntry((pool + kPoolTotal), (totalAmount + stakedAmount)), IntegerEntry((pool + kPoolTotalLoan), totalStakedWithLoan), IntegerEntry((((((pool + "_") + user) + "_") + toString(posNum)) + kUserPosition), stakedAmount), IntegerEntry((((((pool + "_") + user) + "_") + toString(posNum)) + kUserPositionInterest), curPoolInterest), StringEntry((((user + "_") + toString(posNum)) + kUserPositionPool), pool), IntegerEntry((user + kUserPositionNum), posNum), ScriptTransfer(moneyBox, axlyFeeAmount, fromBase58String(shareId))]
691713 }
692714
693715
694716 func exchangeKeeper (toToken,pmtAmount,pmtAsset,amountsIn,addresses,assetsToReceive,estReceived,slippageTolerance,minReceived,options) = {
695717 let tokenBalanceBefore = accountBalance(assetIdFromStr(toToken))
696718 if ((tokenBalanceBefore == tokenBalanceBefore))
697719 then {
698720 let inv = invoke(exContract, "swap", [amountsIn, addresses, assetsToReceive, estReceived, slippageTolerance, minReceived, options], [AttachedPayment(pmtAsset, pmtAmount)])
699721 if ((inv == inv))
700722 then (accountBalance(assetIdFromStr(toToken)) - tokenBalanceBefore)
701723 else throw("Strict value is not equal to itself.")
702724 }
703725 else throw("Strict value is not equal to itself.")
704726 }
705727
706728
707729 func exchangePuzzle (toToken,pmtAmount,pmtAsset,routesStr,minToReceive,options) = {
708730 let tokenBalanceBefore = accountBalance(assetIdFromStr(toToken))
709731 if ((tokenBalanceBefore == tokenBalanceBefore))
710732 then {
711733 let inv = invoke(exContract, "puzzleSwap", [routesStr, minToReceive, options], [AttachedPayment(pmtAsset, pmtAmount)])
712734 if ((inv == inv))
713735 then (accountBalance(assetIdFromStr(toToken)) - tokenBalanceBefore)
714736 else throw("Strict value is not equal to itself.")
715737 }
716738 else throw("Strict value is not equal to itself.")
717739 }
718740
719741
720742 func exchangeSwopFi (toToken,pmtAmount,pmtAsset,exchangers,exchangersType,args1,args2,routingAssetsKeys,minAmountToReceive,options) = {
721743 let tokenBalanceBefore = accountBalance(assetIdFromStr(toToken))
722744 if ((tokenBalanceBefore == tokenBalanceBefore))
723745 then {
724746 let inv = invoke(exContract, "swopfiSwap", [exchangers, exchangersType, args1, args2, routingAssetsKeys, minAmountToReceive, options], [AttachedPayment(pmtAsset, pmtAmount)])
725747 if ((inv == inv))
726748 then (accountBalance(assetIdFromStr(toToken)) - tokenBalanceBefore)
727749 else throw("Strict value is not equal to itself.")
728750 }
729751 else throw("Strict value is not equal to itself.")
730752 }
731753
732754
733755 func capitalize (pool,pType,tokenId,tokenAmount) = {
734756 let poolAddr = Address(fromBase58String(pool))
735- let $t02188921955 = getPoolData(poolAddr, pType)
736- let AId = $t02188921955._1
737- let BId = $t02188921955._2
738- let balA = $t02188921955._3
739- let balB = $t02188921955._4
740- let shareId = $t02188921955._5
757+ let $t02235722423 = getPoolData(poolAddr, pType)
758+ let AId = $t02235722423._1
759+ let BId = $t02235722423._2
760+ let balA = $t02235722423._3
761+ let balB = $t02235722423._4
762+ let shareId = $t02235722423._5
741763 if (if ((tokenId != AId))
742764 then (tokenId != BId)
743765 else false)
744766 then throw("Wrong asset")
745767 else {
746- let $t02204022120 = if ((tokenId == AId))
768+ let $t02250822588 = if ((tokenId == AId))
747769 then $Tuple2(tokenAmount, 0)
748770 else $Tuple2(0, tokenAmount)
749- let pmtA = $t02204022120._1
750- let pmtB = $t02204022120._2
751- let $t02212322227 = replenishByType(pType, pool, NO_FEE, pmtA, AId, pmtB, BId, balA, balB, shareId)
752- let stakedAmount = $t02212322227._1
753- let nf = $t02212322227._2
771+ let pmtA = $t02250822588._1
772+ let pmtB = $t02250822588._2
773+ let $t02259122695 = replenishByType(pType, pool, NO_FEE, pmtA, AId, pmtB, BId, balA, balB, shareId)
774+ let stakedAmount = $t02259122695._1
775+ let nf = $t02259122695._2
754776 let curPoolInterestLoan = valueOrElse(getInteger(this, (pool + kPoolInterestLoan)), 0)
755777 let curPoolInterestNoLoan = valueOrElse(getInteger(this, (pool + kPoolInterestNoLoan)), 0)
756778 let totalShareAmount = getPoolTotalShare(pool)
757779 let totalShareAmountWithLoan = getPoolTotalShareWithLoan(pool)
758780 let loanPercent = fraction(totalShareAmountWithLoan, SCALE8, totalShareAmount)
759781 let stakedLoan = fraction(stakedAmount, loanPercent, SCALE8)
760782 let stakedNoLoan = (stakedAmount - stakedLoan)
761783 let newInterestLoan = if ((totalShareAmountWithLoan > 0))
762784 then (curPoolInterestLoan + fraction(stakedLoan, SCALE10, totalShareAmountWithLoan))
763785 else 0
764786 let newInterestNoLoan = if (((totalShareAmount - totalShareAmountWithLoan) > 0))
765787 then (curPoolInterestNoLoan + fraction(stakedNoLoan, SCALE10, (totalShareAmount - totalShareAmountWithLoan)))
766788 else 0
767789 let axlyFeeLoan = fraction(stakedLoan, getAxlyFee(pool, CAP_FEE_LOAN), FEE_SCALE6)
768790 let axlyFeeNoLoan = fraction(stakedNoLoan, getAxlyFee(pool, CAP_FEE_NO_LOAN), FEE_SCALE6)
769791 let axlyFee = unstakeLP(pool, pType, shareId, (axlyFeeLoan + axlyFeeNoLoan))
770792 if ((axlyFee == axlyFee))
771793 then ([IntegerEntry((pool + kPoolInterestLoan), newInterestLoan), IntegerEntry((pool + kPoolInterestNoLoan), newInterestNoLoan), IntegerEntry((pool + kPoolTotal), ((totalShareAmount + stakedAmount) - axlyFee)), IntegerEntry((pool + kPoolTotalLoan), ((totalShareAmountWithLoan + stakedLoan) - axlyFeeLoan)), ScriptTransfer(moneyBox, (axlyFeeLoan + axlyFeeNoLoan), fromBase58String(shareId))] ++ getCursEntries(AId, BId, shareId))
772794 else throw("Strict value is not equal to itself.")
773795 }
774796 }
775797
776798
777799 func withdrawAmountCalc (pool,userCanWithdraw,debt,borrowAsset) = {
778800 let poolAddr = Address(fromBase58String(pool))
779801 let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Unknown pool")
780- let $t02399524071 = getPoolData(poolAddr, pType)
781- let assetIdA = $t02399524071._1
782- let assetIdB = $t02399524071._2
783- let balA = $t02399524071._3
784- let balB = $t02399524071._4
785- let shareId = $t02399524071._5
802+ let $t02446324539 = getPoolData(poolAddr, pType)
803+ let assetIdA = $t02446324539._1
804+ let assetIdB = $t02446324539._2
805+ let balA = $t02446324539._3
806+ let balB = $t02446324539._4
807+ let shareId = $t02446324539._5
786808 let cBalABefore = accountBalance(assetIdFromStr(assetIdA))
787809 if ((cBalABefore == cBalABefore))
788810 then {
789811 let cBalBBefore = accountBalance(assetIdFromStr(assetIdB))
790812 if ((cBalBBefore == cBalBBefore))
791813 then {
792814 let inv = if ((pType == SF_POOL))
793815 then invoke(poolAddr, "callFunction", ["withdraw", [toString(userCanWithdraw)]], nil)
794816 else {
795817 let inv = unstakeLP(pool, pType, shareId, userCanWithdraw)
796818 if ((inv == inv))
797819 then invoke(poolAddr, "get", nil, [AttachedPayment(assetIdFromStr(shareId), userCanWithdraw)])
798820 else throw("Strict value is not equal to itself.")
799821 }
800822 if ((inv == inv))
801823 then {
802824 let cBalAAfter = accountBalance(assetIdFromStr(assetIdA))
803825 let cBalBAfter = accountBalance(assetIdFromStr(assetIdB))
804- let $t02463424723 = $Tuple2((cBalAAfter - cBalABefore), (cBalBAfter - cBalBBefore))
805- let tokensAmountA = $t02463424723._1
806- let tokensAmountB = $t02463424723._2
807- let $t02472625422 = if ((debt > 0))
826+ let $t02510225191 = $Tuple2((cBalAAfter - cBalABefore), (cBalBAfter - cBalBBefore))
827+ let tokensAmountA = $t02510225191._1
828+ let tokensAmountB = $t02510225191._2
829+ let $t02519425890 = if ((debt > 0))
808830 then {
809831 let amountToGetEx = if (if ((borrowAsset == assetIdA))
810832 then (debt > tokensAmountA)
811833 else false)
812834 then (debt - tokensAmountA)
813835 else if (if ((borrowAsset == assetIdB))
814836 then (debt > tokensAmountB)
815837 else false)
816838 then (debt - tokensAmountB)
817839 else 0
818840 let exInv = if ((amountToGetEx > 0))
819841 then exchangeDirectly(pType, pool, assetIdA, assetIdB, balA, balB, amountToGetEx, borrowAsset)
820842 else 0
821843 if ((exInv == exInv))
822844 then {
823845 let cBalAAfterRepay = accountBalance(assetIdFromStr(assetIdA))
824846 let cBalBAfterRepay = accountBalance(assetIdFromStr(assetIdB))
825847 $Tuple2((cBalAAfterRepay - cBalABefore), (cBalBAfterRepay - cBalBBefore))
826848 }
827849 else throw("Strict value is not equal to itself.")
828850 }
829851 else $Tuple2(tokensAmountA, tokensAmountB)
830- let toUserAmountA = $t02472625422._1
831- let toUserAmountB = $t02472625422._2
852+ let toUserAmountA = $t02519425890._1
853+ let toUserAmountB = $t02519425890._2
832854 $Tuple7(toUserAmountA, assetIdA, toUserAmountB, assetIdB, cBalAAfter, cBalBAfter, shareId)
833855 }
834856 else throw("Strict value is not equal to itself.")
835857 }
836858 else throw("Strict value is not equal to itself.")
837859 }
838860 else throw("Strict value is not equal to itself.")
839861 }
840862
841863
842864 func userCanWithdrawShareCalc (user,pool,posId,borrowed) = {
843865 let pAmount = valueOrErrorMessage(getInteger(this, (((((pool + "_") + user) + "_") + posId) + kUserPosition)), "Unknown position")
844866 let userInterest = getIntegerValue(this, (((((pool + "_") + user) + "_") + posId) + kUserPositionInterest))
845867 let poolInterest = if (borrowed)
846868 then getIntegerValue(this, (pool + kPoolInterestLoan))
847869 else getIntegerValue(this, (pool + kPoolInterestNoLoan))
848870 (pAmount + fraction(pAmount, (poolInterest - userInterest), SCALE10))
849871 }
850872
851873
852874 func withdrawToUser (user,pool,posId,stopLoss) = {
853875 let pAmount = valueOrErrorMessage(getInteger(this, (((((pool + "_") + user) + "_") + posId) + kUserPosition)), "Unknown position")
854876 let userInterest = getIntegerValue(this, (((((pool + "_") + user) + "_") + posId) + kUserPositionInterest))
855877 let borrowAmount = valueOrElse(getInteger(this, (((((pool + "_") + user) + "_") + posId) + kUserBorrowAmount)), 0)
856878 let userCanWithdraw = userCanWithdrawShareCalc(user, pool, posId, (borrowAmount > 0))
857879 let poolTotalShare = getPoolTotalShare(pool)
858880 let userAddr = Address(fromBase58String(user))
859881 let borrowAsset = valueOrElse(getString(this, (((((pool + "_") + user) + "_") + posId) + kUserBorrowAssetId)), "")
860882 let debt = if ((borrowAmount > 0))
861883 then {
862884 let @ = invoke(getLendSrvAddr(), "getAssetDebt", [false, ((user + "_") + posId), borrowAsset], nil)
863885 if ($isInstanceOf(@, "Int"))
864886 then @
865887 else throw(($getType(@) + " couldn't be cast to Int"))
866888 }
867889 else 0
868- let $t02692127074 = withdrawAmountCalc(pool, userCanWithdraw, debt, borrowAsset)
869- if (($t02692127074 == $t02692127074))
890+ let $t02738927542 = withdrawAmountCalc(pool, userCanWithdraw, debt, borrowAsset)
891+ if (($t02738927542 == $t02738927542))
870892 then {
871- let shareId = $t02692127074._7
872- let cBalBAfter = $t02692127074._6
873- let cBalAAfter = $t02692127074._5
874- let assetIdB = $t02692127074._4
875- let toUserAmountB = $t02692127074._3
876- let assetIdA = $t02692127074._2
877- let toUserAmountA = $t02692127074._1
893+ let shareId = $t02738927542._7
894+ let cBalBAfter = $t02738927542._6
895+ let cBalAAfter = $t02738927542._5
896+ let assetIdB = $t02738927542._4
897+ let toUserAmountB = $t02738927542._3
898+ let assetIdA = $t02738927542._2
899+ let toUserAmountA = $t02738927542._1
878900 let closeDbtInv = if ((debt > 0))
879901 then invoke(getLendSrvAddr(), "repayFor", [((user + "_") + posId)], [AttachedPayment(assetIdFromStr(borrowAsset), debt)])
880902 else 0
881903 if ((closeDbtInv == closeDbtInv))
882904 then ([DeleteEntry((((((pool + "_") + user) + "_") + posId) + kUserPosition)), DeleteEntry((((((pool + "_") + user) + "_") + posId) + kUserPositionInterest)), IntegerEntry((pool + kPoolTotal), (poolTotalShare - userCanWithdraw)), ScriptTransfer(userAddr, toUserAmountA, assetIdFromStr(assetIdA)), ScriptTransfer(userAddr, toUserAmountB, assetIdFromStr(assetIdB))] ++ getCursEntries(assetIdA, assetIdB, shareId))
883905 else throw("Strict value is not equal to itself.")
884906 }
885907 else throw("Strict value is not equal to itself.")
886908 }
887909
888910
889911 func parseRequest (requestId) = {
890912 let request = split(valueOrErrorMessage(getString(this, (requestId + kRequestId)), ("No request with id " + requestId)), ",")
891913 let user = request[0]
892914 let pool = request[1]
893915 let pmtA = parseIntValue(request[2])
894916 let AId = request[3]
895917 let pmtB = parseIntValue(request[4])
896918 let BId = request[5]
897919 let balA = parseIntValue(request[6])
898920 let balB = parseIntValue(request[7])
899921 let shareId = request[8]
900922 let bwAsset = request[9]
901923 let bwAmount = parseIntValue(request[10])
902924 $Tuple11(user, pool, pmtA, AId, pmtB, BId, balA, balB, shareId, bwAsset, bwAmount)
903925 }
904926
905927
906928 func calcBorrowAmount (pmtA,pmtB,aId,bId,leverage,borrowId) = {
907929 let dPriceA = ( let @ = invoke(priceOracleAddr, "getTWAP60", [aId, false], nil)
908930 if ($isInstanceOf(@, "(Int, Int)"))
909931 then @
910932 else throw(($getType(@) + " couldn't be cast to (Int, Int)")))._2
911933 let dPriceB = ( let @ = invoke(priceOracleAddr, "getTWAP60", [bId, false], nil)
912934 if ($isInstanceOf(@, "(Int, Int)"))
913935 then @
914936 else throw(($getType(@) + " couldn't be cast to (Int, Int)")))._2
915937 let decPrA = pow(10, 0, getAssetDecimals(aId), 0, 0, DOWN)
916938 let decPrB = pow(10, 0, getAssetDecimals(bId), 0, 0, DOWN)
917939 let paydInDollar = (fraction(dPriceA, pmtA, decPrA) + fraction(dPriceB, pmtB, decPrB))
918- let $t02876028857 = if ((borrowId == aId))
940+ let $t02922829325 = if ((borrowId == aId))
919941 then $Tuple2(dPriceA, decPrA)
920942 else $Tuple2(dPriceB, decPrB)
921- let borrowPrice = $t02876028857._1
922- let borrowDecPr = $t02876028857._2
943+ let borrowPrice = $t02922829325._1
944+ let borrowDecPr = $t02922829325._2
923945 fraction(fraction(paydInDollar, (leverage - 100), 100), borrowDecPr, borrowPrice)
924946 }
925947
926948
927949 @Callable(i)
928950 func calcPriceImpactEVALONLY (pool,leverage,borrowId,pmtA,pmtB) = if (if ((100 > leverage))
929951 then true
930952 else (leverage > 300))
931953 then throw("Leverage can't be <100 and >300")
932954 else {
933955 let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited")
934- let $t02927529365 = getPoolData(Address(fromBase58String(pool)), pType)
935- let AId = $t02927529365._1
936- let BId = $t02927529365._2
937- let balA = $t02927529365._3
938- let balB = $t02927529365._4
939- let shareId = $t02927529365._5
956+ let $t02974329833 = getPoolData(Address(fromBase58String(pool)), pType)
957+ let AId = $t02974329833._1
958+ let BId = $t02974329833._2
959+ let balA = $t02974329833._3
960+ let balB = $t02974329833._4
961+ let shareId = $t02974329833._5
940962 let borrowAmount = if ((leverage > 100))
941963 then calcBorrowAmount(pmtA, pmtB, AId, BId, leverage, borrowId)
942964 else 0
943- let $t02950029607 = if ((borrowId == AId))
965+ let $t02996830075 = if ((borrowId == AId))
944966 then $Tuple2((pmtA + borrowAmount), pmtB)
945967 else $Tuple2(pmtA, (pmtB + borrowAmount))
946- let payInA = $t02950029607._1
947- let payInB = $t02950029607._2
948- let lpAmount = calcReplenishLPVirt(pType, pool, payInA, AId, payInB, BId, balA, balB)
949- let newBalA = (balA + payInA)
950- let newBalB = (balB + payInB)
951- let $t02976429900 = calcWithdrawLPVirt(pType, pool, lpAmount, shareId, AId, BId, newBalA, newBalB, borrowAmount, borrowId)
952- if (($t02976429900 == $t02976429900))
953- then {
954- let amountGetB = $t02976429900._2
955- let amountGetA = $t02976429900._1
956- let ratioBefore = fraction(balB, SCALE8, balA)
957- let ratioAfter = fraction((newBalB - amountGetB), SCALE8, (newBalA - amountGetA))
958- let impact = (SCALE8 - fraction(ratioBefore, SCALE8, ratioAfter))
959- let impactMod = if ((0 > impact))
960- then (impact * -1)
961- else impact
962- $Tuple2(nil, [impactMod])
963- }
964- else throw("Strict value is not equal to itself.")
968+ let payInA = $t02996830075._1
969+ let payInB = $t02996830075._2
970+ let $t03007830171 = calcReplenishLPVirt(pType, pool, payInA, AId, payInB, BId, balA, balB)
971+ let lpAmount = $t03007830171._1
972+ let loss = $t03007830171._2
973+ let impactMod = if ((0 > loss))
974+ then (loss * -1)
975+ else loss
976+ $Tuple2(nil, [impactMod])
965977 }
966978
967979
968980
969981 @Callable(i)
970982 func getShareAssetPriceREADONLY (shareId) = {
971983 let sharePrices = getSharePrice(shareId)
972984 $Tuple2(nil, sharePrices)
973985 }
974986
975987
976988
977989 @Callable(i)
978990 func getUserPositionShareAmountREADONLY (user,posNum) = {
979991 let pool = valueOrErrorMessage(getString(this, (((user + "_") + posNum) + kUserPositionPool)), "Unknown position")
980992 let borrowAmount = getIntegerValue(this, (((((pool + "_") + user) + "_") + posNum) + kUserBorrowAmount))
981993 let userCanWithdraw = userCanWithdrawShareCalc(user, pool, posNum, (borrowAmount > 0))
982994 $Tuple2(nil, userCanWithdraw)
983995 }
984996
985997
986998
987999 @Callable(i)
9881000 func getUserPositionInDollarsREADONLY (user,pools,posNum) = {
9891001 func userPos (a,pool) = {
990- let $t03091430948 = a
991- let totalPos = $t03091430948._1
992- let posDebt = $t03091430948._2
993- let index = $t03091430948._3
1002+ let $t03098431018 = a
1003+ let totalPos = $t03098431018._1
1004+ let posDebt = $t03098431018._2
1005+ let index = $t03098431018._3
9941006 let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited")
995- let $t03104031130 = getPoolData(Address(fromBase58String(pool)), pType)
996- let AId = $t03104031130._1
997- let BId = $t03104031130._2
998- let balA = $t03104031130._3
999- let balB = $t03104031130._4
1000- let shareId = $t03104031130._5
1007+ let $t03111031200 = getPoolData(Address(fromBase58String(pool)), pType)
1008+ let AId = $t03111031200._1
1009+ let BId = $t03111031200._2
1010+ let balA = $t03111031200._3
1011+ let balB = $t03111031200._4
1012+ let shareId = $t03111031200._5
10011013 let borrowAmount = valueOrElse(getInteger(this, (((((pool + "_") + user) + "_") + posNum[index]) + kUserBorrowAmount)), 0)
10021014 let userCanWithdraw = userCanWithdrawShareCalc(user, pool, posNum[index], (borrowAmount > 0))
10031015 let sharePrices = getSharePrice(shareId)
10041016 let decPrShare = pow(10, 0, getAssetDecimals(shareId), 0, 0, DOWN)
10051017 let shareD = fraction(userCanWithdraw, sharePrices, decPrShare)
10061018 if ((borrowAmount == 0))
10071019 then $Tuple3((totalPos :+ shareD), (posDebt :+ 0), (index + 1))
10081020 else {
10091021 let borrowAsset = getStringValue(this, (((((pool + "_") + user) + "_") + posNum[index]) + kUserBorrowAssetId))
10101022 let debt = {
10111023 let @ = invoke(getLendSrvAddr(), "getAssetDebt", [false, ((user + "_") + posNum[index]), borrowAsset], nil)
10121024 if ($isInstanceOf(@, "Int"))
10131025 then @
10141026 else throw(($getType(@) + " couldn't be cast to Int"))
10151027 }
10161028 let borrowAssetPrice = ( let @ = invoke(priceOracleAddr, "getTWAP60", [borrowAsset, false], nil)
10171029 if ($isInstanceOf(@, "(Int, Int)"))
10181030 then @
10191031 else throw(($getType(@) + " couldn't be cast to (Int, Int)")))._1
10201032 let decPrBorrowId = pow(10, 0, getAssetDecimals(borrowAsset), 0, 0, DOWN)
10211033 let debtD = fraction(debt, borrowAssetPrice, decPrBorrowId)
10221034 $Tuple3((totalPos :+ shareD), (posDebt :+ debtD), (index + 1))
10231035 }
10241036 }
10251037
1026- let $t03217332228 = {
1038+ let $t03224332298 = {
10271039 let $l = pools
10281040 let $s = size($l)
10291041 let $acc0 = $Tuple3(nil, nil, 0)
10301042 func $f0_1 ($a,$i) = if (($i >= $s))
10311043 then $a
10321044 else userPos($a, $l[$i])
10331045
10341046 func $f0_2 ($a,$i) = if (($i >= $s))
10351047 then $a
10361048 else throw("List size exceeds 20")
10371049
10381050 $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18), 19), 20)
10391051 }
1040- let pos = $t03217332228._1
1041- let debt = $t03217332228._2
1052+ let pos = $t03224332298._1
1053+ let debt = $t03224332298._2
10421054 $Tuple2(nil, $Tuple2(pos, debt))
10431055 }
10441056
10451057
10461058
10471059 @Callable(i)
10481060 func replenish (pool,leverage,borrowId) = if (if ((100 > leverage))
10491061 then true
10501062 else (leverage > 300))
10511063 then throw("Leverage can't be <100 and >300")
10521064 else {
10531065 let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited")
1054- let $t03255132641 = getPoolData(Address(fromBase58String(pool)), pType)
1055- let AId = $t03255132641._1
1056- let BId = $t03255132641._2
1057- let balA = $t03255132641._3
1058- let balB = $t03255132641._4
1059- let shareId = $t03255132641._5
1060- let $t03264433281 = if ((size(i.payments) == 2))
1066+ let $t03262132711 = getPoolData(Address(fromBase58String(pool)), pType)
1067+ let AId = $t03262132711._1
1068+ let BId = $t03262132711._2
1069+ let balA = $t03262132711._3
1070+ let balB = $t03262132711._4
1071+ let shareId = $t03262132711._5
1072+ let $t03271433351 = if ((size(i.payments) == 2))
10611073 then if ((assetIdToStr(i.payments[0].assetId) != AId))
10621074 then throw("Wrong payment asset A")
10631075 else if ((assetIdToStr(i.payments[1].assetId) != BId))
10641076 then throw("Wrong payment asset B")
10651077 else $Tuple4(i.payments[0].amount, AId, i.payments[1].amount, BId)
10661078 else if ((size(i.payments) == 1))
10671079 then if ((assetIdToStr(i.payments[0].assetId) == AId))
10681080 then $Tuple4(i.payments[0].amount, AId, 0, BId)
10691081 else if ((assetIdToStr(i.payments[0].assetId) == BId))
10701082 then $Tuple4(0, AId, i.payments[0].amount, BId)
10711083 else throw("Wrong payment")
10721084 else throw("One or two payments expected")
1073- let pmtA = $t03264433281._1
1074- let pmtAssetA = $t03264433281._2
1075- let pmtB = $t03264433281._3
1076- let pmtAssetB = $t03264433281._4
1085+ let pmtA = $t03271433351._1
1086+ let pmtAssetA = $t03271433351._2
1087+ let pmtB = $t03271433351._3
1088+ let pmtAssetB = $t03271433351._4
10771089 let newPosNum = getNewUserPositionNumber(toString(i.caller))
10781090 if ((leverage > 100))
10791091 then {
10801092 let borrowAmount = calcBorrowAmount(pmtA, pmtB, pmtAssetA, pmtAssetB, leverage, borrowId)
10811093 let request = makeString([toString(i.caller), pool, toString(pmtA), pmtAssetA, toString(pmtB), pmtAssetB, toString(balA), toString(balB), shareId, borrowId, toString(borrowAmount)], ",")
10821094 let newRequestId = {
10831095 let @ = invoke(this, "createNewRequest", [request], nil)
10841096 if ($isInstanceOf(@, "Int"))
10851097 then @
10861098 else throw(($getType(@) + " couldn't be cast to Int"))
10871099 }
10881100 if ((newRequestId == newRequestId))
10891101 then {
10901102 let args = [((toString(i.caller) + "_") + toString(newPosNum)), shareId, borrowId, borrowAmount, toString(this), "replenishFromLand", toString(valueOrErrorMessage(newRequestId, "Can't create new request"))]
10911103 let inv = reentrantInvoke(getLendSrvAddr(), "flashPosition", args, nil)
10921104 if ((inv == inv))
10931105 then nil
10941106 else throw("Strict value is not equal to itself.")
10951107 }
10961108 else throw("Strict value is not equal to itself.")
10971109 }
10981110 else {
1099- let $t03420934321 = replenishByType(pType, pool, NO_LOAN_FEE, pmtA, AId, pmtB, BId, balA, balB, shareId)
1100- let userStaked = $t03420934321._1
1101- let axlyFee = $t03420934321._2
1111+ let $t03427934391 = replenishByType(pType, pool, NO_LOAN_FEE, pmtA, AId, pmtB, BId, balA, balB, shareId)
1112+ let userStaked = $t03427934391._1
1113+ let axlyFee = $t03427934391._2
11021114 (replenishEntries(pool, toString(i.caller), userStaked, axlyFee, newPosNum, shareId, pType, false) ++ getCursEntries(AId, BId, shareId))
11031115 }
11041116 }
1105-
1106-
1107-
1108-@Callable(i)
1109-func replenishFromLand (requestId) = {
1110- let $t03453234636 = parseRequest(requestId)
1111- let user = $t03453234636._1
1112- let pool = $t03453234636._2
1113- let pmtA = $t03453234636._3
1114- let AId = $t03453234636._4
1115- let pmtB = $t03453234636._5
1116- let BId = $t03453234636._6
1117- let balA = $t03453234636._7
1118- let balB = $t03453234636._8
1119- let shareId = $t03453234636._9
1120- let bwAsset = $t03453234636._10
1121- let bwAmount = $t03453234636._11
1122- if ((size(i.payments) != 1))
1123- then throw("Wrong payment size")
1124- else if (if ((assetIdToStr(i.payments[0].assetId) != bwAsset))
1125- then true
1126- else (i.payments[0].amount != bwAmount))
1127- then throw("Wrong payment")
1128- else {
1129- let $t03482634950 = if ((AId == bwAsset))
1130- then $Tuple2((pmtA + i.payments[0].amount), pmtB)
1131- else $Tuple2(pmtA, (pmtB + i.payments[0].amount))
1132- let pmtAllA = $t03482634950._1
1133- let pmtAllB = $t03482634950._2
1134- let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Unknown pool")
1135- let $t03503235141 = replenishByType(pType, pool, LOAN_FEE, pmtA, AId, pmtB, BId, balA, balB, shareId)
1136- let userStaked = $t03503235141._1
1137- let axlyFee = $t03503235141._2
1138- let posNum = getNewUserPositionNumber(user)
1139- let borrowEntries = [IntegerEntry((((((pool + "_") + user) + "_") + toString(posNum)) + kUserBorrowAmount), bwAmount), StringEntry((((((pool + "_") + user) + "_") + toString(posNum)) + kUserBorrowAssetId), bwAsset)]
1140- let entries = replenishEntries(pool, user, userStaked, axlyFee, posNum, shareId, pType, true)
1141- $Tuple2((((entries ++ getCursEntries(AId, BId, shareId)) ++ borrowEntries) :+ DeleteEntry((requestId + kRequestId))), userStaked)
1142- }
1143- }
11441117
11451118
11461119
11471120 @Callable(i)
11481121 func withdraw (pool,posId) = withdrawToUser(toString(i.caller), pool, toString(posId), false)
11491122
11501123
11511124
11521125 @Callable(i)
11531126 func createUpdateStopLoss (posId,poolId,assetId,price) = {
11541127 let tokenOraclePrice = ( let @ = invoke(priceOracleAddr, "getTWAP60", [assetId, false], nil)
11551128 if ($isInstanceOf(@, "(Int, Int)"))
11561129 then @
11571130 else throw(($getType(@) + " couldn't be cast to (Int, Int)")))._1
11581131 if (!(isDefined(getInteger(this, (((((poolId + "_") + toString(i.caller)) + "_") + toString(posId)) + kUserPosition)))))
11591132 then throw("There are no user position")
11601133 else if ((0 >= price))
11611134 then throw("Price must be greater than 0")
11621135 else if ((price > tokenOraclePrice))
11631136 then throw("Price must be less than current token price")
11641137 else [IntegerEntry((((((((toString(i.caller) + "_") + toString(posId)) + "_") + poolId) + "_") + assetId) + kUserStopLoss), price)]
11651138 }
11661139
11671140
11681141
11691142 @Callable(i)
11701143 func deleteStopLoss (posId,poolId,assetId) = if (!(isDefined(getInteger(this, (((((((toString(i.caller) + "_") + toString(posId)) + "_") + poolId) + "_") + assetId) + kUserStopLoss)))))
11711144 then throw("No entry")
11721145 else [DeleteEntry((((((((toString(i.caller) + "_") + toString(posId)) + "_") + poolId) + "_") + assetId) + kUserStopLoss))]
11731146
11741147
11751148
11761149 @Callable(i)
11771150 func createNewRequest (params) = valueOrElse(isSelfCall(i), {
11781151 let newRequestId = (valueOrElse(getInteger(this, kRequestIter), 0) + 1)
11791152 $Tuple2([StringEntry((toString(newRequestId) + kRequestId), params), IntegerEntry(kRequestIter, newRequestId)], newRequestId)
11801153 })
11811154
11821155
11831156
11841157 @Callable(i)
1185-func stopLoss (user,posId,pool,assetId) = {
1158+func replenishFromLand (requestId) = valueOrElse(isLandCall(i), {
1159+ let $t03614436248 = parseRequest(requestId)
1160+ let user = $t03614436248._1
1161+ let pool = $t03614436248._2
1162+ let pmtA = $t03614436248._3
1163+ let AId = $t03614436248._4
1164+ let pmtB = $t03614436248._5
1165+ let BId = $t03614436248._6
1166+ let balA = $t03614436248._7
1167+ let balB = $t03614436248._8
1168+ let shareId = $t03614436248._9
1169+ let bwAsset = $t03614436248._10
1170+ let bwAmount = $t03614436248._11
1171+ if ((size(i.payments) != 1))
1172+ then throw("Wrong payment size")
1173+ else if (if ((assetIdToStr(i.payments[0].assetId) != bwAsset))
1174+ then true
1175+ else (i.payments[0].amount != bwAmount))
1176+ then throw("Wrong payment")
1177+ else {
1178+ let $t03643836562 = if ((AId == bwAsset))
1179+ then $Tuple2((pmtA + i.payments[0].amount), pmtB)
1180+ else $Tuple2(pmtA, (pmtB + i.payments[0].amount))
1181+ let pmtAllA = $t03643836562._1
1182+ let pmtAllB = $t03643836562._2
1183+ let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Unknown pool")
1184+ let $t03664436753 = replenishByType(pType, pool, LOAN_FEE, pmtA, AId, pmtB, BId, balA, balB, shareId)
1185+ let userStaked = $t03664436753._1
1186+ let axlyFee = $t03664436753._2
1187+ let posNum = getNewUserPositionNumber(user)
1188+ let borrowEntries = [IntegerEntry((((((pool + "_") + user) + "_") + toString(posNum)) + kUserBorrowAmount), bwAmount), StringEntry((((((pool + "_") + user) + "_") + toString(posNum)) + kUserBorrowAssetId), bwAsset)]
1189+ let entries = replenishEntries(pool, user, userStaked, axlyFee, posNum, shareId, pType, true)
1190+ $Tuple2((((entries ++ getCursEntries(AId, BId, shareId)) ++ borrowEntries) :+ DeleteEntry((requestId + kRequestId))), userStaked)
1191+ }
1192+ })
1193+
1194+
1195+
1196+@Callable(i)
1197+func liquidate (user,posId,liquidateAmount) = valueOrElse(isLandCall(i), {
1198+ let pool = valueOrErrorMessage(getString(this, (((user + "_") + posId) + kUserPositionPool)), "no position")
1199+ let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited")
1200+ let $t03753237622 = getPoolData(Address(fromBase58String(pool)), pType)
1201+ let AId = $t03753237622._1
1202+ let BId = $t03753237622._2
1203+ let balA = $t03753237622._3
1204+ let balB = $t03753237622._4
1205+ let shareId = $t03753237622._5
1206+ let amount = unstakeLP(pool, pType, shareId, liquidateAmount)
1207+ let borrowAmount = getIntegerValue(this, (((((pool + "_") + user) + "_") + posId) + kUserBorrowAmount))
1208+ let borrowAsset = getStringValue(this, (((((pool + "_") + user) + "_") + posId) + kUserBorrowAssetId))
1209+ let userCanWithdraw = userCanWithdrawShareCalc(user, pool, posId, (borrowAmount > 0))
1210+ if ((borrowAmount == 0))
1211+ then throw("You can't liquidate position without borrow")
1212+ else [IntegerEntry((((((pool + "_") + user) + "_") + posId) + kUserPositionInterest), getIntegerValue(this, (pool + kPoolInterestLoan))), IntegerEntry((pool + kPoolTotalLoan), (getPoolTotalShareWithLoan(pool) - liquidateAmount)), IntegerEntry((pool + kPoolTotal), (getPoolTotalShare(pool) - liquidateAmount)), IntegerEntry((((((pool + "_") + user) + "_") + posId) + kUserPosition), (userCanWithdraw - liquidateAmount)), ScriptTransfer(i.caller, amount, fromBase58String(shareId))]
1213+ })
1214+
1215+
1216+
1217+@Callable(i)
1218+func stopLoss (user,posId,pool,assetId) = valueOrElse(isAdminCall(i), {
11861219 let tokenOraclePrice = ( let @ = invoke(priceOracleAddr, "getTWAP60", [assetId, false], nil)
11871220 if ($isInstanceOf(@, "(Int, Int)"))
11881221 then @
11891222 else throw(($getType(@) + " couldn't be cast to (Int, Int)")))._1
11901223 if (!(isDefined(getInteger(this, (((((((user + "_") + toString(posId)) + "_") + pool) + "_") + assetId) + kUserStopLoss)))))
11911224 then throw("No entry")
11921225 else (withdrawToUser(toString(i.caller), pool, toString(posId), true) :+ DeleteEntry((((((((user + "_") + toString(posId)) + "_") + pool) + "_") + assetId) + kUserStopLoss)))
1193- }
1226+ })
11941227
11951228
11961229
11971230 @Callable(i)
1198-func liquidate (user,posId,liquidateAmount) = {
1199- let pool = valueOrErrorMessage(getString(this, (((user + "_") + posId) + kUserPositionPool)), "no position")
1200- let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited")
1201- let $t03790337993 = getPoolData(Address(fromBase58String(pool)), pType)
1202- let AId = $t03790337993._1
1203- let BId = $t03790337993._2
1204- let balA = $t03790337993._3
1205- let balB = $t03790337993._4
1206- let shareId = $t03790337993._5
1207- let amount = unstakeLP(pool, pType, shareId, liquidateAmount)
1208- let borrowAmount = getIntegerValue(this, (((((pool + "_") + user) + "_") + posId) + kUserBorrowAmount))
1209- let borrowAsset = getStringValue(this, (((((pool + "_") + user) + "_") + posId) + kUserBorrowAssetId))
1210- let userCanWithdraw = userCanWithdrawShareCalc(user, pool, posId, (borrowAmount > 0))
1211- if ((borrowAmount == 0))
1212- then throw("You can't liquidate position without borrow")
1213- else [IntegerEntry((((((pool + "_") + user) + "_") + posId) + kUserPositionInterest), getIntegerValue(this, (pool + kPoolInterestLoan))), IntegerEntry((pool + kPoolTotalLoan), (getPoolTotalShareWithLoan(pool) - liquidateAmount)), IntegerEntry((pool + kPoolTotal), (getPoolTotalShare(pool) - liquidateAmount)), IntegerEntry((((((pool + "_") + user) + "_") + posId) + kUserPosition), (userCanWithdraw - liquidateAmount)), ScriptTransfer(i.caller, amount, fromBase58String(shareId))]
1214- }
1215-
1216-
1217-
1218-@Callable(i)
1219-func capitalizeExKeeper (pool,type,tokenToId,amountToExchange,claim,amountsIn,addresses,assetsToReceive,estReceived,slippageTolerance,minReceived,options) = {
1220- let $t03922839422 = if (claim)
1231+func capitalizeExKeeper (pool,type,tokenToId,amountToExchange,claim,amountsIn,addresses,assetsToReceive,estReceived,slippageTolerance,minReceived,options) = valueOrElse(isAdminCall(i), {
1232+ let $t03940739601 = if (claim)
12211233 then claimFarmed(type, pool)
12221234 else {
12231235 let claimedAsset = if ((type == SF_POOL))
12241236 then SWOPID
12251237 else WXID
12261238 $Tuple2(amountToExchange, claimedAsset)
12271239 }
1228- let claimedAmount = $t03922839422._1
1229- let claimedAsset = $t03922839422._2
1240+ let claimedAmount = $t03940739601._1
1241+ let claimedAsset = $t03940739601._2
12301242 let exchangedAmount = exchangeKeeper(tokenToId, amountToExchange, claimedAsset, amountsIn, addresses, assetsToReceive, estReceived, slippageTolerance, minReceived, options)
12311243 let change = (claimedAmount - amountToExchange)
12321244 let changeEntry = if ((change > 0))
12331245 then [IntegerEntry((pool + kPoolCapChange), (change + valueOrElse(getInteger(this, (pool + kPoolCapChange)), 0)))]
12341246 else nil
12351247 (capitalize(pool, type, tokenToId, exchangedAmount) ++ changeEntry)
1236- }
1248+ })
12371249
12381250
12391251
12401252 @Callable(i)
1241-func capitalizeExPuzzle (pool,type,tokenToId,amountToExchange,claim,routesStr,minToReceive,options) = {
1242- let $t04007940273 = if (claim)
1253+func capitalizeExPuzzle (pool,type,tokenToId,amountToExchange,claim,routesStr,minToReceive,options) = valueOrElse(isAdminCall(i), {
1254+ let $t04028640480 = if (claim)
12431255 then claimFarmed(type, pool)
12441256 else {
12451257 let claimedAsset = if ((type == SF_POOL))
12461258 then SWOPID
12471259 else WXID
12481260 $Tuple2(amountToExchange, claimedAsset)
12491261 }
1250- let claimedAmount = $t04007940273._1
1251- let claimedAsset = $t04007940273._2
1262+ let claimedAmount = $t04028640480._1
1263+ let claimedAsset = $t04028640480._2
12521264 let exchangedAmount = exchangePuzzle(tokenToId, amountToExchange, claimedAsset, routesStr, minToReceive, options)
12531265 let change = (claimedAmount - amountToExchange)
12541266 let changeEntry = if ((change > 0))
12551267 then [IntegerEntry((pool + kPoolCapChange), (change + valueOrElse(getInteger(this, (pool + kPoolCapChange)), 0)))]
12561268 else nil
12571269 (capitalize(pool, type, tokenToId, exchangedAmount) ++ changeEntry)
1258- }
1270+ })
12591271
12601272
12611273
12621274 @Callable(i)
1263-func capitalizeExSwopFi (pool,type,tokenToId,amountToExchange,claim,exchangers,exchangersType,args1,args2,routingAssetsKeys,minAmountToReceive,options) = {
1264- let $t04099641190 = if (claim)
1275+func capitalizeExSwopFi (pool,type,tokenToId,amountToExchange,claim,exchangers,exchangersType,args1,args2,routingAssetsKeys,minAmountToReceive,options) = valueOrElse(isAdminCall(i), {
1276+ let $t04123141425 = if (claim)
12651277 then claimFarmed(type, pool)
12661278 else {
12671279 let claimedAsset = if ((type == SF_POOL))
12681280 then SWOPID
12691281 else WXID
12701282 $Tuple2(amountToExchange, claimedAsset)
12711283 }
1272- let claimedAmount = $t04099641190._1
1273- let claimedAsset = $t04099641190._2
1284+ let claimedAmount = $t04123141425._1
1285+ let claimedAsset = $t04123141425._2
12741286 let exchangedAmount = exchangeSwopFi(tokenToId, amountToExchange, claimedAsset, exchangers, exchangersType, args1, args2, routingAssetsKeys, minAmountToReceive, options)
12751287 let change = (claimedAmount - amountToExchange)
12761288 let changeEntry = if ((change > 0))
12771289 then [IntegerEntry((pool + kPoolCapChange), (change + valueOrElse(getInteger(this, (pool + kPoolCapChange)), 0)))]
12781290 else nil
12791291 (capitalize(pool, type, tokenToId, exchangedAmount) ++ changeEntry)
1280- }
1292+ })
12811293
12821294
12831295
12841296 @Callable(i)
1285-func initNewPool (type,poolAddr,inFeeNoLoan,inFeeLoan,capFeeNoLoan,capFeeWithLoan,stoplossFeeNoLoan,stoplossFeeWithLoan) = if (if ((type != SF_POOL))
1297+func initNewPool (type,poolAddr,inFeeNoLoan,inFeeLoan,capFeeNoLoan,capFeeWithLoan,stoplossFeeNoLoan,stoplossFeeWithLoan) = valueOrElse(isAdminCall(i), if (if ((type != SF_POOL))
12861298 then (type != WX_POOL)
12871299 else false)
12881300 then throw("Wrong type")
12891301 else {
1290- let $t04188341977 = getPoolData(Address(fromBase58String(poolAddr)), type)
1291- let aId = $t04188341977._1
1292- let bId = $t04188341977._2
1293- let aBal = $t04188341977._3
1294- let bBal = $t04188341977._4
1295- let shareId = $t04188341977._5
1302+ let $t04214642240 = getPoolData(Address(fromBase58String(poolAddr)), type)
1303+ let aId = $t04214642240._1
1304+ let bId = $t04214642240._2
1305+ let aBal = $t04214642240._3
1306+ let bBal = $t04214642240._4
1307+ let shareId = $t04214642240._5
12961308 [IntegerEntry((poolAddr + kAxlyInFeeWithoutLoan), inFeeNoLoan), IntegerEntry((poolAddr + kAxlyInFeeWithLoan), inFeeLoan), IntegerEntry((poolAddr + kAxlyNoLoanCapFee), capFeeNoLoan), IntegerEntry((poolAddr + kAxlyWithLoanCapFee), capFeeWithLoan), IntegerEntry((poolAddr + kAxlyStopLossNoLoanFee), stoplossFeeNoLoan), IntegerEntry((poolAddr + kAxlyStopLossLoanFee), stoplossFeeWithLoan), IntegerEntry((poolAddr + kPoolInterestLoan), 0), IntegerEntry((poolAddr + kPoolInterestNoLoan), 0), StringEntry((kPool + poolAddr), type), StringEntry((shareId + kSharePool), poolAddr)]
1297- }
1298-
1299-
1300-
1301-@Callable(i)
1302-func capitalizeTest (pool,pType,tokenId,tokenAmount) = {
1303- let poolAddr = Address(fromBase58String(pool))
1304- let $t04277342852 = getPoolData(poolAddr, pType)
1305- let AId = $t04277342852._1
1306- let BId = $t04277342852._2
1307- let balA = $t04277342852._3
1308- let balB = $t04277342852._4
1309- let shareId = $t04277342852._5
1310- let $t04285542935 = if ((tokenId == AId))
1311- then $Tuple2(tokenAmount, 0)
1312- else $Tuple2(0, tokenAmount)
1313- let pmtA = $t04285542935._1
1314- let pmtB = $t04285542935._2
1315- let $t04293843042 = replenishByType(pType, pool, NO_FEE, pmtA, AId, pmtB, BId, balA, balB, shareId)
1316- let stakedAmount = $t04293843042._1
1317- let nf = $t04293843042._2
1318- let curPoolInterestLoan = valueOrElse(getInteger(this, (pool + kPoolInterestLoan)), 0)
1319- let curPoolInterestNoLoan = valueOrElse(getInteger(this, (pool + kPoolInterestNoLoan)), 0)
1320- let totalShareAmount = getPoolTotalShare(pool)
1321- let totalShareAmountWithLoan = getPoolTotalShareWithLoan(pool)
1322- let loanPercent = fraction(totalShareAmountWithLoan, SCALE8, totalShareAmount)
1323- let stakedLoan = fraction(stakedAmount, loanPercent, SCALE8)
1324- let stakedNoLoan = (stakedAmount - stakedLoan)
1325- let newInterestLoan = if ((totalShareAmountWithLoan > 0))
1326- then (curPoolInterestLoan + fraction(stakedLoan, SCALE10, totalShareAmountWithLoan))
1327- else 0
1328- let newInterestNoLoan = if (((totalShareAmount - totalShareAmountWithLoan) > 0))
1329- then (curPoolInterestNoLoan + fraction(stakedNoLoan, SCALE10, (totalShareAmount - totalShareAmountWithLoan)))
1330- else 0
1331- let axlyFeeLoan = fraction(stakedLoan, getAxlyFee(pool, CAP_FEE_LOAN), FEE_SCALE6)
1332- let axlyFeeNoLoan = fraction(stakedNoLoan, getAxlyFee(pool, CAP_FEE_NO_LOAN), FEE_SCALE6)
1333- let axlyFee = unstakeLP(pool, pType, shareId, (axlyFeeLoan + axlyFeeNoLoan))
1334- if ((axlyFee == axlyFee))
1335- then ([IntegerEntry((pool + kPoolInterestLoan), newInterestLoan), IntegerEntry((pool + kPoolInterestNoLoan), newInterestNoLoan), IntegerEntry((pool + kPoolTotal), ((totalShareAmount + stakedAmount) - axlyFee)), IntegerEntry((pool + kPoolTotalLoan), ((totalShareAmountWithLoan + stakedLoan) - axlyFeeLoan)), ScriptTransfer(moneyBox, (axlyFeeLoan + axlyFeeNoLoan), fromBase58String(shareId))] ++ getCursEntries(AId, BId, shareId))
1336- else throw("Strict value is not equal to itself.")
1337- }
1338-
1339-
1340-
1341-@Callable(i)
1342-func claimFarmedTest (type,pool) = if ((type == SF_POOL))
1343- then {
1344- let balBefore = accountBalance(SWOPID)
1345- if ((balBefore == balBefore))
1346- then {
1347- let inv = invoke(getSFFarmingAddr(), "claim", [pool], nil)
1348- if ((inv == inv))
1349- then {
1350- let balAfter = accountBalance(SWOPID)
1351- $Tuple2(nil, $Tuple2((balAfter - balBefore), SWOPID))
1352- }
1353- else throw("Strict value is not equal to itself.")
1354- }
1355- else throw("Strict value is not equal to itself.")
1356- }
1357- else if ((type == WX_POOL))
1358- then {
1359- let balBefore = accountBalance(WXID)
1360- if ((balBefore == balBefore))
1361- then {
1362- let inv = invoke(getWXFarmingAddr(Address(fromBase58String(pool))), "claimWX", [pool], nil)
1363- if ((inv == inv))
1364- then {
1365- let balAfter = accountBalance(WXID)
1366- $Tuple2(nil, $Tuple2((balAfter - balBefore), WXID))
1367- }
1368- else throw("Strict value is not equal to itself.")
1369- }
1370- else throw("Strict value is not equal to itself.")
1371- }
1372- else throw("Wrong pool type")
1309+ })
13731310
13741311
13751312 @Verifier(tx)
13761313 func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)
13771314

github/deemru/w8io/3ef1775 
311.14 ms