tx · AyWWFYgP6wkUM1FC3xCMC9HYJ2goDhJSBVwsX2YoLdb9

3MvRWw2FPEimFCTGtK7qY9uAJbM7XJ4ZfJS:  -0.04700000 Waves

2023.07.20 13:17 [2674055] smart account 3MvRWw2FPEimFCTGtK7qY9uAJbM7XJ4ZfJS > SELF 0.00000000 Waves

{ "type": 13, "id": "AyWWFYgP6wkUM1FC3xCMC9HYJ2goDhJSBVwsX2YoLdb9", "fee": 4700000, "feeAssetId": null, "timestamp": 1689848323207, "version": 2, "chainId": 84, "sender": "3MvRWw2FPEimFCTGtK7qY9uAJbM7XJ4ZfJS", "senderPublicKey": "HP8sssVq1866F7CaPQJwgFrt6fsqhQjKwM84cL1wjD2a", "proofs": [ "3b3Yxdfh3D95U8SDs1nbnJSVYWZVJwmP2FSy4JTtBE45gNf1LG6h2Gv9dbTRmk6nBiacsbD3G9P5CSePKXgq6dBG" ], "script": "base64:BgKmAQgCEgMKAQgSBAoCCAgSBQoDCBgYEgUKAwgBCBIECgIIARIGCgQBCAgBEgUKAwEICBILCgkICAgICAgICAgSAwoBCBIDCgEIEgUKAwgIARIGCgQIAQgIEg0KCwgIAQQRGBgRAQEYEgkKBwgIAQQIARgSDQoLCAgBBBgYGBgYARgSCwoJCAgBAQEBAQEEEgASABIAEgASABIAEgASABIDCgEIEgMKAQh3AAdTRl9QT09MAgJTRgAHV1hfUE9PTAICV1gAD0NBUF9GRUVfTk9fTE9BTgIJY2FwTm9Mb2FuAAxDQVBfRkVFX0xPQU4CB2NhcExvYW4AFFNUT1BMT1NTX0ZFRV9OT19MT0FOAg5zdG9wTG9zc05vTG9hbgANU1RPUExPU1NfTE9BTgIMc3RvcExvc3NMb2FuAAhMT0FOX0ZFRQIEbG9hbgALTk9fTE9BTl9GRUUCBm5vTG9hbgAGTk9fRkVFAgVub0ZlZQAGU0NBTEU4AIDC1y8AB1NDQUxFMTAAgMivoCUAB1NDQUxFMTYJALYCAQCAgIT+pt7hEQAKRkVFX1NDQUxFNgDAhD0AFGtTRlBvb2xBQXNzZXRCYWxhbmNlAg9BX2Fzc2V0X2JhbGFuY2UAFGtTRlBvb2xCQXNzZXRCYWxhbmNlAg9CX2Fzc2V0X2JhbGFuY2UAD2tTRlBvb2xBQXNzZXRJZAIKQV9hc3NldF9pZAAPa1NGUG9vbEJBc3NldElkAgpCX2Fzc2V0X2lkAA5rU0ZQb29sU2hhcmVJZAIOc2hhcmVfYXNzZXRfaWQAEmtTRlBvb2xTaGFyZVN1cHBseQISc2hhcmVfYXNzZXRfc3VwcGx5AAprU0ZQb29sRmVlAgpjb21taXNzaW9uAA1rVXNlclBvc2l0aW9uAg1fdXNlclBvc2l0aW9uABFrVXNlclBvc2l0aW9uUG9vbAIRX3VzZXJQb3NpdGlvblBvb2wAEWtVc2VyQm9ycm93QW1vdW50AhlfdXNlclBvc2l0aW9uQm9ycm93QW1vdW50ABJrVXNlckJvcnJvd0Fzc2V0SWQCGl91c2VyUG9zaXRpb25Cb3Jyb3dBc3NldElkABBrVXNlclBvc2l0aW9uTnVtAhNfdXNlclBvc2l0aW9uTnVtYmVyABVrVXNlclBvc2l0aW9uSW50ZXJlc3QCFV91c2VyUG9zaXRpb25JbnRlcmVzdAAKa1Bvb2xUb3RhbAIKX3Bvb2xUb3RhbAAOa1Bvb2xUb3RhbExvYW4CDl9wb29sVG90YWxMb2FuABFrUG9vbEludGVyZXN0TG9hbgIRX3Bvb2xJbnRlcmVzdExvYW4AE2tQb29sSW50ZXJlc3ROb0xvYW4CE19wb29sSW50ZXJlc3ROb0xvYW4ADmtQb29sQ2FuQm9ycm93Ag5fcG9vbENhbkJvcnJvdwAVa0F4bHlJbkZlZVdpdGhvdXRMb2FuAg5fYXhseUZlZU5vTG9hbgASa0F4bHlJbkZlZVdpdGhMb2FuAhBfYXhseUZlZVdpdGhMb2FuABFrQXhseU5vTG9hbkNhcEZlZQITX2F4bHlGZWVDYXBXaXRoTG9hbgATa0F4bHlXaXRoTG9hbkNhcEZlZQIRX2F4bHlGZWVDYXBOb0xvYW4AFmtBeGx5U3RvcExvc3NOb0xvYW5GZWUCGF9heGx5RmVlU3RvcGxvc3NXaXRoTG9hbgAUa0F4bHlTdG9wTG9zc0xvYW5GZWUCFl9heGx5RmVlU3RvcGxvc3NOb0xvYW4ACmtSZXF1ZXN0SWQCC19yZXF1ZXN0X2lkAAxrUmVxdWVzdEl0ZXICDXJlcXVlc3RzX2l0ZXIABWtQb29sAgVwb29sXwAKa1NoYXJlUG9vbAIMX3Bvb2xTaGFyZUlkAA5rUG9vbENhcENoYW5nZQIOX3Bvb2xDYXBDaGFuZ2UAD2tUb2tlbkxhc3RQcmljZQIKbGFzdF9wcmljZQAOa1ByaWNlSW5PcmFjbGUCB190d2FwNUIAB2tBY3RpdmUCBmFjdGl2ZQAMa0FjdGl2ZVVzZXJzAgthY3RpdmVVc2VycwALa0FjdGl2ZVNGV1gCB19hY3RpdmUAC2tQb29sQWN0aXZlAgtfYWN0aXZlUG9vbAANa1VzZXJTdG9wTG9zcwIJX3N0b3BMb3NzAAlrTW9uZXlCb3gCDmF4bHlfbW9uZXlfYm94AA5rU0ZGYXJtaW5nQWRkcgITc3dvcGZpX2Zhcm1pbmdfYWRkcgAMa0xlbmRTZXJ2aWNlAhFsZW5kX3NlcnZpY2VfYWRkcgAMa0FkbWluQ2FsbFBLAhJhZG1pbl9jYWxsX3B1Yl9rZXkADGtQcmljZU9yYWNsZQIMcHJpY2Vfb3JhY2xlAAtrRXhDb250cmFjdAIRZXhjaGFuZ2VfY29udHJhY3QAD2tXeFN3YXBDb250cmFjdAIQd3hfc3dhcF9jb250cmFjdAAHa1N3b3BJZAIHc3dvcF9pZAAFa1d4SWQCBXd4X2lkAAhtb25leUJveAkBB0FkZHJlc3MBCQDZBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzBQlrTW9uZXlCb3gCGE5vIGF4bHkgbW9uZXlCb3ggYWRkcmVzcwAKZXhDb250cmFjdAkBB0FkZHJlc3MBCQDZBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzBQtrRXhDb250cmFjdAIcTm8gZXhjaGFuZ2UgY29udHJhY3QgYWRkcmVzcwAPcHJpY2VPcmFjbGVBZGRyCQEHQWRkcmVzcwEJANkEAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMFDGtQcmljZU9yYWNsZQIXTm8gcHJpY2Ugb3JhY2xlIGFkZHJlc3MADnd4U3dhcENvbnRyYWN0CQEHQWRkcmVzcwEJANkEAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMFD2tXeFN3YXBDb250cmFjdAISTm8gd3ggc3dhcCBhZGRyZXNzAAZTV09QSUQJANkEAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMFB2tTd29wSWQCCk5vIHN3b3AgaWQABFdYSUQJANkEAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMFBWtXeElkAghObyB3eCBpZAEPdW5rbm93blBvb2xUeXBlAAkAAgECD1dyb25nIHBvb2wgdHlwZQEOZ2V0TGVuZFNydkFkZHIACQEHQWRkcmVzcwEJANkEAQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMFDGtMZW5kU2VydmljZQIbQ2FuJ3QgZ2V0IGxlbmQgc2VydmljZSBhZGRyARBnZXRBZG1pbkNhbGxBZGRyAAkApwgBCQDZBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzBQxrQWRtaW5DYWxsUEsCFENhbid0IGdldCBhZG1pbiBhZGRyAQtpc0FkbWluQ2FsbAEBaQMJAAACCAUBaQZjYWxsZXIJARBnZXRBZG1pbkNhbGxBZGRyAAUEdW5pdAkAAgECIU9ubHkgYWRtaW4gY2FuIGNhbGwgdGhpcyBmdW5jdGlvbgEKaXNTZWxmQ2FsbAEBaQMJAAACCAUBaQZjYWxsZXIFBHRoaXMFBHVuaXQJAAIBAitPbmx5IGNvbnRyYWN0IGl0c2VsZiBjYW4gY2FsbCB0aGlzIGZ1bmN0aW9uAQppc0xhbmRDYWxsAQFpAwkAAAIIBQFpBmNhbGxlcgkBDmdldExlbmRTcnZBZGRyAAUEdW5pdAkAAgECKU9ubHkgbGFuZCBjb250cmFjdCBjYW4gY2FsbCB0aGlzIGZ1bmN0aW9uAQhpc0FjdGl2ZQADCQAAAgkBC3ZhbHVlT3JFbHNlAgkAmwgCBQR0aGlzBQdrQWN0aXZlBgYFBHVuaXQJAAIBAh9EQXBwIGlzIGluYWN0aXZlIGF0IHRoaXMgbW9tZW50ARBpc0FjdGl2ZUZvclVzZXJzAAMDCQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMFB2tBY3RpdmUGCQAAAgkBC3ZhbHVlT3JFbHNlAgkAmwgCBQR0aGlzBQxrQWN0aXZlVXNlcnMGBgcFBHVuaXQJAAIBAilEQXBwIGlzIGluYWN0aXZlIGZvciB1c2VycyBhdCB0aGlzIG1vbWVudAEMaXNQb29sQWN0aXZlAgRwb29sBHR5cGUECldYU0ZBY3RpdmUJAQt2YWx1ZU9yRWxzZQIJAJsIAgUEdGhpcwkArAICBQR0eXBlBQtrQWN0aXZlU0ZXWAYECnBvb2xBY3RpdmUJAQt2YWx1ZU9yRWxzZQIJAJsIAgUEdGhpcwkArAICBQRwb29sBQtrUG9vbEFjdGl2ZQYDAwUKV1hTRkFjdGl2ZQUKcG9vbEFjdGl2ZQcGBwEOYWNjb3VudEJhbGFuY2UBB2Fzc2V0SWQEByRtYXRjaDAFB2Fzc2V0SWQDCQABAgUHJG1hdGNoMAIKQnl0ZVZlY3RvcgQCaWQFByRtYXRjaDAJAPAHAgUEdGhpcwUCaWQDCQABAgUHJG1hdGNoMAIEVW5pdAQFd2F2ZXMFByRtYXRjaDAICQDvBwEFBHRoaXMJYXZhaWxhYmxlCQACAQILTWF0Y2ggZXJyb3IBEWdldFNGUG9vbEJhbGFuY2VzAQhwb29sQWRkcgkAlAoCCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUIcG9vbEFkZHIFFGtTRlBvb2xBQXNzZXRCYWxhbmNlAh5DYW4ndCBnZXQgcG9vbCBBIGFzc2V0IGJhbGFuY2UJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQhwb29sQWRkcgUUa1NGUG9vbEJBc3NldEJhbGFuY2UCHkNhbid0IGdldCBwb29sIEIgYXNzZXQgYmFsYW5jZQERZ2V0V1hQb29sQmFsYW5jZXMDCHBvb2xBZGRyA2FJZANiSWQJAJQKAgoAAUAJAPwHBAUIcG9vbEFkZHICHGdldEFjY0JhbGFuY2VXcmFwcGVyUkVBRE9OTFkJAMwIAgUDYUlkBQNuaWwFA25pbAMJAAECBQFAAgNJbnQFAUAJAAIBCQCsAgIJAAMBBQFAAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQKAAFACQD8BwQFCHBvb2xBZGRyAhxnZXRBY2NCYWxhbmNlV3JhcHBlclJFQURPTkxZCQDMCAIFA2JJZAUDbmlsBQNuaWwDCQABAgUBQAIDSW50BQFACQACAQkArAICCQADAQUBQAIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50AQ9nZXRQb29sQmFsYW5jZXMECHBvb2xBZGRyBHR5cGUDYUlkA2JJZAMJAAACBQR0eXBlBQdTRl9QT09MCQERZ2V0U0ZQb29sQmFsYW5jZXMBBQhwb29sQWRkcgMJAAACBQR0eXBlBQdXWF9QT09MCQERZ2V0V1hQb29sQmFsYW5jZXMDBQhwb29sQWRkcgUDYUlkBQNiSWQJAQ91bmtub3duUG9vbFR5cGUAAQ1nZXRTRlBvb2xEYXRhAQhwb29sQWRkcgQLJHQwNzA2NDcxMTMJARFnZXRTRlBvb2xCYWxhbmNlcwEFCHBvb2xBZGRyAwkAAAIFCyR0MDcwNjQ3MTEzBQskdDA3MDY0NzExMwQEYmFsQggFCyR0MDcwNjQ3MTEzAl8yBARiYWxBCAULJHQwNzA2NDcxMTMCXzEJAJcKBQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFCHBvb2xBZGRyBQ9rU0ZQb29sQUFzc2V0SWQCGUNhbid0IGdldCBwb29sIEEgYXNzZXQgaWQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQhwb29sQWRkcgUPa1NGUG9vbEJBc3NldElkAhlDYW4ndCBnZXQgcG9vbCBCIGFzc2V0IGlkBQRiYWxBBQRiYWxCCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUIcG9vbEFkZHIFDmtTRlBvb2xTaGFyZUlkAhhDYW4ndCBnZXQgc2hhcmUgYXNzZXQgaWQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BDWdldFdYUG9vbERhdGEBCHBvb2xBZGRyBANjZmcKAAFACQD8BwQFCHBvb2xBZGRyAhxnZXRQb29sQ29uZmlnV3JhcHBlclJFQURPTkxZBQNuaWwFA25pbAMJAAECBQFAAglMaXN0W0FueV0FAUAJAAIBCQCsAgIJAAMBBQFAAh4gY291bGRuJ3QgYmUgY2FzdCB0byBMaXN0W0FueV0DCQAAAgUDY2ZnBQNjZmcEA2FJZAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCgABQAkAkQMCBQNjZmcABAMJAAECBQFAAgZTdHJpbmcFAUAFBHVuaXQCGUNhbid0IGdldCBwb29sIEEgYXNzZXQgaWQEA2JJZAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCgABQAkAkQMCBQNjZmcABQMJAAECBQFAAgZTdHJpbmcFAUAFBHVuaXQCGUNhbid0IGdldCBwb29sIEIgYXNzZXQgaWQEB3NoYXJlSWQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgoAAUAJAJEDAgUDY2ZnAAMDCQABAgUBQAIGU3RyaW5nBQFABQR1bml0AhpDYW4ndCBnZXQgcG9vbCBMUCBhc3NldCBpZAQLJHQwNzgxMDc4NjkJARFnZXRXWFBvb2xCYWxhbmNlcwMFCHBvb2xBZGRyBQNhSWQFA2JJZAMJAAACBQskdDA3ODEwNzg2OQULJHQwNzgxMDc4NjkEBGJhbEIIBQskdDA3ODEwNzg2OQJfMgQEYmFsQQgFCyR0MDc4MTA3ODY5Al8xCQCXCgUFA2FJZAUDYklkBQRiYWxBBQRiYWxCBQdzaGFyZUlkCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQtnZXRQb29sRGF0YQIIcG9vbEFkZHIEdHlwZQMJAAACBQR0eXBlBQdTRl9QT09MCQENZ2V0U0ZQb29sRGF0YQEFCHBvb2xBZGRyAwkAAAIFBHR5cGUFB1dYX1BPT0wJAQ1nZXRXWFBvb2xEYXRhAQUIcG9vbEFkZHIJAQ91bmtub3duUG9vbFR5cGUAAQ5nZXRTaGFyZVN1cHBseQMIcG9vbEFkZHIEdHlwZQdzaGFyZUlkAwkAAAIFBHR5cGUFB1NGX1BPT0wJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQhwb29sQWRkcgUSa1NGUG9vbFNoYXJlU3VwcGx5AhxDYW4ndCBnZXQgc2hhcmUgYXNzZXQgc3VwcGx5AwkAAAIFBHR5cGUFB1dYX1BPT0wICQETdmFsdWVPckVycm9yTWVzc2FnZQIJAOwHAQkA2QQBBQdzaGFyZUlkAg1Xcm9uZyBTaGFyZUlkCHF1YW50aXR5CQEPdW5rbm93blBvb2xUeXBlAAERZ2V0UG9vbFRvdGFsU2hhcmUBBHBvb2wJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkArAICBQRwb29sBQprUG9vbFRvdGFsAAABGWdldFBvb2xUb3RhbFNoYXJlV2l0aExvYW4BBHBvb2wJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkArAICBQRwb29sBQ5rUG9vbFRvdGFsTG9hbgAAARhnZXROZXdVc2VyUG9zaXRpb25OdW1iZXIBBHVzZXIJAGQCCQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAKwCAgUEdXNlcgUQa1VzZXJQb3NpdGlvbk51bQAAAAEBCmdldEF4bHlGZWUCBHBvb2wHZmVlVHlwZQMJAAACBQdmZWVUeXBlBQxDQVBfRkVFX0xPQU4JARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAKwCAgUEcG9vbAUTa0F4bHlXaXRoTG9hbkNhcEZlZQMJAAACBQdmZWVUeXBlBQ9DQVBfRkVFX05PX0xPQU4JARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAKwCAgUEcG9vbAURa0F4bHlOb0xvYW5DYXBGZWUDCQAAAgUHZmVlVHlwZQUITE9BTl9GRUUJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAKwCAgUEcG9vbAUSa0F4bHlJbkZlZVdpdGhMb2FuAwkAAAIFB2ZlZVR5cGUFC05PX0xPQU5fRkVFCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzCQCsAgIFBHBvb2wFFWtBeGx5SW5GZWVXaXRob3V0TG9hbgMJAAACBQdmZWVUeXBlBQZOT19GRUUAAAkAAgECDldyb25nIGZlZSB0eXBlARBnZXRTRkZhcm1pbmdBZGRyAAkBB0FkZHJlc3MBCQDZBAEJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzBQ5rU0ZGYXJtaW5nQWRkcgIdQ2FuJ3QgZ2V0IHN3b3BmaSBmYXJtaW5nIGFkZHIBEGdldFdYRmFybWluZ0FkZHIBCHBvb2xBZGRyBAlmQ29udHJhY3QJAQdBZGRyZXNzAQkA2QQBCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUIcG9vbEFkZHICEyVzX19mYWN0b3J5Q29udHJhY3QCIkNhbid0IGdldCBXWCBmYWN0b3J5IGNvbnRyYWN0IGFkZHIECmZhY3Ryb3lDZmcJALUJAgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFCWZDb250cmFjdAIRJXNfX2ZhY3RvcnlDb25maWcCGENhbid0IGdldCBXWCBmYWN0b3J5IGNmZwICX18JAQdBZGRyZXNzAQkA2QQBCQCRAwIFCmZhY3Ryb3lDZmcAAQEMYXNzZXRJZFRvU3RyAQdhc3NldElkBAckbWF0Y2gwBQdhc3NldElkAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEAmlkBQckbWF0Y2gwCQDYBAEFAmlkAwkAAQIFByRtYXRjaDACBFVuaXQEBXdhdmVzBQckbWF0Y2gwAgVXQVZFUwkAAgECDE5vdCBBc3NldCBpZAEOYXNzZXRJZEZyb21TdHIBB2Fzc2V0SWQDCQAAAgUHYXNzZXRJZAIFV0FWRVMFBHVuaXQJANkEAQUHYXNzZXRJZAEQZ2V0QXNzZXREZWNpbWFscwEHYXNzZXRJZAMJAAACBQdhc3NldElkAgVXQVZFUwAIBAckbWF0Y2gwCQDsBwEJANkEAQUHYXNzZXRJZAMJAAECBQckbWF0Y2gwAgVBc3NldAQFYXNzZXQFByRtYXRjaDAIBQVhc3NldAhkZWNpbWFscwkAAgECEENhbid0IGZpbmQgYXNzZXQBEWdldEFzc2V0UHJlY2l0aW9uAQdhc3NldElkCQBsBgAKAAAJARBnZXRBc3NldERlY2ltYWxzAQUHYXNzZXRJZAAAAAAFBERPV04BDmdldEFzc2V0c1ByaWNlAQhhc3NldElkcwoBCWdldFByaWNlcwIBYQdhc3NldElkBAphc3NldFByaWNlCQERQGV4dHJOYXRpdmUoMTA1MCkCBQ9wcmljZU9yYWNsZUFkZHIJAKwCAgUHYXNzZXRJZAUOa1ByaWNlSW5PcmFjbGUJAM0IAgUBYQUKYXNzZXRQcmljZQoAAiRsBQhhc3NldElkcwoAAiRzCQCQAwEFAiRsCgAFJGFjYzAFA25pbAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEJZ2V0UHJpY2VzAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyA1MAkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKAAsADAANAA4ADwAQABEAEgATABQAFQAWABcAGAAZABoAGwAcAB0AHgAfACAAIQAiACMAJAAlACYAJwAoACkAKgArACwALQAuAC8AMAAxADIBDWdldFNoYXJlUHJpY2UBB3NoYXJlSWQEBHBvb2wJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzCQCsAgIFB3NoYXJlSWQFCmtTaGFyZVBvb2wCIENhbid0IGZpbmQgcG9vbCBhZGRyIGJ5IHNoYXJlIGlkBAhwb29sQWRkcgkBB0FkZHJlc3MBCQDZBAEFBHBvb2wEBXBUeXBlCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwkArAICBQVrUG9vbAUEcG9vbAISUG9vbCBpcyBub3QgaW5pdGVkBA0kdDAxMDg0NzEwOTEyCQELZ2V0UG9vbERhdGECBQhwb29sQWRkcgUFcFR5cGUEA2FJZAgFDSR0MDEwODQ3MTA5MTICXzEEA2JJZAgFDSR0MDEwODQ3MTA5MTICXzIECGFCYWxhbmNlCAUNJHQwMTA4NDcxMDkxMgJfMwQIYkJhbGFuY2UIBQ0kdDAxMDg0NzEwOTEyAl80BAdkUHJpY2VBCQERQGV4dHJOYXRpdmUoMTA1MCkCBQ9wcmljZU9yYWNsZUFkZHIJAKwCAgUDYUlkBQ5rUHJpY2VJbk9yYWNsZQQHZFByaWNlQgkBEUBleHRyTmF0aXZlKDEwNTApAgUPcHJpY2VPcmFjbGVBZGRyCQCsAgIFA2JJZAUOa1ByaWNlSW5PcmFjbGUEC3NoYXJlU3VwcGx5CQEOZ2V0U2hhcmVTdXBwbHkDBQhwb29sQWRkcgUFcFR5cGUFB3NoYXJlSWQECkFQcmVjaXNpb24JAGwGAAoAAAkBEGdldEFzc2V0RGVjaW1hbHMBBQNhSWQAAAAABQRET1dOBApCUHJlY2lzaW9uCQBsBgAKAAAJARBnZXRBc3NldERlY2ltYWxzAQUDYklkAAAAAAUERE9XTgQOc2hhcmVQcmVjaXNpb24JAGwGAAoAAAkBEGdldEFzc2V0RGVjaW1hbHMBBQdzaGFyZUlkAAAAAAUERE9XTgQDc3VtCQBkAgkAawMFCGFCYWxhbmNlBQdkUHJpY2VBBQpBUHJlY2lzaW9uCQBrAwUIYkJhbGFuY2UFB2RQcmljZUIFCkJQcmVjaXNpb24JAGsDBQNzdW0FDnNoYXJlUHJlY2lzaW9uBQtzaGFyZVN1cHBseQEOZ2V0U2hhcmVQcmljZXMBCHNoYXJlSWRzCgEJZ2V0UHJpY2VzAgFhB3NoYXJlSWQJAM0IAgUBYQkBDWdldFNoYXJlUHJpY2UBBQdzaGFyZUlkCgACJGwFCHNoYXJlSWRzCgACJHMJAJADAQUCJGwKAAUkYWNjMAUDbmlsCgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQlnZXRQcmljZXMCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDIwCQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoACwAMAA0ADgAPABAAEQASABMAFAEOZ2V0Q3Vyc0VudHJpZXMEA2FJZANiSWQHc2hhcmVJZAh3QW1vdW50cwQMYXNzZXRzUHJpY2VzCQEOZ2V0QXNzZXRzUHJpY2UBCQDMCAIFA2FJZAkAzAgCBQNiSWQFA25pbAQKc2hhcmVQcmljZQkBDWdldFNoYXJlUHJpY2UBBQdzaGFyZUlkBAZwcmljZXMJAM4IAgkAzAgCCQCkAwEJAJEDAgUMYXNzZXRzUHJpY2VzAAAJAMwIAgkApAMBCQCRAwIFDGFzc2V0c1ByaWNlcwABCQDMCAIJAKQDAQUKc2hhcmVQcmljZQUDbmlsBQh3QW1vdW50cwkAzAgCCQELU3RyaW5nRW50cnkCBQ9rVG9rZW5MYXN0UHJpY2UJALkJAgUGcHJpY2VzAgEsBQNuaWwBGGNhbGNSZXBsZW5pc2hCeVR3b1Rva2VucwgFcFR5cGUIcG9vbEFkZHIEcG10QQNhSWQEcG10QgNiSWQEYmFsQQRiYWxCAwkAAAIFBXBUeXBlBQdTRl9QT09MBARyZXBsCgABQAkA/AcEBQhwb29sQWRkcgIMY2FsbEZ1bmN0aW9uCQDMCAICIGNhbGNMUFJlcGxlbmlzaFR3b1Rva2Vuc1JFQURPTkxZCQDMCAIJAMwIAgkApAMBBQRwbXRBCQDMCAIJAKQDAQUEcG10QgUDbmlsBQNuaWwFA25pbAMJAAECBQFAAglMaXN0W0FueV0FAUAJAAIBCQCsAgIJAAMBBQFAAh4gY291bGRuJ3QgYmUgY2FzdCB0byBMaXN0W0FueV0DCQAAAgUEcmVwbAUEcmVwbAkAlwoFCgABQAkAkQMCBQRyZXBsAAMDCQABAgUBQAIDSW50BQFACQACAQkArAICCQADAQUBQAIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50CgABQAkAkQMCBQRyZXBsAAQDCQABAgUBQAIDSW50BQFACQACAQkArAICCQADAQUBQAIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50CgABQAkAkQMCBQRyZXBsAAEDCQABAgUBQAIDSW50BQFACQACAQkArAICCQADAQUBQAIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50CQEMYXNzZXRJZFRvU3RyAQkAkQMCBQRyZXBsAAIKAAFACQCRAwIFBHJlcGwAAAMJAAECBQFAAgNJbnQFAUAJAAIBCQCsAgIJAAMBBQFAAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4DCQAAAgUFcFR5cGUFB1dYX1BPT0wEDSR0MDEyNDU3MTI3MDcJAJQKAgkAtQkCCgABQAkA/AcEBQhwb29sQWRkcgIgZXZhbHVhdGVQdXRCeUFtb3VudEFzc2V0UkVBRE9OTFkJAMwIAgUEcG10QQUDbmlsBQNuaWwDCQABAgUBQAIGU3RyaW5nBQFACQACAQkArAICCQADAQUBQAIbIGNvdWxkbid0IGJlIGNhc3QgdG8gU3RyaW5nAgJfXwkAtQkCCgABQAkA/AcEBQhwb29sQWRkcgIfZXZhbHVhdGVQdXRCeVByaWNlQXNzZXRSRUFET05MWQkAzAgCBQRwbXRCBQNuaWwFA25pbAMJAAECBQFAAgZTdHJpbmcFAUAJAAIBCQCsAgIJAAMBBQFAAhsgY291bGRuJ3QgYmUgY2FzdCB0byBTdHJpbmcCAl9fAwkAAAIFDSR0MDEyNDU3MTI3MDcFDSR0MDEyNDU3MTI3MDcECmV2YWxQdXRJbkIIBQ0kdDAxMjQ1NzEyNzA3Al8yBApldmFsUHV0SW5BCAUNJHQwMTI0NTcxMjcwNwJfMQQFbHBJbkEJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQpldmFsUHV0SW5BAAEEBWxwSW5CCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUKZXZhbFB1dEluQgABAwkAZgIFBWxwSW5CBQVscEluQQQDcG10CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUKZXZhbFB1dEluQQAICQCXCgUFBHBtdEEFA3BtdAkAZQIFBHBtdEIFA3BtdAUDYklkBQVscEluQgQDcG10CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUKZXZhbFB1dEluQgAHCQCXCgUFA3BtdAUEcG10QgkAZQIFBHBtdEEFA3BtdAUDYUlkBQVscEluQQkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkBD3Vua25vd25Qb29sVHlwZQABGHJlcGxlbmlzaFR3b1Rva2Vuc0J5VHlwZQYIcG9vbEFkZHIFcFR5cGUEcG10QQNhSWQEcG10QgNiSWQECHBheW1lbnRzCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQEOYXNzZXRJZEZyb21TdHIBBQNhSWQFBHBtdEEJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJAQ5hc3NldElkRnJvbVN0cgEFA2JJZAUEcG10QgUDbmlsAwkAAAIFBXBUeXBlBQdTRl9QT09MCQD8BwQFCHBvb2xBZGRyAgxjYWxsRnVuY3Rpb24JAMwIAgIWcmVwbGVuaXNoV2l0aFR3b1Rva2VucwkAzAgCCQDMCAICBWZhbHNlCQDMCAICATAFA25pbAUDbmlsBQhwYXltZW50cwMJAAACBQVwVHlwZQUHV1hfUE9PTAkA/AcEBQhwb29sQWRkcgIDcHV0CQDMCAIAwIQ9CQDMCAIHBQNuaWwFCHBheW1lbnRzCQEPdW5rbm93blBvb2xUeXBlAAEXcmVwbGVuaXNoT25lVG9rZW5CeVR5cGUECHBvb2xBZGRyBXBUeXBlA3BtdAVwbXRJZAQIcGF5bWVudHMJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJAQ5hc3NldElkRnJvbVN0cgEFBXBtdElkBQNwbXQFA25pbAMJAAACBQVwVHlwZQUHU0ZfUE9PTAkA/AcEBQhwb29sQWRkcgIMY2FsbEZ1bmN0aW9uCQDMCAICFXJlcGxlbmlzaFdpdGhPbmVUb2tlbgkAzAgCCQDMCAICATAJAMwIAgIFZmFsc2UJAMwIAgIBMAUDbmlsBQNuaWwFCHBheW1lbnRzAwkAAAIFBXBUeXBlBQdXWF9QT09MCQD8BwQFCHBvb2xBZGRyAglwdXRPbmVUa24JAMwIAgAACQDMCAIHBQNuaWwFCHBheW1lbnRzCQEPdW5rbm93blBvb2xUeXBlAAEHc3Rha2VMUAQEcG9vbAVwVHlwZQdzaGFyZUlkBmFtb3VudAQIcGF5bWVudHMJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIJANkEAQUHc2hhcmVJZAUGYW1vdW50BQNuaWwDCQAAAgUFcFR5cGUFB1NGX1BPT0wJAPwHBAkBEGdldFNGRmFybWluZ0FkZHIAAg9sb2NrU2hhcmVUb2tlbnMJAMwIAgUEcG9vbAkAzAgCAAAFA25pbAUIcGF5bWVudHMDCQAAAgUFcFR5cGUFB1dYX1BPT0wJAPwHBAkBEGdldFdYRmFybWluZ0FkZHIBCQERQGV4dHJOYXRpdmUoMTA2MikBBQRwb29sAgVzdGFrZQUDbmlsBQhwYXltZW50cwkBD3Vua25vd25Qb29sVHlwZQABCXVuc3Rha2VMUAQEcG9vbAVwVHlwZQdzaGFyZUlkBmFtb3VudAQNJHQwMTQzNjYxNDcxNgMJAAACBQVwVHlwZQUHU0ZfUE9PTAkAlQoDCQEQZ2V0U0ZGYXJtaW5nQWRkcgACE3dpdGhkcmF3U2hhcmVUb2tlbnMJAMwIAgUEcG9vbAkAzAgCBQZhbW91bnQFA25pbAMJAAACBQVwVHlwZQUHV1hfUE9PTAkAlQoDCQEQZ2V0V1hGYXJtaW5nQWRkcgEJAQdBZGRyZXNzAQkA2QQBBQRwb29sAgd1bnN0YWtlCQDMCAIFB3NoYXJlSWQJAMwIAgUGYW1vdW50BQNuaWwJAQ91bmtub3duUG9vbFR5cGUABAhmYXJtQWRkcggFDSR0MDE0MzY2MTQ3MTYCXzEEBWZOYW1lCAUNJHQwMTQzNjYxNDcxNgJfMgQGcGFyYW1zCAUNJHQwMTQzNjYxNDcxNgJfMwQDaW52CQD8BwQFCGZhcm1BZGRyBQVmTmFtZQUGcGFyYW1zBQNuaWwDCQAAAgUDaW52BQNpbnYFBmFtb3VudAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgERY2FsY0Ftb3VudFRvUGF5U0YHBHBvb2wIYXNzZXRJZEEIYXNzZXRJZEIEYmFsQQRiYWxCEGFtb3VudFRva2VuVG9HZXQPYXNzZXRUb2tlblRvR2V0BAhwb29sQWRkcgkBB0FkZHJlc3MBCQDZBAEFBHBvb2wECWZlZVNjYWxlNgDAhD0EA2ZlZQkBEUBleHRyTmF0aXZlKDEwNTApAgUIcG9vbEFkZHIFCmtTRlBvb2xGZWUEDGFtbnRHZXROb0ZlZQkAbgQFEGFtb3VudFRva2VuVG9HZXQFCWZlZVNjYWxlNgkAZQIFCWZlZVNjYWxlNgUDZmVlBQdDRUlMSU5HBA0kdDAxNTEzODE1NDQ0AwkAAAIFD2Fzc2V0VG9rZW5Ub0dldAUIYXNzZXRJZEEEC2Ftb3VudFRvUGF5CQBuBAUMYW1udEdldE5vRmVlBQRiYWxCCQBlAgUEYmFsQQUMYW1udEdldE5vRmVlBQdDRUlMSU5HCQCUCgIFC2Ftb3VudFRvUGF5BQhhc3NldElkQgQLYW1vdW50VG9QYXkJAG4EBQxhbW50R2V0Tm9GZWUFBGJhbEEJAGUCBQRiYWxCBQxhbW50R2V0Tm9GZWUFB0NFSUxJTkcJAJQKAgULYW1vdW50VG9QYXkFCGFzc2V0SWRBBAthbW91bnRUb1BheQgFDSR0MDE1MTM4MTU0NDQCXzEECmFzc2V0VG9QYXkIBQ0kdDAxNTEzODE1NDQ0Al8yCQCUCgIFCmFzc2V0VG9QYXkFC2Ftb3VudFRvUGF5ARFjYWxjQW1vdW50VG9QYXlXWAcEcG9vbAhhc3NldElkQQhhc3NldElkQgRiYWxBBGJhbEIQYW1vdW50VG9rZW5Ub0dldA9hc3NldFRva2VuVG9HZXQEBXByRmVlCQERQGV4dHJOYXRpdmUoMTA1MCkCBQ53eFN3YXBDb250cmFjdAIPJXNfX3Byb3RvY29sRmVlBARwRmVlCQERQGV4dHJOYXRpdmUoMTA1MCkCBQ53eFN3YXBDb250cmFjdAILJXNfX3Bvb2xGZWUECGZlZVNjYWxlCQC2AgEAgMLXLwQNJHQwMTU3ODMxNjA5MQMJAAACBQ9hc3NldFRva2VuVG9HZXQFCGFzc2V0SWRBBAthbW91bnRUb1BheQkAawMFEGFtb3VudFRva2VuVG9HZXQFBGJhbEIJAGUCBQRiYWxBBRBhbW91bnRUb2tlblRvR2V0CQCUCgIFC2Ftb3VudFRvUGF5BQhhc3NldElkQgQLYW1vdW50VG9QYXkJAGsDBRBhbW91bnRUb2tlblRvR2V0BQRiYWxBCQBlAgUEYmFsQgUQYW1vdW50VG9rZW5Ub0dldAkAlAoCBQthbW91bnRUb1BheQUIYXNzZXRJZEEEC2Ftb3VudFRvUGF5CAUNJHQwMTU3ODMxNjA5MQJfMQQKYXNzZXRUb1BheQgFDSR0MDE1NzgzMTYwOTECXzIEEmFtb3VudFRvUGF5V2l0aEZlZQkAoAMBCQC9AgQJALYCAQULYW1vdW50VG9QYXkFCGZlZVNjYWxlCQC4AgIFCGZlZVNjYWxlCQC2AgEJAGQCBQVwckZlZQUEcEZlZQUHQ0VJTElORwkAlAoCBQphc3NldFRvUGF5BRJhbW91bnRUb1BheVdpdGhGZWUBEGV4Y2hhbmdlRGlyZWN0bHkIBXBUeXBlBHBvb2wIYXNzZXRJZEEIYXNzZXRJZEIEYmFsQQRiYWxCEGFtb3VudFRva2VuVG9HZXQPYXNzZXRUb2tlblRvR2V0AwkAAAIFBXBUeXBlBQdTRl9QT09MBA0kdDAxNjQzODE2NTYwCQERY2FsY0Ftb3VudFRvUGF5U0YHBQRwb29sBQhhc3NldElkQQUIYXNzZXRJZEIFBGJhbEEFBGJhbEIFEGFtb3VudFRva2VuVG9HZXQFD2Fzc2V0VG9rZW5Ub0dldAQKYXNzZXRUb1BheQgFDSR0MDE2NDM4MTY1NjACXzEEC2Ftb3VudFRvUGF5CAUNJHQwMTY0MzgxNjU2MAJfMgkA/AcECQERQGV4dHJOYXRpdmUoMTA2MikBBQRwb29sAgxjYWxsRnVuY3Rpb24JAMwIAgIIZXhjaGFuZ2UJAMwIAgkAzAgCCQCkAwEFEGFtb3VudFRva2VuVG9HZXQFA25pbAUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQEOYXNzZXRJZEZyb21TdHIBBQphc3NldFRvUGF5BQthbW91bnRUb1BheQUDbmlsAwkAAAIFBXBUeXBlBQdXWF9QT09MBA0kdDAxNjc2MDE2ODgyCQERY2FsY0Ftb3VudFRvUGF5V1gHBQRwb29sBQhhc3NldElkQQUIYXNzZXRJZEIFBGJhbEEFBGJhbEIFEGFtb3VudFRva2VuVG9HZXQFD2Fzc2V0VG9rZW5Ub0dldAQKYXNzZXRUb1BheQgFDSR0MDE2NzYwMTY4ODICXzEEC2Ftb3VudFRvUGF5CAUNJHQwMTY3NjAxNjg4MgJfMgkA/AcEBQ53eFN3YXBDb250cmFjdAIEc3dhcAkAzAgCBRBhbW91bnRUb2tlblRvR2V0CQDMCAIFD2Fzc2V0VG9rZW5Ub0dldAkAzAgCCQClCAEFBHRoaXMFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkBDmFzc2V0SWRGcm9tU3RyAQUKYXNzZXRUb1BheQULYW1vdW50VG9QYXkFA25pbAkBD3Vua25vd25Qb29sVHlwZQABGmNhbGNXaXRoZHJhd0xQRnJvbVBvb2xWaXJ0BAhwb29sQWRkcgVwVHlwZQdzaGFyZUlkD3VzZXJDYW5XaXRoZHJhdwQNJHQwMTcxNjkxNzYwOAMJAAACBQVwVHlwZQUHU0ZfUE9PTAQDaW52CgABQAkA/AcEBQhwb29sQWRkcgIMY2FsbEZ1bmN0aW9uCQDMCAICEHdpdGhkcmF3UkVBRE9OTFkJAMwIAgkAzAgCCQCkAwEFD3VzZXJDYW5XaXRoZHJhdwUDbmlsBQNuaWwFA25pbAMJAAECBQFAAgooSW50LCBJbnQpBQFACQACAQkArAICCQADAQUBQAIfIGNvdWxkbid0IGJlIGNhc3QgdG8gKEludCwgSW50KQMJAAACBQNpbnYFA2ludgkAlAoCCAUDaW52Al8xCAUDaW52Al8yCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAwkAAAIFBXBUeXBlBQdXWF9QT09MBANpbnYJALUJAgoAAUAJAPwHBAUIcG9vbEFkZHICE2V2YWx1YXRlR2V0UkVBRE9OTFkJAMwIAgUHc2hhcmVJZAkAzAgCBQ91c2VyQ2FuV2l0aGRyYXcFA25pbAUDbmlsAwkAAQIFAUACBlN0cmluZwUBQAkAAgEJAKwCAgkAAwEFAUACGyBjb3VsZG4ndCBiZSBjYXN0IHRvIFN0cmluZwICX18DCQAAAgUDaW52BQNpbnYJAJQKAgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFA2ludgABCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUDaW52AAIJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAQ91bmtub3duUG9vbFR5cGUABAdhbW91bnRBCAUNJHQwMTcxNjkxNzYwOAJfMQQHYW1vdW50QggFDSR0MDE3MTY5MTc2MDgCXzIJAJQKAgUHYW1vdW50QQUHYW1vdW50QgELY2xhaW1GYXJtZWQCBXBUeXBlBHBvb2wDCQAAAgUFcFR5cGUFB1NGX1BPT0wECWJhbEJlZm9yZQkBDmFjY291bnRCYWxhbmNlAQUGU1dPUElEAwkAAAIFCWJhbEJlZm9yZQUJYmFsQmVmb3JlBANpbnYJAPwHBAkBEGdldFNGRmFybWluZ0FkZHIAAgVjbGFpbQkAzAgCBQRwb29sBQNuaWwFA25pbAMJAAACBQNpbnYFA2ludgQIYmFsQWZ0ZXIJAQ5hY2NvdW50QmFsYW5jZQEFBlNXT1BJRAkAlAoCCQBlAgUIYmFsQWZ0ZXIFCWJhbEJlZm9yZQUGU1dPUElECQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAwkAAAIFBXBUeXBlBQdXWF9QT09MBAliYWxCZWZvcmUJAQ5hY2NvdW50QmFsYW5jZQEFBFdYSUQDCQAAAgUJYmFsQmVmb3JlBQliYWxCZWZvcmUEA2ludgkA/AcECQEQZ2V0V1hGYXJtaW5nQWRkcgEJAQdBZGRyZXNzAQkA2QQBBQRwb29sAgdjbGFpbVdYCQDMCAIFBHBvb2wFA25pbAUDbmlsAwkAAAIFA2ludgUDaW52BAhiYWxBZnRlcgkBDmFjY291bnRCYWxhbmNlAQUEV1hJRAkAlAoCCQBlAgUIYmFsQWZ0ZXIFCWJhbEJlZm9yZQUEV1hJRAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkBD3Vua25vd25Qb29sVHlwZQABD3JlcGxlbmlzaEJ5VHlwZQoFcFR5cGUEcG9vbAdmZWVUeXBlBHBtdEEDYUlkBHBtdEIDYklkBGJhbEEEYmFsQgRMUElkBA9scEJhbGFuY2VCZWZvcmUJAQ5hY2NvdW50QmFsYW5jZQEJANkEAQUETFBJZAMJAAACBQ9scEJhbGFuY2VCZWZvcmUFD2xwQmFsYW5jZUJlZm9yZQQIcG9vbEFkZHIJARFAZXh0ck5hdGl2ZSgxMDYyKQEFBHBvb2wEDSR0MDE4NTczMTg5ODkDAwkAZgIFBHBtdEEAAAkAZgIFBHBtdEIAAAcEDSR0MDE4NjM5MTg3NTUJARhjYWxjUmVwbGVuaXNoQnlUd29Ub2tlbnMIBQVwVHlwZQUIcG9vbEFkZHIFBHBtdEEFA2FJZAUEcG10QgUDYklkBQRiYWxBBQRiYWxCBAZwbXRJbkEIBQ0kdDAxODYzOTE4NzU1Al8xBAZwbXRJbkIIBQ0kdDAxODYzOTE4NzU1Al8yBAZjaGFuZ2UIBQ0kdDAxODYzOTE4NzU1Al8zBAhjaGFuZ2VJZAgFDSR0MDE4NjM5MTg3NTUCXzQEA2ludgkBGHJlcGxlbmlzaFR3b1Rva2Vuc0J5VHlwZQYFCHBvb2xBZGRyBQVwVHlwZQUGcG10SW5BBQNhSWQFBnBtdEluQgUDYklkAwkAAAIFA2ludgUDaW52CQCUCgIFBmNoYW5nZQUIY2hhbmdlSWQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4DCQBmAgUEcG10QQAACQCUCgIFBHBtdEEFA2FJZAMJAGYCBQRwbXRCAAAJAJQKAgUEcG10QgUDYklkCQACAQIQcG10cyBtdXN0IGJlID4gMAQGY2hhbmdlCAUNJHQwMTg1NzMxODk4OQJfMQQIY2hhbmdlSWQIBQ0kdDAxODU3MzE4OTg5Al8yBANpbnYDCQBmAgUGY2hhbmdlAAAJARdyZXBsZW5pc2hPbmVUb2tlbkJ5VHlwZQQFCHBvb2xBZGRyBQVwVHlwZQUGY2hhbmdlBQhjaGFuZ2VJZAUDbmlsAwkAAAIFA2ludgUDaW52BA5scEJhbGFuY2VBZnRlcgkBDmFjY291bnRCYWxhbmNlAQkA2QQBBQRMUElkBAt0b3RhbFN0YWtlZAkAZQIFDmxwQmFsYW5jZUFmdGVyBQ9scEJhbGFuY2VCZWZvcmUEDWF4bHlGZWVBbW91bnQJAGsDBQt0b3RhbFN0YWtlZAkBCmdldEF4bHlGZWUCBQRwb29sBQdmZWVUeXBlBQpGRUVfU0NBTEU2BBF1c2VyU2hhcmVGb3JTdGFrZQkAZQIFC3RvdGFsU3Rha2VkBQ1heGx5RmVlQW1vdW50AwkAZwIAAAURdXNlclNoYXJlRm9yU3Rha2UJAAIBAihhbW91bnQgb2Ygc3Rha2VkIHNoYXJldG9rZW5zIG11c3QgYmUgPiAwBAVpbnZMUAkBB3N0YWtlTFAEBQRwb29sBQVwVHlwZQUETFBJZAURdXNlclNoYXJlRm9yU3Rha2UDCQAAAgUFaW52TFAFBWludkxQCQCUCgIFEXVzZXJTaGFyZUZvclN0YWtlBQ1heGx5RmVlQW1vdW50CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuARByZXBsZW5pc2hFbnRyaWVzCARwb29sBHVzZXIMc3Rha2VkQW1vdW50DWF4bHlGZWVBbW91bnQGcG9zTnVtB3NoYXJlSWQEdHlwZQh3aXRoTG9hbgQLdG90YWxBbW91bnQJARFnZXRQb29sVG90YWxTaGFyZQEFBHBvb2wED3RvdGFsQW1vdW50TG9hbgkBGWdldFBvb2xUb3RhbFNoYXJlV2l0aExvYW4BBQRwb29sBA0kdDAxOTg0NzIwMDg1AwUId2l0aExvYW4JAJQKAgkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwkArAICBQRwb29sBRFrUG9vbEludGVyZXN0TG9hbgkAZAIFD3RvdGFsQW1vdW50TG9hbgUMc3Rha2VkQW1vdW50CQCUCgIJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAKwCAgUEcG9vbAUTa1Bvb2xJbnRlcmVzdE5vTG9hbgUPdG90YWxBbW91bnRMb2FuBA9jdXJQb29sSW50ZXJlc3QIBQ0kdDAxOTg0NzIwMDg1Al8xBBN0b3RhbFN0YWtlZFdpdGhMb2FuCAUNJHQwMTk4NDcyMDA4NQJfMgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQRwb29sBQprUG9vbFRvdGFsCQBkAgULdG90YWxBbW91bnQFDHN0YWtlZEFtb3VudAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQRwb29sBQ5rUG9vbFRvdGFsTG9hbgUTdG90YWxTdGFrZWRXaXRoTG9hbgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBHBvb2wCAV8FBHVzZXICAV8JAKQDAQUGcG9zTnVtBQ1rVXNlclBvc2l0aW9uBQxzdGFrZWRBbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfCQCkAwEFBnBvc051bQUVa1VzZXJQb3NpdGlvbkludGVyZXN0BQ9jdXJQb29sSW50ZXJlc3QJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgIJAKwCAgUEdXNlcgIBXwkApAMBBQZwb3NOdW0FEWtVc2VyUG9zaXRpb25Qb29sBQRwb29sCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFBHVzZXIFEGtVc2VyUG9zaXRpb25OdW0FBnBvc051bQkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQhtb25leUJveAUNYXhseUZlZUFtb3VudAkA2QQBBQdzaGFyZUlkBQNuaWwBDmV4Y2hhbmdlS2VlcGVyCgd0b1Rva2VuCXBtdEFtb3VudAhwbXRBc3NldAlhbW91bnRzSW4JYWRkcmVzc2VzD2Fzc2V0c1RvUmVjZWl2ZQtlc3RSZWNlaXZlZBFzbGlwcGFnZVRvbGVyYW5jZQttaW5SZWNlaXZlZAdvcHRpb25zBBJ0b2tlbkJhbGFuY2VCZWZvcmUJAQ5hY2NvdW50QmFsYW5jZQEJAQ5hc3NldElkRnJvbVN0cgEFB3RvVG9rZW4DCQAAAgUSdG9rZW5CYWxhbmNlQmVmb3JlBRJ0b2tlbkJhbGFuY2VCZWZvcmUEA2ludgkA/AcEBQpleENvbnRyYWN0AgRzd2FwCQDMCAIFCWFtb3VudHNJbgkAzAgCBQlhZGRyZXNzZXMJAMwIAgUPYXNzZXRzVG9SZWNlaXZlCQDMCAIFC2VzdFJlY2VpdmVkCQDMCAIFEXNsaXBwYWdlVG9sZXJhbmNlCQDMCAIFC21pblJlY2VpdmVkCQDMCAIFB29wdGlvbnMFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUIcG10QXNzZXQFCXBtdEFtb3VudAUDbmlsAwkAAAIFA2ludgUDaW52CQBlAgkBDmFjY291bnRCYWxhbmNlAQkBDmFzc2V0SWRGcm9tU3RyAQUHdG9Ub2tlbgUSdG9rZW5CYWxhbmNlQmVmb3JlCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQ5leGNoYW5nZVB1enpsZQYHdG9Ub2tlbglwbXRBbW91bnQIcG10QXNzZXQJcm91dGVzU3RyDG1pblRvUmVjZWl2ZQdvcHRpb25zBBJ0b2tlbkJhbGFuY2VCZWZvcmUJAQ5hY2NvdW50QmFsYW5jZQEJAQ5hc3NldElkRnJvbVN0cgEFB3RvVG9rZW4DCQAAAgUSdG9rZW5CYWxhbmNlQmVmb3JlBRJ0b2tlbkJhbGFuY2VCZWZvcmUEA2ludgkA/AcEBQpleENvbnRyYWN0AgpwdXp6bGVTd2FwCQDMCAIFCXJvdXRlc1N0cgkAzAgCBQxtaW5Ub1JlY2VpdmUJAMwIAgUHb3B0aW9ucwUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQhwbXRBc3NldAUJcG10QW1vdW50BQNuaWwDCQAAAgUDaW52BQNpbnYJAGUCCQEOYWNjb3VudEJhbGFuY2UBCQEOYXNzZXRJZEZyb21TdHIBBQd0b1Rva2VuBRJ0b2tlbkJhbGFuY2VCZWZvcmUJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BDmV4Y2hhbmdlU3dvcEZpCgd0b1Rva2VuCXBtdEFtb3VudAhwbXRBc3NldApleGNoYW5nZXJzDmV4Y2hhbmdlcnNUeXBlBWFyZ3MxBWFyZ3MyEXJvdXRpbmdBc3NldHNLZXlzEm1pbkFtb3VudFRvUmVjZWl2ZQdvcHRpb25zBBJ0b2tlbkJhbGFuY2VCZWZvcmUJAQ5hY2NvdW50QmFsYW5jZQEJAQ5hc3NldElkRnJvbVN0cgEFB3RvVG9rZW4DCQAAAgUSdG9rZW5CYWxhbmNlQmVmb3JlBRJ0b2tlbkJhbGFuY2VCZWZvcmUEA2ludgkA/AcEBQpleENvbnRyYWN0Agpzd29wZmlTd2FwCQDMCAIFCmV4Y2hhbmdlcnMJAMwIAgUOZXhjaGFuZ2Vyc1R5cGUJAMwIAgUFYXJnczEJAMwIAgUFYXJnczIJAMwIAgURcm91dGluZ0Fzc2V0c0tleXMJAMwIAgUSbWluQW1vdW50VG9SZWNlaXZlCQDMCAIFB29wdGlvbnMFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUIcG10QXNzZXQFCXBtdEFtb3VudAUDbmlsAwkAAAIFA2ludgUDaW52CQBlAgkBDmFjY291bnRCYWxhbmNlAQkBDmFzc2V0SWRGcm9tU3RyAQUHdG9Ub2tlbgUSdG9rZW5CYWxhbmNlQmVmb3JlCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAQpjYXBpdGFsaXplBARwb29sBXBUeXBlB3Rva2VuSWQLdG9rZW5BbW91bnQECHBvb2xBZGRyCQEHQWRkcmVzcwEJANkEAQUEcG9vbAQNJHQwMjI0MzYyMjUwMgkBC2dldFBvb2xEYXRhAgUIcG9vbEFkZHIFBXBUeXBlBANBSWQIBQ0kdDAyMjQzNjIyNTAyAl8xBANCSWQIBQ0kdDAyMjQzNjIyNTAyAl8yBARiYWxBCAUNJHQwMjI0MzYyMjUwMgJfMwQEYmFsQggFDSR0MDIyNDM2MjI1MDICXzQEB3NoYXJlSWQIBQ0kdDAyMjQzNjIyNTAyAl81AwMJAQIhPQIFB3Rva2VuSWQFA0FJZAkBAiE9AgUHdG9rZW5JZAUDQklkBwkAAgECC1dyb25nIGFzc2V0BA0kdDAyMjU4NzIyNjY3AwkAAAIFB3Rva2VuSWQFA0FJZAkAlAoCBQt0b2tlbkFtb3VudAAACQCUCgIAAAULdG9rZW5BbW91bnQEBHBtdEEIBQ0kdDAyMjU4NzIyNjY3Al8xBARwbXRCCAUNJHQwMjI1ODcyMjY2NwJfMgQNJHQwMjI2NzAyMjc3NAkBD3JlcGxlbmlzaEJ5VHlwZQoFBXBUeXBlBQRwb29sBQZOT19GRUUFBHBtdEEFA0FJZAUEcG10QgUDQklkBQRiYWxBBQRiYWxCBQdzaGFyZUlkBAxzdGFrZWRBbW91bnQIBQ0kdDAyMjY3MDIyNzc0Al8xBAJuZggFDSR0MDIyNjcwMjI3NzQCXzIEE2N1clBvb2xJbnRlcmVzdExvYW4JAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkArAICBQRwb29sBRFrUG9vbEludGVyZXN0TG9hbgAABBVjdXJQb29sSW50ZXJlc3ROb0xvYW4JAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkArAICBQRwb29sBRNrUG9vbEludGVyZXN0Tm9Mb2FuAAAEEHRvdGFsU2hhcmVBbW91bnQJARFnZXRQb29sVG90YWxTaGFyZQEFBHBvb2wEGHRvdGFsU2hhcmVBbW91bnRXaXRoTG9hbgkBGWdldFBvb2xUb3RhbFNoYXJlV2l0aExvYW4BBQRwb29sBAtsb2FuUGVyY2VudAkAawMFGHRvdGFsU2hhcmVBbW91bnRXaXRoTG9hbgUGU0NBTEU4BRB0b3RhbFNoYXJlQW1vdW50BApzdGFrZWRMb2FuCQBrAwUMc3Rha2VkQW1vdW50BQtsb2FuUGVyY2VudAUGU0NBTEU4BAxzdGFrZWROb0xvYW4JAGUCBQxzdGFrZWRBbW91bnQFCnN0YWtlZExvYW4ED25ld0ludGVyZXN0TG9hbgMJAGYCBRh0b3RhbFNoYXJlQW1vdW50V2l0aExvYW4AAAkAZAIFE2N1clBvb2xJbnRlcmVzdExvYW4JAGsDBQpzdGFrZWRMb2FuBQdTQ0FMRTEwBRh0b3RhbFNoYXJlQW1vdW50V2l0aExvYW4AAAQRbmV3SW50ZXJlc3ROb0xvYW4DCQBmAgkAZQIFEHRvdGFsU2hhcmVBbW91bnQFGHRvdGFsU2hhcmVBbW91bnRXaXRoTG9hbgAACQBkAgUVY3VyUG9vbEludGVyZXN0Tm9Mb2FuCQBrAwUMc3Rha2VkTm9Mb2FuBQdTQ0FMRTEwCQBlAgUQdG90YWxTaGFyZUFtb3VudAUYdG90YWxTaGFyZUFtb3VudFdpdGhMb2FuAAAEC2F4bHlGZWVMb2FuCQBrAwUKc3Rha2VkTG9hbgkBCmdldEF4bHlGZWUCBQRwb29sBQxDQVBfRkVFX0xPQU4FCkZFRV9TQ0FMRTYEDWF4bHlGZWVOb0xvYW4JAGsDBQxzdGFrZWROb0xvYW4JAQpnZXRBeGx5RmVlAgUEcG9vbAUPQ0FQX0ZFRV9OT19MT0FOBQpGRUVfU0NBTEU2BAdheGx5RmVlCQEJdW5zdGFrZUxQBAUEcG9vbAUFcFR5cGUFB3NoYXJlSWQJAGQCBQtheGx5RmVlTG9hbgUNYXhseUZlZU5vTG9hbgMJAAACBQdheGx5RmVlBQdheGx5RmVlCQDOCAIJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUEcG9vbAURa1Bvb2xJbnRlcmVzdExvYW4FD25ld0ludGVyZXN0TG9hbgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQRwb29sBRNrUG9vbEludGVyZXN0Tm9Mb2FuBRFuZXdJbnRlcmVzdE5vTG9hbgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQRwb29sBQprUG9vbFRvdGFsCQBlAgkAZAIFEHRvdGFsU2hhcmVBbW91bnQFDHN0YWtlZEFtb3VudAUHYXhseUZlZQkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQRwb29sBQ5rUG9vbFRvdGFsTG9hbgkAZQIJAGQCBRh0b3RhbFNoYXJlQW1vdW50V2l0aExvYW4FCnN0YWtlZExvYW4FC2F4bHlGZWVMb2FuCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFCG1vbmV5Qm94CQBkAgULYXhseUZlZUxvYW4FDWF4bHlGZWVOb0xvYW4JANkEAQUHc2hhcmVJZAUDbmlsCQEOZ2V0Q3Vyc0VudHJpZXMEBQNBSWQFA0JJZAUHc2hhcmVJZAUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuARJ3aXRoZHJhd0Ftb3VudENhbGMFBHBvb2wPdXNlckNhbldpdGhkcmF3BGRlYnQLYm9ycm93QXNzZXQLc3RvcExvc3NGZWUECHBvb2xBZGRyCQEHQWRkcmVzcwEJANkEAQUEcG9vbAQFcFR5cGUJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzCQCsAgIFBWtQb29sBQRwb29sAgxVbmtub3duIHBvb2wEDSR0MDI0NTY0MjQ2NDAJAQtnZXRQb29sRGF0YQIFCHBvb2xBZGRyBQVwVHlwZQQIYXNzZXRJZEEIBQ0kdDAyNDU2NDI0NjQwAl8xBAhhc3NldElkQggFDSR0MDI0NTY0MjQ2NDACXzIEBGJhbEEIBQ0kdDAyNDU2NDI0NjQwAl8zBARiYWxCCAUNJHQwMjQ1NjQyNDY0MAJfNAQHc2hhcmVJZAgFDSR0MDI0NTY0MjQ2NDACXzUEC2NCYWxBQmVmb3JlCQEOYWNjb3VudEJhbGFuY2UBCQEOYXNzZXRJZEZyb21TdHIBBQhhc3NldElkQQMJAAACBQtjQmFsQUJlZm9yZQULY0JhbEFCZWZvcmUEC2NCYWxCQmVmb3JlCQEOYWNjb3VudEJhbGFuY2UBCQEOYXNzZXRJZEZyb21TdHIBBQhhc3NldElkQgMJAAACBQtjQmFsQkJlZm9yZQULY0JhbEJCZWZvcmUEA2ludgMJAAACBQVwVHlwZQUHU0ZfUE9PTAQDaW52CQEJdW5zdGFrZUxQBAUEcG9vbAUFcFR5cGUFB3NoYXJlSWQFC3N0b3BMb3NzRmVlAwkAAAIFA2ludgUDaW52CQD8BwQFCHBvb2xBZGRyAgxjYWxsRnVuY3Rpb24JAMwIAgIId2l0aGRyYXcJAMwIAgkAzAgCCQCkAwEFD3VzZXJDYW5XaXRoZHJhdwUDbmlsBQNuaWwFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgMJAAACBQVwVHlwZQUHV1hfUE9PTAQDaW52CQEJdW5zdGFrZUxQBAUEcG9vbAUFcFR5cGUFB3NoYXJlSWQJAGQCBQ91c2VyQ2FuV2l0aGRyYXcFC3N0b3BMb3NzRmVlAwkAAAIFA2ludgUDaW52CQD8BwQFCHBvb2xBZGRyAgNnZXQFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgkBDmFzc2V0SWRGcm9tU3RyAQUHc2hhcmVJZAUPdXNlckNhbldpdGhkcmF3BQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAQ91bmtub3duUG9vbFR5cGUAAwkAAAIFA2ludgUDaW52BApjQmFsQUFmdGVyCQEOYWNjb3VudEJhbGFuY2UBCQEOYXNzZXRJZEZyb21TdHIBBQhhc3NldElkQQQKY0JhbEJBZnRlcgkBDmFjY291bnRCYWxhbmNlAQkBDmFzc2V0SWRGcm9tU3RyAQUIYXNzZXRJZEIEDSR0MDI1MzMzMjU0MjIJAJQKAgkAZQIFCmNCYWxBQWZ0ZXIFC2NCYWxBQmVmb3JlCQBlAgUKY0JhbEJBZnRlcgULY0JhbEJCZWZvcmUEDXRva2Vuc0Ftb3VudEEIBQ0kdDAyNTMzMzI1NDIyAl8xBA10b2tlbnNBbW91bnRCCAUNJHQwMjUzMzMyNTQyMgJfMgQNJHQwMjU0MjUyNjI3OQMJAGYCBQRkZWJ0AAAEDWFtb3VudFRvR2V0RXgDAwkAAAIFC2JvcnJvd0Fzc2V0BQhhc3NldElkQQkAZgIFBGRlYnQFDXRva2Vuc0Ftb3VudEEHCQBlAgUEZGVidAUNdG9rZW5zQW1vdW50QQMDCQAAAgULYm9ycm93QXNzZXQFCGFzc2V0SWRCCQBmAgUEZGVidAUNdG9rZW5zQW1vdW50QgcJAGUCBQRkZWJ0BQ10b2tlbnNBbW91bnRCAAAEBWV4SW52AwkAZgIFDWFtb3VudFRvR2V0RXgAAAkBEGV4Y2hhbmdlRGlyZWN0bHkIBQVwVHlwZQUEcG9vbAUIYXNzZXRJZEEFCGFzc2V0SWRCCQBlAgUEYmFsQQUNdG9rZW5zQW1vdW50QQkAZQIFBGJhbEIFDXRva2Vuc0Ftb3VudEIFDWFtb3VudFRvR2V0RXgFC2JvcnJvd0Fzc2V0BQNuaWwDCQAAAgUFZXhJbnYFBWV4SW52BA9jQmFsQUFmdGVyUmVwYXkJAQ5hY2NvdW50QmFsYW5jZQEJAQ5hc3NldElkRnJvbVN0cgEFCGFzc2V0SWRBBA9jQmFsQkFmdGVyUmVwYXkJAQ5hY2NvdW50QmFsYW5jZQEJAQ5hc3NldElkRnJvbVN0cgEFCGFzc2V0SWRCAwkAAAIFC2JvcnJvd0Fzc2V0BQhhc3NldElkQQkAlAoCCQBlAgkAZQIFD2NCYWxBQWZ0ZXJSZXBheQULY0JhbEFCZWZvcmUFBGRlYnQJAGUCBQ9jQmFsQkFmdGVyUmVwYXkFC2NCYWxCQmVmb3JlCQCUCgIJAGUCBQ9jQmFsQUFmdGVyUmVwYXkFC2NCYWxBQmVmb3JlCQBlAgkAZQIFD2NCYWxCQWZ0ZXJSZXBheQULY0JhbEJCZWZvcmUFBGRlYnQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAJQKAgUNdG9rZW5zQW1vdW50QQUNdG9rZW5zQW1vdW50QgQHdG9Vc2VyQQgFDSR0MDI1NDI1MjYyNzkCXzEEB3RvVXNlckIIBQ0kdDAyNTQyNTI2Mjc5Al8yCQCXCgUFB3RvVXNlckEFCGFzc2V0SWRBBQd0b1VzZXJCBQhhc3NldElkQgUHc2hhcmVJZAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgEYdXNlckNhbldpdGhkcmF3U2hhcmVDYWxjBAR1c2VyBHBvb2wFcG9zSWQIYm9ycm93ZWQEB3BBbW91bnQJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAmggCBQR0aGlzCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUEcG9vbAIBXwUEdXNlcgIBXwUFcG9zSWQFDWtVc2VyUG9zaXRpb24CEFVua25vd24gcG9zaXRpb24EDHVzZXJJbnRlcmVzdAkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBHBvb2wCAV8FBHVzZXICAV8FBXBvc0lkBRVrVXNlclBvc2l0aW9uSW50ZXJlc3QEDHBvb2xJbnRlcmVzdAMFCGJvcnJvd2VkCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzCQCsAgIFBHBvb2wFEWtQb29sSW50ZXJlc3RMb2FuCQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzCQCsAgIFBHBvb2wFE2tQb29sSW50ZXJlc3ROb0xvYW4JAGQCBQdwQW1vdW50CQBrAwUHcEFtb3VudAkAZQIFDHBvb2xJbnRlcmVzdAUMdXNlckludGVyZXN0BQdTQ0FMRTEwAQ53aXRoZHJhd1RvVXNlcgQEdXNlcgRwb29sBXBvc0lkCHN0b3BMb3NzBAdwQW1vdW50CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJoIAgUEdGhpcwkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBHBvb2wCAV8FBHVzZXICAV8FBXBvc0lkBQ1rVXNlclBvc2l0aW9uAhBVbmtub3duIHBvc2l0aW9uBAxib3Jyb3dBbW91bnQJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBHBvb2wCAV8FBHVzZXICAV8FBXBvc0lkBRFrVXNlckJvcnJvd0Ftb3VudAAABA91c2VyQ2FuV2l0aGRyYXcJARh1c2VyQ2FuV2l0aGRyYXdTaGFyZUNhbGMEBQR1c2VyBQRwb29sBQVwb3NJZAkAZgIFDGJvcnJvd0Ftb3VudAAABA5wb29sVG90YWxTaGFyZQkBEWdldFBvb2xUb3RhbFNoYXJlAQUEcG9vbAQIdXNlckFkZHIJAQdBZGRyZXNzAQkA2QQBBQR1c2VyBAtib3Jyb3dBc3NldAkBC3ZhbHVlT3JFbHNlAgkAnQgCBQR0aGlzCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUEcG9vbAIBXwUEdXNlcgIBXwUFcG9zSWQFEmtVc2VyQm9ycm93QXNzZXRJZAIABA0kdDAyNzQ3NzI3NzExAwkAZgIFDGJvcnJvd0Ftb3VudAAACQCUCgIKAAFACQD8BwQJAQ5nZXRMZW5kU3J2QWRkcgACDGdldEFzc2V0RGVidAkAzAgCBwkAzAgCCQCsAgIJAKwCAgUEdXNlcgIBXwUFcG9zSWQJAMwIAgULYm9ycm93QXNzZXQFA25pbAUDbmlsAwkAAQIFAUACA0ludAUBQAkAAgEJAKwCAgkAAwEFAUACGCBjb3VsZG4ndCBiZSBjYXN0IHRvIEludAUNU1RPUExPU1NfTE9BTgkAlAoCAAAFFFNUT1BMT1NTX0ZFRV9OT19MT0FOBARkZWJ0CAUNJHQwMjc0NzcyNzcxMQJfMQQHZmVlVHlwZQgFDSR0MDI3NDc3Mjc3MTECXzIEC3N0b3BMb3NzRmVlAwUIc3RvcExvc3MJAGsDBQ91c2VyQ2FuV2l0aGRyYXcJAQpnZXRBeGx5RmVlAgUEcG9vbAUHZmVlVHlwZQUKRkVFX1NDQUxFNgAABA0kdDAyNzgyODI3OTg0CQESd2l0aGRyYXdBbW91bnRDYWxjBQUEcG9vbAkAZQIFD3VzZXJDYW5XaXRoZHJhdwULc3RvcExvc3NGZWUFBGRlYnQFC2JvcnJvd0Fzc2V0BQtzdG9wTG9zc0ZlZQMJAAACBQ0kdDAyNzgyODI3OTg0BQ0kdDAyNzgyODI3OTg0BAdzaGFyZUlkCAUNJHQwMjc4MjgyNzk4NAJfNQQIYXNzZXRJZEIIBQ0kdDAyNzgyODI3OTg0Al80BA10b1VzZXJBbW91bnRCCAUNJHQwMjc4MjgyNzk4NAJfMwQIYXNzZXRJZEEIBQ0kdDAyNzgyODI3OTg0Al8yBA10b1VzZXJBbW91bnRBCAUNJHQwMjc4MjgyNzk4NAJfMQQLY2xvc2VEYnRJbnYDCQBmAgUEZGVidAAACQD8BwQJAQ5nZXRMZW5kU3J2QWRkcgACCHJlcGF5Rm9yCQDMCAIJAKwCAgkArAICBQR1c2VyAgFfBQVwb3NJZAUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCCQEOYXNzZXRJZEZyb21TdHIBBQtib3Jyb3dBc3NldAUEZGVidAUDbmlsAAADCQAAAgULY2xvc2VEYnRJbnYFC2Nsb3NlRGJ0SW52CQDOCAIJAMwIAgkBC0RlbGV0ZUVudHJ5AQkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBHBvb2wCAV8FBHVzZXICAV8FBXBvc0lkBQ1rVXNlclBvc2l0aW9uCQDMCAIJAQtEZWxldGVFbnRyeQEJAKwCAgkArAICCQCsAgIFBHVzZXICAV8FBXBvc0lkBRFrVXNlclBvc2l0aW9uUG9vbAkAzAgCCQELRGVsZXRlRW50cnkBCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUEcG9vbAIBXwUEdXNlcgIBXwUFcG9zSWQFEWtVc2VyQm9ycm93QW1vdW50CQDMCAIJAQtEZWxldGVFbnRyeQEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfBQVwb3NJZAUSa1VzZXJCb3Jyb3dBc3NldElkCQDMCAIJAQtEZWxldGVFbnRyeQEJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfBQVwb3NJZAUVa1VzZXJQb3NpdGlvbkludGVyZXN0CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFBHBvb2wFCmtQb29sVG90YWwJAGUCCQBlAgUOcG9vbFRvdGFsU2hhcmUFD3VzZXJDYW5XaXRoZHJhdwULc3RvcExvc3NGZWUJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUIdXNlckFkZHIFDXRvVXNlckFtb3VudEEJAQ5hc3NldElkRnJvbVN0cgEFCGFzc2V0SWRBCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMFCHVzZXJBZGRyBQ10b1VzZXJBbW91bnRCCQEOYXNzZXRJZEZyb21TdHIBBQhhc3NldElkQgkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQhtb25leUJveAULc3RvcExvc3NGZWUJANkEAQUHc2hhcmVJZAUDbmlsCQEOZ2V0Q3Vyc0VudHJpZXMEBQhhc3NldElkQQUIYXNzZXRJZEIFB3NoYXJlSWQFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgEMcGFyc2VSZXF1ZXN0AQlyZXF1ZXN0SWQEB3JlcXVlc3QJALUJAgkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMJAKwCAgUJcmVxdWVzdElkBQprUmVxdWVzdElkCQCsAgICE05vIHJlcXVlc3Qgd2l0aCBpZCAFCXJlcXVlc3RJZAIBLAQEdXNlcgkAkQMCBQdyZXF1ZXN0AAAEBHBvb2wJAJEDAgUHcmVxdWVzdAABBARwbXRBCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUHcmVxdWVzdAACBANBSWQJAJEDAgUHcmVxdWVzdAADBARwbXRCCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUHcmVxdWVzdAAEBANCSWQJAJEDAgUHcmVxdWVzdAAFBARiYWxBCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUHcmVxdWVzdAAGBARiYWxCCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUHcmVxdWVzdAAHBAdzaGFyZUlkCQCRAwIFB3JlcXVlc3QACAQHYndBc3NldAkAkQMCBQdyZXF1ZXN0AAkECGJ3QW1vdW50CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUHcmVxdWVzdAAKCQCdCgsFBHVzZXIFBHBvb2wFBHBtdEEFA0FJZAUEcG10QgUDQklkBQRiYWxBBQRiYWxCBQdzaGFyZUlkBQdid0Fzc2V0BQhid0Ftb3VudAEQY2FsY0JvcnJvd0Ftb3VudAYEcG10QQRwbXRCA2FJZANiSWQIbGV2ZXJhZ2UIYm9ycm93SWQDAwkBAiE9AgUIYm9ycm93SWQFA2FJZAkBAiE9AgUIYm9ycm93SWQFA2JJZAcJAAIBAhJXcm9uZyBib3Jyb3cgYXNzZXQEB2RQcmljZUEJARFAZXh0ck5hdGl2ZSgxMDUwKQIFD3ByaWNlT3JhY2xlQWRkcgkArAICBQNhSWQFDmtQcmljZUluT3JhY2xlBAdkUHJpY2VCCQERQGV4dHJOYXRpdmUoMTA1MCkCBQ9wcmljZU9yYWNsZUFkZHIJAKwCAgUDYklkBQ5rUHJpY2VJbk9yYWNsZQQGZGVjUHJBCQBsBgAKAAAJARBnZXRBc3NldERlY2ltYWxzAQUDYUlkAAAAAAUERE9XTgQGZGVjUHJCCQBsBgAKAAAJARBnZXRBc3NldERlY2ltYWxzAQUDYklkAAAAAAUERE9XTgQMcGF5ZEluRG9sbGFyCQBkAgkAawMFB2RQcmljZUEFBHBtdEEFBmRlY1ByQQkAawMFB2RQcmljZUIFBHBtdEIFBmRlY1ByQgQNJHQwMjk5ODkzMDA4NgMJAAACBQhib3Jyb3dJZAUDYUlkCQCUCgIFB2RQcmljZUEFBmRlY1ByQQkAlAoCBQdkUHJpY2VCBQZkZWNQckIEC2JvcnJvd1ByaWNlCAUNJHQwMjk5ODkzMDA4NgJfMQQLYm9ycm93RGVjUHIIBQ0kdDAyOTk4OTMwMDg2Al8yCQBrAwkAawMFDHBheWRJbkRvbGxhcgkAZQIFCGxldmVyYWdlAGQAZAULYm9ycm93RGVjUHIFC2JvcnJvd1ByaWNlARJwYXJzZVJlcGxlbmlzaFBtdHMDBHBtdHMDQUlkA0JJZAMJAAACCQCQAwEFBHBtdHMAAgMJAQIhPQIJAQxhc3NldElkVG9TdHIBCAkAkQMCBQRwbXRzAAAHYXNzZXRJZAUDQUlkCQACAQIVV3JvbmcgcGF5bWVudCBhc3NldCBBAwkBAiE9AgkBDGFzc2V0SWRUb1N0cgEICQCRAwIFBHBtdHMAAQdhc3NldElkBQNCSWQJAAIBAhVXcm9uZyBwYXltZW50IGFzc2V0IEIJAJQKAggJAJEDAgUEcG10cwAABmFtb3VudAgJAJEDAgUEcG10cwABBmFtb3VudAMJAAACCQCQAwEFBHBtdHMAAQMJAAACCQEMYXNzZXRJZFRvU3RyAQgJAJEDAgUEcG10cwAAB2Fzc2V0SWQFA0FJZAkAlAoCCAkAkQMCBQRwbXRzAAAGYW1vdW50AAADCQAAAgkBDGFzc2V0SWRUb1N0cgEICQCRAwIFBHBtdHMAAAdhc3NldElkBQNCSWQJAJQKAgAACAkAkQMCBQRwbXRzAAAGYW1vdW50CQACAQINV3JvbmcgcGF5bWVudAkAAgECHE9uZSBvciB0d28gcGF5bWVudHMgZXhwZWN0ZWQBD2NhbGNQcmljZUltcGFjdAQEYmFsQQRiYWxCB25ld0JhbEEHbmV3QmFsQgQDcHJpCQBoAgkAZQIFBlNDQUxFOAkAawMJAGsDBQRiYWxCBQZTQ0FMRTgFBGJhbEEFBlNDQUxFOAkAawMFB25ld0JhbEIFBlNDQUxFOAUHbmV3QmFsQQBkAwkAZgIAAAUDcHJpCQBoAgUDcHJpAP///////////wEFA3ByaQETY2xhaW1BbmRDaGVja0FtbnRFeAUEcG9vbAVwVHlwZQVjbGFpbRBhbW91bnRUb0V4Y2hhbmdlBmNoYW5nZQQNJHQwMzExMDAzMTM4NwMFBWNsYWltCQELY2xhaW1GYXJtZWQCBQVwVHlwZQUEcG9vbAQMY2xhaW1lZEFzc2V0AwkAAAIFBXBUeXBlBQdTRl9QT09MBQZTV09QSUQDCQAAAgUFcFR5cGUFB1dYX1BPT0wFBFdYSUQJAQ91bmtub3duUG9vbFR5cGUACQCUCgIFEGFtb3VudFRvRXhjaGFuZ2UFDGNsYWltZWRBc3NldAQLY2xhaW1BbW91bnQIBQ0kdDAzMTEwMDMxMzg3Al8xBApjbGFpbUFzc2V0CAUNJHQwMzExMDAzMTM4NwJfMgMJAGYCBRBhbW91bnRUb0V4Y2hhbmdlCQBkAgULY2xhaW1BbW91bnQFBmNoYW5nZQkAAgECGVRvIGJpZyBhbW91bnQgdG8gZXhjaGFuZ2UJAJQKAgULY2xhaW1BbW91bnQFCmNsYWltQXNzZXQaAWkBGmdldFNoYXJlQXNzZXRQcmljZVJFQURPTkxZAQdzaGFyZUlkBAtzaGFyZVByaWNlcwkBDWdldFNoYXJlUHJpY2UBBQdzaGFyZUlkCQCUCgIFA25pbAULc2hhcmVQcmljZXMBaQEiZ2V0VXNlclBvc2l0aW9uU2hhcmVBbW91bnRSRUFET05MWQIEdXNlcgZwb3NOdW0EBHBvb2wJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzCQCsAgIJAKwCAgkArAICBQR1c2VyAgFfBQZwb3NOdW0FEWtVc2VyUG9zaXRpb25Qb29sAhBVbmtub3duIHBvc2l0aW9uBAxib3Jyb3dBbW91bnQJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfBQZwb3NOdW0FEWtVc2VyQm9ycm93QW1vdW50BA91c2VyQ2FuV2l0aGRyYXcJARh1c2VyQ2FuV2l0aGRyYXdTaGFyZUNhbGMEBQR1c2VyBQRwb29sBQZwb3NOdW0JAGYCBQxib3Jyb3dBbW91bnQAAAkAlAoCBQNuaWwFD3VzZXJDYW5XaXRoZHJhdwFpASBnZXRVc2VyUG9zaXRpb25JbkRvbGxhcnNSRUFET05MWQMEdXNlcgVwb29scwZwb3NOdW0KAQd1c2VyUG9zAgFhBHBvb2wEDSR0MDMyMjgzMzIzMTcFAWEECHRvdGFsUG9zCAUNJHQwMzIyODMzMjMxNwJfMQQHcG9zRGVidAgFDSR0MDMyMjgzMzIzMTcCXzIEBWluZGV4CAUNJHQwMzIyODMzMjMxNwJfMwQFcFR5cGUJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzCQCsAgIFBWtQb29sBQRwb29sAhJQb29sIGlzIG5vdCBpbml0ZWQEDSR0MDMyNDA5MzI0OTkJAQtnZXRQb29sRGF0YQIJAQdBZGRyZXNzAQkA2QQBBQRwb29sBQVwVHlwZQQDQUlkCAUNJHQwMzI0MDkzMjQ5OQJfMQQDQklkCAUNJHQwMzI0MDkzMjQ5OQJfMgQEYmFsQQgFDSR0MDMyNDA5MzI0OTkCXzMEBGJhbEIIBQ0kdDAzMjQwOTMyNDk5Al80BAdzaGFyZUlkCAUNJHQwMzI0MDkzMjQ5OQJfNQQMYm9ycm93QW1vdW50CQELdmFsdWVPckVsc2UCCQCaCAIFBHRoaXMJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfCQCRAwIFBnBvc051bQUFaW5kZXgFEWtVc2VyQm9ycm93QW1vdW50AAADCQEBIQEJAQlpc0RlZmluZWQBCQCaCAIFBHRoaXMJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfCQCRAwIFBnBvc051bQUFaW5kZXgFDWtVc2VyUG9zaXRpb24JAJUKAwkAzQgCBQh0b3RhbFBvcwAACQDNCAIFB3Bvc0RlYnQAAAkAZAIFBWluZGV4AAEED3VzZXJDYW5XaXRoZHJhdwkBGHVzZXJDYW5XaXRoZHJhd1NoYXJlQ2FsYwQFBHVzZXIFBHBvb2wJAJEDAgUGcG9zTnVtBQVpbmRleAkAZgIFDGJvcnJvd0Ftb3VudAAABAtzaGFyZVByaWNlcwkBDWdldFNoYXJlUHJpY2UBBQdzaGFyZUlkBApkZWNQclNoYXJlCQBsBgAKAAAJARBnZXRBc3NldERlY2ltYWxzAQUHc2hhcmVJZAAAAAAFBERPV04EBnNoYXJlRAkAawMFD3VzZXJDYW5XaXRoZHJhdwULc2hhcmVQcmljZXMFCmRlY1ByU2hhcmUDCQAAAgUMYm9ycm93QW1vdW50AAAJAJUKAwkAzQgCBQh0b3RhbFBvcwUGc2hhcmVECQDNCAIFB3Bvc0RlYnQAAAkAZAIFBWluZGV4AAEEC2JvcnJvd0Fzc2V0CQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUEcG9vbAIBXwUEdXNlcgIBXwkAkQMCBQZwb3NOdW0FBWluZGV4BRJrVXNlckJvcnJvd0Fzc2V0SWQEBGRlYnQKAAFACQD8BwQJAQ5nZXRMZW5kU3J2QWRkcgACDGdldEFzc2V0RGVidAkAzAgCBwkAzAgCCQCsAgIJAKwCAgUEdXNlcgIBXwkAkQMCBQZwb3NOdW0FBWluZGV4CQDMCAIFC2JvcnJvd0Fzc2V0BQNuaWwFA25pbAMJAAECBQFAAgNJbnQFAUAJAAIBCQCsAgIJAAMBBQFAAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQEEGJvcnJvd0Fzc2V0UHJpY2UJARFAZXh0ck5hdGl2ZSgxMDUwKQIFD3ByaWNlT3JhY2xlQWRkcgkArAICBQtib3Jyb3dBc3NldAUOa1ByaWNlSW5PcmFjbGUEDWRlY1ByQm9ycm93SWQJAGwGAAoAAAkBEGdldEFzc2V0RGVjaW1hbHMBBQtib3Jyb3dBc3NldAAAAAAFBERPV04EBWRlYnRECQBrAwUEZGVidAUQYm9ycm93QXNzZXRQcmljZQUNZGVjUHJCb3Jyb3dJZAkAlQoDCQDNCAIFCHRvdGFsUG9zBQZzaGFyZUQJAM0IAgUHcG9zRGVidAUFZGVidEQJAGQCBQVpbmRleAABBA0kdDAzMzY2MzMzNzE4CgACJGwFBXBvb2xzCgACJHMJAJADAQUCJGwKAAUkYWNjMAkAlQoDBQNuaWwFA25pbAAACgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQd1c2VyUG9zAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAyMAkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKAAsADAANAA4ADwAQABEAEgATABQEA3BvcwgFDSR0MDMzNjYzMzM3MTgCXzEEBGRlYnQIBQ0kdDAzMzY2MzMzNzE4Al8yCQCUCgIFA25pbAkAlAoCBQNwb3MFBGRlYnQBaQEJcmVwbGVuaXNoAwRwb29sCGxldmVyYWdlCGJvcnJvd0lkCQELdmFsdWVPckVsc2UCCQEQaXNBY3RpdmVGb3JVc2VycwADAwkAZgIAZAUIbGV2ZXJhZ2UGCQBmAgUIbGV2ZXJhZ2UArAIJAAIBAh9MZXZlcmFnZSBjYW4ndCBiZSA8MTAwIGFuZCA+MzAwAwMJAQEhAQkBEUBleHRyTmF0aXZlKDEwNTEpAgUEdGhpcwkArAICBQRwb29sBQ5rUG9vbENhbkJvcnJvdwkAZgIFCGxldmVyYWdlAGQHCQACAQIdWW91IGNhbid0IGJvcnJvdyBpbiB0aGlzIHBvb2wEBXBUeXBlCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwkArAICBQVrUG9vbAUEcG9vbAISUG9vbCBpcyBub3QgaW5pdGVkBA0kdDAzNDE4OTM0Mjc5CQELZ2V0UG9vbERhdGECCQEHQWRkcmVzcwEJANkEAQUEcG9vbAUFcFR5cGUEA0FJZAgFDSR0MDM0MTg5MzQyNzkCXzEEA0JJZAgFDSR0MDM0MTg5MzQyNzkCXzIEBGJhbEEIBQ0kdDAzNDE4OTM0Mjc5Al8zBARiYWxCCAUNJHQwMzQxODkzNDI3OQJfNAQHc2hhcmVJZAgFDSR0MDM0MTg5MzQyNzkCXzUDAwkBAiE9AgUIYm9ycm93SWQFA0FJZAkBAiE9AgUIYm9ycm93SWQFA0JJZAcJAAIBAhJXcm9uZyBib3Jyb3cgYXNzZXQEDSR0MDM0MzYwMzQ0MTkJARJwYXJzZVJlcGxlbmlzaFBtdHMDCAUBaQhwYXltZW50cwUDQUlkBQNCSWQEBHBtdEEIBQ0kdDAzNDM2MDM0NDE5Al8xBARwbXRCCAUNJHQwMzQzNjAzNDQxOQJfMgQEdXNlcgkApQgBCAUBaQZjYWxsZXIECW5ld1Bvc051bQkBGGdldE5ld1VzZXJQb3NpdGlvbk51bWJlcgEFBHVzZXIDCQBmAgUIbGV2ZXJhZ2UAZAQMYm9ycm93QW1vdW50CQEQY2FsY0JvcnJvd0Ftb3VudAYFBHBtdEEFBHBtdEIFA0FJZAUDQklkBQhsZXZlcmFnZQUIYm9ycm93SWQEB3JlcXVlc3QJALkJAgkAzAgCBQR1c2VyCQDMCAIFBHBvb2wJAMwIAgkApAMBBQRwbXRBCQDMCAIFA0FJZAkAzAgCCQCkAwEFBHBtdEIJAMwIAgUDQklkCQDMCAIJAKQDAQUEYmFsQQkAzAgCCQCkAwEFBGJhbEIJAMwIAgUHc2hhcmVJZAkAzAgCBQhib3Jyb3dJZAkAzAgCCQCkAwEFDGJvcnJvd0Ftb3VudAUDbmlsAgEsBAxuZXdSZXF1ZXN0SWQKAAFACQD8BwQFBHRoaXMCEGNyZWF0ZU5ld1JlcXVlc3QJAMwIAgUHcmVxdWVzdAUDbmlsBQNuaWwDCQABAgUBQAIDSW50BQFACQACAQkArAICCQADAQUBQAIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50AwkAAAIFDG5ld1JlcXVlc3RJZAUMbmV3UmVxdWVzdElkBARhcmdzCQDMCAIJAKwCAgkArAICBQR1c2VyAgFfCQCkAwEFCW5ld1Bvc051bQkAzAgCBQdzaGFyZUlkCQDMCAIFCGJvcnJvd0lkCQDMCAIFDGJvcnJvd0Ftb3VudAkAzAgCCQClCAEFBHRoaXMJAMwIAgIRcmVwbGVuaXNoRnJvbUxhbmQJAMwIAgkApAMBCQETdmFsdWVPckVycm9yTWVzc2FnZQIFDG5ld1JlcXVlc3RJZAIYQ2FuJ3QgY3JlYXRlIG5ldyByZXF1ZXN0BQNuaWwEA2ludgkA/QcECQEOZ2V0TGVuZFNydkFkZHIAAg1mbGFzaFBvc2l0aW9uBQRhcmdzBQNuaWwDCQAAAgUDaW52BQNpbnYECnVzZXJTdGFrZWQJARFAZXh0ck5hdGl2ZSgxMDUwKQIFBHRoaXMJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfCQCkAwEFCW5ld1Bvc051bQUNa1VzZXJQb3NpdGlvbgQNJHQwMzU0MDgzNTUwMgkBD2dldFBvb2xCYWxhbmNlcwQJAQdBZGRyZXNzAQkA2QQBBQRwb29sBQVwVHlwZQUDQUlkBQNCSWQDCQAAAgUNJHQwMzU0MDgzNTUwMgUNJHQwMzU0MDgzNTUwMgQHbmV3QmFsQggFDSR0MDM1NDA4MzU1MDICXzIEB25ld0JhbEEIBQ0kdDAzNTQwODM1NTAyAl8xBAhwckltcGFjdAkBD2NhbGNQcmljZUltcGFjdAQFBGJhbEEFBGJhbEIFB25ld0JhbEEFB25ld0JhbEIEDSR0MDM1NTcyMzU2ODcJARpjYWxjV2l0aGRyYXdMUEZyb21Qb29sVmlydAQJAQdBZGRyZXNzAQkA2QQBBQRwb29sBQVwVHlwZQUHc2hhcmVJZAUKdXNlclN0YWtlZAQId0Ftb3VudEEIBQ0kdDAzNTU3MjM1Njg3Al8xBAh3QW1vdW50QggFDSR0MDM1NTcyMzU2ODcCXzIJAJQKAgUDbmlsCQDMCAIFCHBySW1wYWN0CQDMCAIFCHdBbW91bnRBCQDMCAIFCHdBbW91bnRCBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4EDSR0MDM1NzQwMzU4NTUJAQ9yZXBsZW5pc2hCeVR5cGUKBQVwVHlwZQUEcG9vbAULTk9fTE9BTl9GRUUFBHBtdEEFA0FJZAUEcG10QgUDQklkBQRiYWxBBQRiYWxCBQdzaGFyZUlkAwkAAAIFDSR0MDM1NzQwMzU4NTUFDSR0MDM1NzQwMzU4NTUEB2F4bHlGZWUIBQ0kdDAzNTc0MDM1ODU1Al8yBAp1c2VyU3Rha2VkCAUNJHQwMzU3NDAzNTg1NQJfMQQNJHQwMzU4NjEzNTk1NQkBD2dldFBvb2xCYWxhbmNlcwQJAQdBZGRyZXNzAQkA2QQBBQRwb29sBQVwVHlwZQUDQUlkBQNCSWQDCQAAAgUNJHQwMzU4NjEzNTk1NQUNJHQwMzU4NjEzNTk1NQQHbmV3QmFsQggFDSR0MDM1ODYxMzU5NTUCXzIEB25ld0JhbEEIBQ0kdDAzNTg2MTM1OTU1Al8xBAhwckltcGFjdAkBD2NhbGNQcmljZUltcGFjdAQFBGJhbEEFBGJhbEIFB25ld0JhbEEFB25ld0JhbEIEDSR0MDM2MDI1MzYxNDAJARpjYWxjV2l0aGRyYXdMUEZyb21Qb29sVmlydAQJAQdBZGRyZXNzAQkA2QQBBQRwb29sBQVwVHlwZQUHc2hhcmVJZAUKdXNlclN0YWtlZAQId0Ftb3VudEEIBQ0kdDAzNjAyNTM2MTQwAl8xBAh3QW1vdW50QggFDSR0MDM2MDI1MzYxNDACXzIJAJQKAgkAzggCCQEQcmVwbGVuaXNoRW50cmllcwgFBHBvb2wFBHVzZXIFCnVzZXJTdGFrZWQFB2F4bHlGZWUFCW5ld1Bvc051bQUHc2hhcmVJZAUFcFR5cGUHCQEOZ2V0Q3Vyc0VudHJpZXMEBQNBSWQFA0JJZAUHc2hhcmVJZAkAzAgCCQCkAwEFCHdBbW91bnRBCQDMCAIJAKQDAQUId0Ftb3VudEIFA25pbAkAzAgCBQhwckltcGFjdAkAzAgCBQh3QW1vdW50QQkAzAgCBQh3QW1vdW50QgUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBCHdpdGhkcmF3AgRwb29sBXBvc0lkCQELdmFsdWVPckVsc2UCCQEQaXNBY3RpdmVGb3JVc2VycwAJAQ53aXRoZHJhd1RvVXNlcgQJAKUIAQgFAWkGY2FsbGVyBQRwb29sCQCkAwEFBXBvc0lkBwFpARRjcmVhdGVVcGRhdGVTdG9wTG9zcwQFcG9zSWQGcG9vbElkB2Fzc2V0SWQFcHJpY2UJAQt2YWx1ZU9yRWxzZQIJARBpc0FjdGl2ZUZvclVzZXJzAAQQdG9rZW5PcmFjbGVQcmljZQkBEUBleHRyTmF0aXZlKDEwNTApAgUPcHJpY2VPcmFjbGVBZGRyCQCsAgIFB2Fzc2V0SWQFDmtQcmljZUluT3JhY2xlAwkBASEBCQEJaXNEZWZpbmVkAQkAmggCBQR0aGlzCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUGcG9vbElkAgFfCQClCAEIBQFpBmNhbGxlcgIBXwkApAMBBQVwb3NJZAUNa1VzZXJQb3NpdGlvbgkAAgECGlRoZXJlIGFyZSBubyB1c2VyIHBvc2l0aW9uAwkAZwIAAAUFcHJpY2UJAAIBAhxQcmljZSBtdXN0IGJlIGdyZWF0ZXIgdGhhbiAwAwkAZgIFBXByaWNlBRB0b2tlbk9yYWNsZVByaWNlCQACAQIrUHJpY2UgbXVzdCBiZSBsZXNzIHRoYW4gY3VycmVudCB0b2tlbiBwcmljZQkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQClCAEIBQFpBmNhbGxlcgIBXwkApAMBBQVwb3NJZAIBXwUGcG9vbElkAgFfBQdhc3NldElkBQ1rVXNlclN0b3BMb3NzBQVwcmljZQUDbmlsAWkBDmRlbGV0ZVN0b3BMb3NzAwVwb3NJZAZwb29sSWQHYXNzZXRJZAkBC3ZhbHVlT3JFbHNlAgkBEGlzQWN0aXZlRm9yVXNlcnMAAwkBASEBCQEJaXNEZWZpbmVkAQkAmggCBQR0aGlzCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKUIAQgFAWkGY2FsbGVyAgFfCQCkAwEFBXBvc0lkAgFfBQZwb29sSWQCAV8FB2Fzc2V0SWQFDWtVc2VyU3RvcExvc3MJAAIBAghObyBlbnRyeQkAzAgCCQELRGVsZXRlRW50cnkBCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKUIAQgFAWkGY2FsbGVyAgFfCQCkAwEFBXBvc0lkAgFfBQZwb29sSWQCAV8FB2Fzc2V0SWQFDWtVc2VyU3RvcExvc3MFA25pbAFpAQRpbml0CQxtb25leUJveEFkZHINc2ZGYXJtaW5nQWRkcghsZW5kQWRkcg9wcmljZU9yYWNsZUFkZHIQa2VlcGVyRXhDb250cmFjdA53eFN3YXBDb250cmFjdAtzd29wQXNzZXRJZAl3eEFzc2V0SWQLYWRtaW5QdWJLZXkDCQECIT0CCQClCAEIBQFpBmNhbGxlcgIjM1BHNDJ5NkZnVDh6TTN1WDV0RUR4SkY1cnFYOEFLR0pSQVIJAAIBAiFPbmx5IGFkbWluIGNhbiBjYWxsIHRoaXMgZnVuY3Rpb24DCQEJaXNEZWZpbmVkAQkAoggBBQxrQWRtaW5DYWxsUEsJAAIBAg5BbHJlYWR5IGluaXRlZAkAzAgCCQELU3RyaW5nRW50cnkCBQlrTW9uZXlCb3gFDG1vbmV5Qm94QWRkcgkAzAgCCQELU3RyaW5nRW50cnkCBQ5rU0ZGYXJtaW5nQWRkcgUNc2ZGYXJtaW5nQWRkcgkAzAgCCQELU3RyaW5nRW50cnkCBQxrTGVuZFNlcnZpY2UFCGxlbmRBZGRyCQDMCAIJAQtTdHJpbmdFbnRyeQIFDGtQcmljZU9yYWNsZQUPcHJpY2VPcmFjbGVBZGRyCQDMCAIJAQtTdHJpbmdFbnRyeQIFC2tFeENvbnRyYWN0BRBrZWVwZXJFeENvbnRyYWN0CQDMCAIJAQtTdHJpbmdFbnRyeQIFD2tXeFN3YXBDb250cmFjdAUOd3hTd2FwQ29udHJhY3QJAMwIAgkBC1N0cmluZ0VudHJ5AgUHa1N3b3BJZAULc3dvcEFzc2V0SWQJAMwIAgkBC1N0cmluZ0VudHJ5AgUFa1d4SWQFCXd4QXNzZXRJZAkAzAgCCQELU3RyaW5nRW50cnkCBQxrQWRtaW5DYWxsUEsFC2FkbWluUHViS2V5BQNuaWwBaQEQY3JlYXRlTmV3UmVxdWVzdAEGcGFyYW1zCQELdmFsdWVPckVsc2UCCQEKaXNTZWxmQ2FsbAEFAWkEDG5ld1JlcXVlc3RJZAkAZAIJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwUMa1JlcXVlc3RJdGVyAAAAAQkAlAoCCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgkApAMBBQxuZXdSZXF1ZXN0SWQFCmtSZXF1ZXN0SWQFBnBhcmFtcwkAzAgCCQEMSW50ZWdlckVudHJ5AgUMa1JlcXVlc3RJdGVyBQxuZXdSZXF1ZXN0SWQFA25pbAUMbmV3UmVxdWVzdElkAWkBEXJlcGxlbmlzaEZyb21MYW5kAQlyZXF1ZXN0SWQJAQt2YWx1ZU9yRWxzZQIJAQhpc0FjdGl2ZQAJAQt2YWx1ZU9yRWxzZQIJAQppc0xhbmRDYWxsAQUBaQQNJHQwMzg5MDkzOTAxMwkBDHBhcnNlUmVxdWVzdAEFCXJlcXVlc3RJZAQEdXNlcggFDSR0MDM4OTA5MzkwMTMCXzEEBHBvb2wIBQ0kdDAzODkwOTM5MDEzAl8yBARwbXRBCAUNJHQwMzg5MDkzOTAxMwJfMwQDQUlkCAUNJHQwMzg5MDkzOTAxMwJfNAQEcG10QggFDSR0MDM4OTA5MzkwMTMCXzUEA0JJZAgFDSR0MDM4OTA5MzkwMTMCXzYEBGJhbEEIBQ0kdDAzODkwOTM5MDEzAl83BARiYWxCCAUNJHQwMzg5MDkzOTAxMwJfOAQHc2hhcmVJZAgFDSR0MDM4OTA5MzkwMTMCXzkEB2J3QXNzZXQIBQ0kdDAzODkwOTM5MDEzA18xMAQIYndBbW91bnQIBQ0kdDAzODkwOTM5MDEzA18xMQMJAQIhPQIJAJADAQgFAWkIcGF5bWVudHMAAQkAAgECEldyb25nIHBheW1lbnQgc2l6ZQMDCQECIT0CCQEMYXNzZXRJZFRvU3RyAQgJAJEDAggFAWkIcGF5bWVudHMAAAdhc3NldElkBQdid0Fzc2V0BgkBAiE9AggJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQFCGJ3QW1vdW50CQACAQINV3JvbmcgcGF5bWVudAQNJHQwMzkyMDMzOTMwMwMJAAACBQNBSWQFB2J3QXNzZXQJAJQKAgkAZAIFBHBtdEEFCGJ3QW1vdW50BQRwbXRCCQCUCgIFBHBtdEEJAGQCBQRwbXRCBQhid0Ftb3VudAQHcG10QWxsQQgFDSR0MDM5MjAzMzkzMDMCXzEEB3BtdEFsbEIIBQ0kdDAzOTIwMzM5MzAzAl8yBAVwVHlwZQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCdCAIFBHRoaXMJAKwCAgUFa1Bvb2wFBHBvb2wCDFVua25vd24gcG9vbAQNJHQwMzkzODUzOTUwMAkBD3JlcGxlbmlzaEJ5VHlwZQoFBXBUeXBlBQRwb29sBQhMT0FOX0ZFRQUHcG10QWxsQQUDQUlkBQdwbXRBbGxCBQNCSWQFBGJhbEEFBGJhbEIFB3NoYXJlSWQECnVzZXJTdGFrZWQIBQ0kdDAzOTM4NTM5NTAwAl8xBAdheGx5RmVlCAUNJHQwMzkzODUzOTUwMAJfMgQGcG9zTnVtCQEYZ2V0TmV3VXNlclBvc2l0aW9uTnVtYmVyAQUEdXNlcgQNYm9ycm93RW50cmllcwkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBHBvb2wCAV8FBHVzZXICAV8JAKQDAQUGcG9zTnVtBRFrVXNlckJvcnJvd0Ftb3VudAUIYndBbW91bnQJAMwIAgkBC1N0cmluZ0VudHJ5AgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBHBvb2wCAV8FBHVzZXICAV8JAKQDAQUGcG9zTnVtBRJrVXNlckJvcnJvd0Fzc2V0SWQFB2J3QXNzZXQFA25pbAQHZW50cmllcwkBEHJlcGxlbmlzaEVudHJpZXMIBQRwb29sBQR1c2VyBQp1c2VyU3Rha2VkBQdheGx5RmVlBQZwb3NOdW0FB3NoYXJlSWQFBXBUeXBlBgQNJHQwMzk4NjAzOTk3NQkBGmNhbGNXaXRoZHJhd0xQRnJvbVBvb2xWaXJ0BAkBB0FkZHJlc3MBCQDZBAEFBHBvb2wFBXBUeXBlBQdzaGFyZUlkBQp1c2VyU3Rha2VkBAh3QW1vdW50QQgFDSR0MDM5ODYwMzk5NzUCXzEECHdBbW91bnRCCAUNJHQwMzk4NjAzOTk3NQJfMgkAlAoCCQDNCAIJAM4IAgkAzggCBQdlbnRyaWVzCQEOZ2V0Q3Vyc0VudHJpZXMEBQNBSWQFA0JJZAUHc2hhcmVJZAkAzAgCCQCkAwEFCHdBbW91bnRBCQDMCAIJAKQDAQUId0Ftb3VudEIFA25pbAUNYm9ycm93RW50cmllcwkBC0RlbGV0ZUVudHJ5AQkArAICBQlyZXF1ZXN0SWQFCmtSZXF1ZXN0SWQFCnVzZXJTdGFrZWQBaQEJbGlxdWlkYXRlAwR1c2VyBXBvc0lkD2xpcXVpZGF0ZUFtb3VudAkBC3ZhbHVlT3JFbHNlAgkBCGlzQWN0aXZlAAkBC3ZhbHVlT3JFbHNlAgkBCmlzTGFuZENhbGwBBQFpBARwb29sCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAJ0IAgUEdGhpcwkArAICCQCsAgIJAKwCAgUEdXNlcgIBXwUFcG9zSWQFEWtVc2VyUG9zaXRpb25Qb29sAgtubyBwb3NpdGlvbgQFcFR5cGUJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQR0aGlzCQCsAgIFBWtQb29sBQRwb29sAhJQb29sIGlzIG5vdCBpbml0ZWQEDSR0MDQwNDk2NDA1ODYJAQtnZXRQb29sRGF0YQIJAQdBZGRyZXNzAQkA2QQBBQRwb29sBQVwVHlwZQQDQUlkCAUNJHQwNDA0OTY0MDU4NgJfMQQDQklkCAUNJHQwNDA0OTY0MDU4NgJfMgQEYmFsQQgFDSR0MDQwNDk2NDA1ODYCXzMEBGJhbEIIBQ0kdDA0MDQ5NjQwNTg2Al80BAdzaGFyZUlkCAUNJHQwNDA0OTY0MDU4NgJfNQQGYW1vdW50CQEJdW5zdGFrZUxQBAUEcG9vbAUFcFR5cGUFB3NoYXJlSWQFD2xpcXVpZGF0ZUFtb3VudAQMYm9ycm93QW1vdW50CQERQGV4dHJOYXRpdmUoMTA1MCkCBQR0aGlzCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUEcG9vbAIBXwUEdXNlcgIBXwUFcG9zSWQFEWtVc2VyQm9ycm93QW1vdW50BAtib3Jyb3dBc3NldAkBEUBleHRyTmF0aXZlKDEwNTMpAgUEdGhpcwkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBHBvb2wCAV8FBHVzZXICAV8FBXBvc0lkBRJrVXNlckJvcnJvd0Fzc2V0SWQED3VzZXJDYW5XaXRoZHJhdwkBGHVzZXJDYW5XaXRoZHJhd1NoYXJlQ2FsYwQFBHVzZXIFBHBvb2wFBXBvc0lkCQBmAgUMYm9ycm93QW1vdW50AAADCQBmAgUPbGlxdWlkYXRlQW1vdW50BQ91c2VyQ2FuV2l0aGRyYXcJAAIBAidZb3UgY2FuJ3QgbGlxdWlkYXRlIG1vcmUgdGhhbiB1c2VyIGhhdmUDCQAAAgUMYm9ycm93QW1vdW50AAAJAAIBAitZb3UgY2FuJ3QgbGlxdWlkYXRlIHBvc2l0aW9uIHdpdGhvdXQgYm9ycm93CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUEcG9vbAIBXwUEdXNlcgIBXwUFcG9zSWQFFWtVc2VyUG9zaXRpb25JbnRlcmVzdAkBEUBleHRyTmF0aXZlKDEwNTApAgUEdGhpcwkArAICBQRwb29sBRFrUG9vbEludGVyZXN0TG9hbgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQRwb29sBQ5rUG9vbFRvdGFsTG9hbgkAZQIJARlnZXRQb29sVG90YWxTaGFyZVdpdGhMb2FuAQUEcG9vbAUPbGlxdWlkYXRlQW1vdW50CQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFBHBvb2wFCmtQb29sVG90YWwJAGUCCQERZ2V0UG9vbFRvdGFsU2hhcmUBBQRwb29sBQ9saXF1aWRhdGVBbW91bnQJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICBQRwb29sAgFfBQR1c2VyAgFfBQVwb3NJZAUNa1VzZXJQb3NpdGlvbgkAZQIFD3VzZXJDYW5XaXRoZHJhdwUPbGlxdWlkYXRlQW1vdW50CQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgUGYW1vdW50CQDZBAEFB3NoYXJlSWQFA25pbAFpAQhzdG9wTG9zcwQEdXNlcgVwb3NJZARwb29sB2Fzc2V0SWQJAQt2YWx1ZU9yRWxzZQIJAQhpc0FjdGl2ZQAJAQt2YWx1ZU9yRWxzZQIJAQtpc0FkbWluQ2FsbAEFAWkEEHRva2VuT3JhY2xlUHJpY2UJARFAZXh0ck5hdGl2ZSgxMDUwKQIFD3ByaWNlT3JhY2xlQWRkcgkArAICBQdhc3NldElkBQ5rUHJpY2VJbk9yYWNsZQMJAGYCBRB0b2tlbk9yYWNsZVByaWNlBRB0b2tlbk9yYWNsZVByaWNlCQACAQIjVG9rZW4gcHJpY2UgZ3JlYXRlciBzdG9wIGxvc3MgcHJpY2UDCQEBIQEJAQlpc0RlZmluZWQBCQCaCAIFBHRoaXMJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgUEdXNlcgIBXwkApAMBBQVwb3NJZAIBXwUEcG9vbAIBXwUHYXNzZXRJZAUNa1VzZXJTdG9wTG9zcwkAAgECCE5vIGVudHJ5CQDNCAIJAQ53aXRoZHJhd1RvVXNlcgQFBHVzZXIFBHBvb2wJAKQDAQUFcG9zSWQGCQELRGVsZXRlRW50cnkBCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIFBHVzZXICAV8JAKQDAQUFcG9zSWQCAV8FBHBvb2wCAV8FB2Fzc2V0SWQFDWtVc2VyU3RvcExvc3MBaQESY2FwaXRhbGl6ZUV4S2VlcGVyCwRwb29sCXRva2VuVG9JZBBhbW91bnRUb0V4Y2hhbmdlBWNsYWltCWFtb3VudHNJbglhZGRyZXNzZXMPYXNzZXRzVG9SZWNlaXZlC2VzdFJlY2VpdmVkEXNsaXBwYWdlVG9sZXJhbmNlC21pblJlY2VpdmVkB29wdGlvbnMJAQt2YWx1ZU9yRWxzZQIJAQhpc0FjdGl2ZQAJAQt2YWx1ZU9yRWxzZQIJAQtpc0FkbWluQ2FsbAEFAWkEBXBUeXBlCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzCQCsAgIFBWtQb29sBQRwb29sBAZjaGFuZ2UJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkArAICBQRwb29sBQ5rUG9vbENhcENoYW5nZQAABA0kdDA0MjY4MDQyNzgxCQETY2xhaW1BbmRDaGVja0FtbnRFeAUFBHBvb2wFBXBUeXBlBQVjbGFpbQUQYW1vdW50VG9FeGNoYW5nZQUGY2hhbmdlBA1jbGFpbWVkQW1vdW50CAUNJHQwNDI2ODA0Mjc4MQJfMQQMY2xhaW1lZEFzc2V0CAUNJHQwNDI2ODA0Mjc4MQJfMgQPZXhjaGFuZ2VkQW1vdW50CQEOZXhjaGFuZ2VLZWVwZXIKBQl0b2tlblRvSWQFEGFtb3VudFRvRXhjaGFuZ2UFDGNsYWltZWRBc3NldAUJYW1vdW50c0luBQlhZGRyZXNzZXMFD2Fzc2V0c1RvUmVjZWl2ZQULZXN0UmVjZWl2ZWQFEXNsaXBwYWdlVG9sZXJhbmNlBQttaW5SZWNlaXZlZAUHb3B0aW9ucwQJbmV3Q2hhbmdlCQBlAgkAZAIFDWNsYWltZWRBbW91bnQFBmNoYW5nZQUQYW1vdW50VG9FeGNoYW5nZQQLY2hhbmdlRW50cnkDCQBnAgUJbmV3Q2hhbmdlAAAJAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUEcG9vbAUOa1Bvb2xDYXBDaGFuZ2UFCW5ld0NoYW5nZQUDbmlsBQNuaWwJAM4IAgkBCmNhcGl0YWxpemUEBQRwb29sBQVwVHlwZQUJdG9rZW5Ub0lkBQ9leGNoYW5nZWRBbW91bnQFC2NoYW5nZUVudHJ5AWkBEmNhcGl0YWxpemVFeFB1enpsZQcEcG9vbAl0b2tlblRvSWQQYW1vdW50VG9FeGNoYW5nZQVjbGFpbQlyb3V0ZXNTdHIMbWluVG9SZWNlaXZlB29wdGlvbnMJAQt2YWx1ZU9yRWxzZQIJAQhpc0FjdGl2ZQAJAQt2YWx1ZU9yRWxzZQIJAQtpc0FkbWluQ2FsbAEFAWkEBXBUeXBlCQERQGV4dHJOYXRpdmUoMTA1MykCBQR0aGlzCQCsAgIFBWtQb29sBQRwb29sBAZjaGFuZ2UJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwkArAICBQRwb29sBQ5rUG9vbENhcENoYW5nZQAABA0kdDA0MzU1NjQzNjU3CQETY2xhaW1BbmRDaGVja0FtbnRFeAUFBHBvb2wFBXBUeXBlBQVjbGFpbQUQYW1vdW50VG9FeGNoYW5nZQUGY2hhbmdlBA1jbGFpbWVkQW1vdW50CAUNJHQwNDM1NTY0MzY1NwJfMQQMY2xhaW1lZEFzc2V0CAUNJHQwNDM1NTY0MzY1NwJfMgQPZXhjaGFuZ2VkQW1vdW50CQEOZXhjaGFuZ2VQdXp6bGUGBQl0b2tlblRvSWQFEGFtb3VudFRvRXhjaGFuZ2UFDGNsYWltZWRBc3NldAUJcm91dGVzU3RyBQxtaW5Ub1JlY2VpdmUFB29wdGlvbnMECW5ld0NoYW5nZQkAZQIJAGQCBQ1jbGFpbWVkQW1vdW50BQZjaGFuZ2UFEGFtb3VudFRvRXhjaGFuZ2UEC2NoYW5nZUVudHJ5AwkAZwIFCW5ld0NoYW5nZQAACQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFBHBvb2wFDmtQb29sQ2FwQ2hhbmdlBQluZXdDaGFuZ2UFA25pbAUDbmlsCQDOCAIJAQpjYXBpdGFsaXplBAUEcG9vbAUFcFR5cGUFCXRva2VuVG9JZAUPZXhjaGFuZ2VkQW1vdW50BQtjaGFuZ2VFbnRyeQFpARJjYXBpdGFsaXplRXhTd29wRmkLBHBvb2wJdG9rZW5Ub0lkEGFtb3VudFRvRXhjaGFuZ2UFY2xhaW0KZXhjaGFuZ2Vycw5leGNoYW5nZXJzVHlwZQVhcmdzMQVhcmdzMhFyb3V0aW5nQXNzZXRzS2V5cxJtaW5BbW91bnRUb1JlY2VpdmUHb3B0aW9ucwkBC3ZhbHVlT3JFbHNlAgkBCGlzQWN0aXZlAAkBC3ZhbHVlT3JFbHNlAgkBC2lzQWRtaW5DYWxsAQUBaQQFcFR5cGUJARFAZXh0ck5hdGl2ZSgxMDUzKQIFBHRoaXMJAKwCAgUFa1Bvb2wFBHBvb2wEBmNoYW5nZQkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzCQCsAgIFBHBvb2wFDmtQb29sQ2FwQ2hhbmdlAAAEDSR0MDQ0NDk5NDQ2MDAJARNjbGFpbUFuZENoZWNrQW1udEV4BQUEcG9vbAUFcFR5cGUFBWNsYWltBRBhbW91bnRUb0V4Y2hhbmdlBQZjaGFuZ2UEDWNsYWltZWRBbW91bnQIBQ0kdDA0NDQ5OTQ0NjAwAl8xBAxjbGFpbWVkQXNzZXQIBQ0kdDA0NDQ5OTQ0NjAwAl8yBA9leGNoYW5nZWRBbW91bnQJAQ5leGNoYW5nZVN3b3BGaQoFCXRva2VuVG9JZAUQYW1vdW50VG9FeGNoYW5nZQUMY2xhaW1lZEFzc2V0BQpleGNoYW5nZXJzBQ5leGNoYW5nZXJzVHlwZQUFYXJnczEFBWFyZ3MyBRFyb3V0aW5nQXNzZXRzS2V5cwUSbWluQW1vdW50VG9SZWNlaXZlBQdvcHRpb25zBAluZXdDaGFuZ2UJAGUCCQBkAgUNY2xhaW1lZEFtb3VudAUGY2hhbmdlBRBhbW91bnRUb0V4Y2hhbmdlBAtjaGFuZ2VFbnRyeQMJAGcCBQluZXdDaGFuZ2UAAAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQRwb29sBQ5rUG9vbENhcENoYW5nZQUJbmV3Q2hhbmdlBQNuaWwFA25pbAkAzggCCQEKY2FwaXRhbGl6ZQQFBHBvb2wFBXBUeXBlBQl0b2tlblRvSWQFD2V4Y2hhbmdlZEFtb3VudAULY2hhbmdlRW50cnkBaQELaW5pdE5ld1Bvb2wJBHR5cGUIcG9vbEFkZHILaW5GZWVOb0xvYW4JaW5GZWVMb2FuDGNhcEZlZU5vTG9hbg5jYXBGZWVXaXRoTG9hbhFzdG9wbG9zc0ZlZU5vTG9hbhNzdG9wbG9zc0ZlZVdpdGhMb2FuCWNhbkJvcnJvdwkBC3ZhbHVlT3JFbHNlAgkBCGlzQWN0aXZlAAkBC3ZhbHVlT3JFbHNlAgkBC2lzQWRtaW5DYWxsAQUBaQMDCQECIT0CBQR0eXBlBQdTRl9QT09MCQECIT0CBQR0eXBlBQdXWF9QT09MBwkAAgECCldyb25nIHR5cGUEDSR0MDQ1MzMxNDU0MjUJAQtnZXRQb29sRGF0YQIJAQdBZGRyZXNzAQkA2QQBBQhwb29sQWRkcgUEdHlwZQQDYUlkCAUNJHQwNDUzMzE0NTQyNQJfMQQDYklkCAUNJHQwNDUzMzE0NTQyNQJfMgQEYUJhbAgFDSR0MDQ1MzMxNDU0MjUCXzMEBGJCYWwIBQ0kdDA0NTMzMTQ1NDI1Al80BAdzaGFyZUlkCAUNJHQwNDUzMzE0NTQyNQJfNQMJAGYCAAAFC2luRmVlTm9Mb2FuCQACAQIiaW5GZWVOb0xvYW4gbXVzdCBiZSBncmVhdGVyIHRoYW4gMAMJAGYCAAAFCWluRmVlTG9hbgkAAgECIGluRmVlTG9hbiBtdXN0IGJlIGdyZWF0ZXIgdGhhbiAwAwkAZgIAAAUMY2FwRmVlTm9Mb2FuCQACAQIjY2FwRmVlTm9Mb2FuIG11c3QgYmUgZ3JlYXRlciB0aGFuIDADCQBmAgAABQ5jYXBGZWVXaXRoTG9hbgkAAgECJWNhcEZlZVdpdGhMb2FuIG11c3QgYmUgZ3JlYXRlciB0aGFuIDADCQBmAgAABRFzdG9wbG9zc0ZlZU5vTG9hbgkAAgECKHN0b3Bsb3NzRmVlTm9Mb2FuIG11c3QgYmUgZ3JlYXRlciB0aGFuIDADCQBmAgAABRNzdG9wbG9zc0ZlZVdpdGhMb2FuCQACAQIqc3RvcGxvc3NGZWVXaXRoTG9hbiBtdXN0IGJlIGdyZWF0ZXIgdGhhbiAwCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFCHBvb2xBZGRyBRVrQXhseUluRmVlV2l0aG91dExvYW4FC2luRmVlTm9Mb2FuCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFCHBvb2xBZGRyBRJrQXhseUluRmVlV2l0aExvYW4FCWluRmVlTG9hbgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQhwb29sQWRkcgURa0F4bHlOb0xvYW5DYXBGZWUFDGNhcEZlZU5vTG9hbgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQhwb29sQWRkcgUTa0F4bHlXaXRoTG9hbkNhcEZlZQUOY2FwRmVlV2l0aExvYW4JAMwIAgkBDEludGVnZXJFbnRyeQIJAKwCAgUIcG9vbEFkZHIFFmtBeGx5U3RvcExvc3NOb0xvYW5GZWUFEXN0b3Bsb3NzRmVlTm9Mb2FuCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQCsAgIFCHBvb2xBZGRyBRRrQXhseVN0b3BMb3NzTG9hbkZlZQUTc3RvcGxvc3NGZWVXaXRoTG9hbgkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQhwb29sQWRkcgURa1Bvb2xJbnRlcmVzdExvYW4AAAkAzAgCCQEMSW50ZWdlckVudHJ5AgkArAICBQhwb29sQWRkcgUTa1Bvb2xJbnRlcmVzdE5vTG9hbgAACQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgUFa1Bvb2wFCHBvb2xBZGRyBQR0eXBlCQDMCAIJAQtTdHJpbmdFbnRyeQIJAKwCAgUHc2hhcmVJZAUKa1NoYXJlUG9vbAUIcG9vbEFkZHIJAMwIAgkBDEJvb2xlYW5FbnRyeQIJAKwCAgUIcG9vbEFkZHIFDmtQb29sQ2FuQm9ycm93BQljYW5Cb3Jyb3cFA25pbAFpAQhhY3RpdmF0ZQAJAQt2YWx1ZU9yRWxzZQIJAQtpc0FkbWluQ2FsbAEFAWkDCQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMFB2tBY3RpdmUGCQACAQITZEFwcCBhbHJlYWR5IGFjdGl2ZQkAzAgCCQEMQm9vbGVhbkVudHJ5AgUHa0FjdGl2ZQYFA25pbAFpAQhzaHV0ZG93bgAJAQt2YWx1ZU9yRWxzZQIJAQtpc0FkbWluQ2FsbAEFAWkDCQEBIQEJAQt2YWx1ZU9yRWxzZQIJAJsIAgUEdGhpcwUHa0FjdGl2ZQYJAAIBAhVkQXBwIGFscmVhZHkgc2h1dGRvd24JAMwIAgkBDEJvb2xlYW5FbnRyeQIFB2tBY3RpdmUHBQNuaWwBaQEQYWN0aXZhdGVGb3JVc2VycwAJAQt2YWx1ZU9yRWxzZQIJAQtpc0FkbWluQ2FsbAEFAWkDCQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMFDGtBY3RpdmVVc2VycwYJAAIBAh1kQXBwIGFscmVhZHkgYWN0aXZlIGZvciB1c2VycwkAzAgCCQEMQm9vbGVhbkVudHJ5AgUHa0FjdGl2ZQYFA25pbAFpARBzaHV0ZG93bkZvclVzZXJzAAkBC3ZhbHVlT3JFbHNlAgkBC2lzQWRtaW5DYWxsAQUBaQMJAQEhAQkBC3ZhbHVlT3JFbHNlAgkAmwgCBQR0aGlzBQxrQWN0aXZlVXNlcnMGCQACAQIfZEFwcCBhbHJlYWR5IHNodXRkb3duIGZvciB1c2VycwkAzAgCCQEMQm9vbGVhbkVudHJ5AgUHa0FjdGl2ZQcFA25pbAFpAQphY3RpdmF0ZVNGAAkBC3ZhbHVlT3JFbHNlAgkBC2lzQWRtaW5DYWxsAQUBaQMJAQt2YWx1ZU9yRWxzZQIJAJsIAgUEdGhpcwkArAICBQdTRl9QT09MBQtrQWN0aXZlU0ZXWAYJAAIBAhVTV09QRkkgYWxyZWFkeSBhY3RpdmUJAMwIAgkBDEJvb2xlYW5FbnRyeQIFB2tBY3RpdmUGBQNuaWwBaQEKc2h1dGRvd25TRgAJAQt2YWx1ZU9yRWxzZQIJAQtpc0FkbWluQ2FsbAEFAWkDCQEBIQEJAQt2YWx1ZU9yRWxzZQIJAJsIAgUEdGhpcwkArAICBQdTRl9QT09MBQtrQWN0aXZlU0ZXWAYJAAIBAhdTV09QRkkgYWxyZWFkeSBzaHV0ZG93bgkAzAgCCQEMQm9vbGVhbkVudHJ5AgUHa0FjdGl2ZQcFA25pbAFpAQphY3RpdmF0ZVdYAAkBC3ZhbHVlT3JFbHNlAgkBC2lzQWRtaW5DYWxsAQUBaQMJAQt2YWx1ZU9yRWxzZQIJAJsIAgUEdGhpcwkArAICBQdXWF9QT09MBQtrQWN0aXZlU0ZXWAYJAAIBAhFXWCBhbHJlYWR5IGFjdGl2ZQkAzAgCCQEMQm9vbGVhbkVudHJ5AgUHa0FjdGl2ZQYFA25pbAFpAQpzaHV0ZG93bldYAAkBC3ZhbHVlT3JFbHNlAgkBC2lzQWRtaW5DYWxsAQUBaQMJAQEhAQkBC3ZhbHVlT3JFbHNlAgkAmwgCBQR0aGlzCQCsAgIFB1dYX1BPT0wFC2tBY3RpdmVTRldYBgkAAgECE1dYIGFscmVhZHkgc2h1dGRvd24JAMwIAgkBDEJvb2xlYW5FbnRyeQIFB2tBY3RpdmUHBQNuaWwBaQEMYWN0aXZhdGVQb29sAQRwb29sCQELdmFsdWVPckVsc2UCCQELaXNBZG1pbkNhbGwBBQFpAwkBASEBCQEJaXNEZWZpbmVkAQkAnQgCBQR0aGlzCQCsAgIFBWtQb29sBQRwb29sCQACAQIMVW5rbm93biBwb29sAwkBC3ZhbHVlT3JFbHNlAgkAmwgCBQR0aGlzCQCsAgIFBHBvb2wFC2tQb29sQWN0aXZlBgkAAgECE1Bvb2wgYWxyZWFkeSBhY3RpdmUJAMwIAgkBDEJvb2xlYW5FbnRyeQIFB2tBY3RpdmUGBQNuaWwBaQEMc2h1dGRvd25Qb29sAQRwb29sCQELdmFsdWVPckVsc2UCCQELaXNBZG1pbkNhbGwBBQFpAwkBASEBCQEJaXNEZWZpbmVkAQkAnQgCBQR0aGlzCQCsAgIFBWtQb29sBQRwb29sCQACAQIMVW5rbm93biBwb29sAwkBASEBCQELdmFsdWVPckVsc2UCCQCbCAIFBHRoaXMJAKwCAgUEcG9vbAULa1Bvb2xBY3RpdmUGCQACAQIVUG9vbCBhbHJlYWR5IHNodXRkb3duCQDMCAIJAQxCb29sZWFuRW50cnkCBQdrQWN0aXZlBwUDbmlsAQJ0eAEGdmVyaWZ5AAkA9AMDCAUCdHgJYm9keUJ5dGVzCQCRAwIIBQJ0eAZwcm9vZnMAAAgFAnR4D3NlbmRlclB1YmxpY0tledEdj0U=", "height": 2674055, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: GE8Q5syFYAaH7jxsXH1nNjEXFaFLCaZwEFRzJUEiB4U5 Next: GcqP6R7ct1uNxW47L3RMfT3kn1oXUYdE3xHmE2KZ9EUy Diff:
OldNewDifferences
8989
9090 let kPriceInOracle = "_twap5B"
9191
92+let kActive = "active"
93+
94+let kActiveUsers = "activeUsers"
95+
96+let kActiveSFWX = "_active"
97+
98+let kPoolActive = "_activePool"
99+
92100 let kUserStopLoss = "_stopLoss"
93101
94102 let kMoneyBox = "axly_money_box"
145153 else throw("Only land contract can call this function")
146154
147155
156+func isActive () = if ((valueOrElse(getBoolean(this, kActive), true) == true))
157+ then unit
158+ else throw("DApp is inactive at this moment")
159+
160+
161+func isActiveForUsers () = if (if (valueOrElse(getBoolean(this, kActive), true))
162+ then (valueOrElse(getBoolean(this, kActiveUsers), true) == true)
163+ else false)
164+ then unit
165+ else throw("DApp is inactive for users at this moment")
166+
167+
168+func isPoolActive (pool,type) = {
169+ let WXSFActive = valueOrElse(getBoolean(this, (type + kActiveSFWX)), true)
170+ let poolActive = valueOrElse(getBoolean(this, (pool + kPoolActive)), true)
171+ if (if (WXSFActive)
172+ then poolActive
173+ else false)
174+ then true
175+ else false
176+ }
177+
178+
148179 func accountBalance (assetId) = match assetId {
149180 case id: ByteVector =>
150181 assetBalance(this, id)
179210
180211
181212 func getSFPoolData (poolAddr) = {
182- let $t061796228 = getSFPoolBalances(poolAddr)
183- if (($t061796228 == $t061796228))
213+ let $t070647113 = getSFPoolBalances(poolAddr)
214+ if (($t070647113 == $t070647113))
184215 then {
185- let balB = $t061796228._2
186- let balA = $t061796228._1
216+ let balB = $t070647113._2
217+ let balA = $t070647113._1
187218 $Tuple5(valueOrErrorMessage(getString(poolAddr, kSFPoolAAssetId), "Can't get pool A asset id"), valueOrErrorMessage(getString(poolAddr, kSFPoolBAssetId), "Can't get pool B asset id"), balA, balB, valueOrErrorMessage(getString(poolAddr, kSFPoolShareId), "Can't get share asset id"))
188219 }
189220 else throw("Strict value is not equal to itself.")
217248 then @
218249 else unit
219250 }, "Can't get pool LP asset id")
220- let $t069256984 = getWXPoolBalances(poolAddr, aId, bId)
221- if (($t069256984 == $t069256984))
251+ let $t078107869 = getWXPoolBalances(poolAddr, aId, bId)
252+ if (($t078107869 == $t078107869))
222253 then {
223- let balB = $t069256984._2
224- let balA = $t069256984._1
254+ let balB = $t078107869._2
255+ let balA = $t078107869._1
225256 $Tuple5(aId, bId, balA, balB, shareId)
226257 }
227258 else throw("Strict value is not equal to itself.")
329360 let pool = valueOrErrorMessage(getString(this, (shareId + kSharePool)), "Can't find pool addr by share id")
330361 let poolAddr = Address(fromBase58String(pool))
331362 let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited")
332- let $t0996210027 = getPoolData(poolAddr, pType)
333- let aId = $t0996210027._1
334- let bId = $t0996210027._2
335- let aBalance = $t0996210027._3
336- let bBalance = $t0996210027._4
363+ let $t01084710912 = getPoolData(poolAddr, pType)
364+ let aId = $t01084710912._1
365+ let bId = $t01084710912._2
366+ let aBalance = $t01084710912._3
367+ let bBalance = $t01084710912._4
337368 let dPriceA = getIntegerValue(priceOracleAddr, (aId + kPriceInOracle))
338369 let dPriceB = getIntegerValue(priceOracleAddr, (bId + kPriceInOracle))
339370 let shareSupply = getShareSupply(poolAddr, pType, shareId)
405436 }
406437 else if ((pType == WX_POOL))
407438 then {
408- let $t01157211822 = $Tuple2(split({
439+ let $t01245712707 = $Tuple2(split({
409440 let @ = invoke(poolAddr, "evaluatePutByAmountAssetREADONLY", [pmtA], nil)
410441 if ($isInstanceOf(@, "String"))
411442 then @
416447 then @
417448 else throw(($getType(@) + " couldn't be cast to String"))
418449 }, "__"))
419- if (($t01157211822 == $t01157211822))
450+ if (($t01245712707 == $t01245712707))
420451 then {
421- let evalPutInB = $t01157211822._2
422- let evalPutInA = $t01157211822._1
452+ let evalPutInB = $t01245712707._2
453+ let evalPutInA = $t01245712707._1
423454 let lpInA = parseIntValue(evalPutInA[1])
424455 let lpInB = parseIntValue(evalPutInB[1])
425456 if ((lpInB > lpInA))
468499
469500
470501 func unstakeLP (pool,pType,shareId,amount) = {
471- let $t01348113831 = if ((pType == SF_POOL))
502+ let $t01436614716 = if ((pType == SF_POOL))
472503 then $Tuple3(getSFFarmingAddr(), "withdrawShareTokens", [pool, amount])
473504 else if ((pType == WX_POOL))
474505 then $Tuple3(getWXFarmingAddr(Address(fromBase58String(pool))), "unstake", [shareId, amount])
475506 else unknownPoolType()
476- let farmAddr = $t01348113831._1
477- let fName = $t01348113831._2
478- let params = $t01348113831._3
507+ let farmAddr = $t01436614716._1
508+ let fName = $t01436614716._2
509+ let params = $t01436614716._3
479510 let inv = invoke(farmAddr, fName, params, nil)
480511 if ((inv == inv))
481512 then amount
488519 let feeScale6 = 1000000
489520 let fee = getIntegerValue(poolAddr, kSFPoolFee)
490521 let amntGetNoFee = fraction(amountTokenToGet, feeScale6, (feeScale6 - fee), CEILING)
491- let $t01425314559 = if ((assetTokenToGet == assetIdA))
522+ let $t01513815444 = if ((assetTokenToGet == assetIdA))
492523 then {
493524 let amountToPay = fraction(amntGetNoFee, balB, (balA - amntGetNoFee), CEILING)
494525 $Tuple2(amountToPay, assetIdB)
497528 let amountToPay = fraction(amntGetNoFee, balA, (balB - amntGetNoFee), CEILING)
498529 $Tuple2(amountToPay, assetIdA)
499530 }
500- let amountToPay = $t01425314559._1
501- let assetToPay = $t01425314559._2
531+ let amountToPay = $t01513815444._1
532+ let assetToPay = $t01513815444._2
502533 $Tuple2(assetToPay, amountToPay)
503534 }
504535
507538 let prFee = getIntegerValue(wxSwapContract, "%s__protocolFee")
508539 let pFee = getIntegerValue(wxSwapContract, "%s__poolFee")
509540 let feeScale = toBigInt(100000000)
510- let $t01489815206 = if ((assetTokenToGet == assetIdA))
541+ let $t01578316091 = if ((assetTokenToGet == assetIdA))
511542 then {
512543 let amountToPay = fraction(amountTokenToGet, balB, (balA - amountTokenToGet))
513544 $Tuple2(amountToPay, assetIdB)
516547 let amountToPay = fraction(amountTokenToGet, balA, (balB - amountTokenToGet))
517548 $Tuple2(amountToPay, assetIdA)
518549 }
519- let amountToPay = $t01489815206._1
520- let assetToPay = $t01489815206._2
550+ let amountToPay = $t01578316091._1
551+ let assetToPay = $t01578316091._2
521552 let amountToPayWithFee = toInt(fraction(toBigInt(amountToPay), feeScale, (feeScale - toBigInt((prFee + pFee))), CEILING))
522553 $Tuple2(assetToPay, amountToPayWithFee)
523554 }
525556
526557 func exchangeDirectly (pType,pool,assetIdA,assetIdB,balA,balB,amountTokenToGet,assetTokenToGet) = if ((pType == SF_POOL))
527558 then {
528- let $t01555315675 = calcAmountToPaySF(pool, assetIdA, assetIdB, balA, balB, amountTokenToGet, assetTokenToGet)
529- let assetToPay = $t01555315675._1
530- let amountToPay = $t01555315675._2
559+ let $t01643816560 = calcAmountToPaySF(pool, assetIdA, assetIdB, balA, balB, amountTokenToGet, assetTokenToGet)
560+ let assetToPay = $t01643816560._1
561+ let amountToPay = $t01643816560._2
531562 invoke(addressFromStringValue(pool), "callFunction", ["exchange", [toString(amountTokenToGet)]], [AttachedPayment(assetIdFromStr(assetToPay), amountToPay)])
532563 }
533564 else if ((pType == WX_POOL))
534565 then {
535- let $t01587515997 = calcAmountToPayWX(pool, assetIdA, assetIdB, balA, balB, amountTokenToGet, assetTokenToGet)
536- let assetToPay = $t01587515997._1
537- let amountToPay = $t01587515997._2
566+ let $t01676016882 = calcAmountToPayWX(pool, assetIdA, assetIdB, balA, balB, amountTokenToGet, assetTokenToGet)
567+ let assetToPay = $t01676016882._1
568+ let amountToPay = $t01676016882._2
538569 invoke(wxSwapContract, "swap", [amountTokenToGet, assetTokenToGet, toString(this)], [AttachedPayment(assetIdFromStr(assetToPay), amountToPay)])
539570 }
540571 else unknownPoolType()
541572
542573
543574 func calcWithdrawLPFromPoolVirt (poolAddr,pType,shareId,userCanWithdraw) = {
544- let $t01628416723 = if ((pType == SF_POOL))
575+ let $t01716917608 = if ((pType == SF_POOL))
545576 then {
546577 let inv = {
547578 let @ = invoke(poolAddr, "callFunction", ["withdrawREADONLY", [toString(userCanWithdraw)]], nil)
566597 else throw("Strict value is not equal to itself.")
567598 }
568599 else unknownPoolType()
569- let amountA = $t01628416723._1
570- let amountB = $t01628416723._2
600+ let amountA = $t01716917608._1
601+ let amountB = $t01716917608._2
571602 $Tuple2(amountA, amountB)
572603 }
573604
610641 if ((lpBalanceBefore == lpBalanceBefore))
611642 then {
612643 let poolAddr = addressFromStringValue(pool)
613- let $t01768818104 = if (if ((pmtA > 0))
644+ let $t01857318989 = if (if ((pmtA > 0))
614645 then (pmtB > 0)
615646 else false)
616647 then {
617- let $t01775417870 = calcReplenishByTwoTokens(pType, poolAddr, pmtA, aId, pmtB, bId, balA, balB)
618- let pmtInA = $t01775417870._1
619- let pmtInB = $t01775417870._2
620- let change = $t01775417870._3
621- let changeId = $t01775417870._4
648+ let $t01863918755 = calcReplenishByTwoTokens(pType, poolAddr, pmtA, aId, pmtB, bId, balA, balB)
649+ let pmtInA = $t01863918755._1
650+ let pmtInB = $t01863918755._2
651+ let change = $t01863918755._3
652+ let changeId = $t01863918755._4
622653 let inv = replenishTwoTokensByType(poolAddr, pType, pmtInA, aId, pmtInB, bId)
623654 if ((inv == inv))
624655 then $Tuple2(change, changeId)
629660 else if ((pmtB > 0))
630661 then $Tuple2(pmtB, bId)
631662 else throw("pmts must be > 0")
632- let change = $t01768818104._1
633- let changeId = $t01768818104._2
663+ let change = $t01857318989._1
664+ let changeId = $t01857318989._2
634665 let inv = if ((change > 0))
635666 then replenishOneTokenByType(poolAddr, pType, change, changeId)
636667 else nil
658689 func replenishEntries (pool,user,stakedAmount,axlyFeeAmount,posNum,shareId,type,withLoan) = {
659690 let totalAmount = getPoolTotalShare(pool)
660691 let totalAmountLoan = getPoolTotalShareWithLoan(pool)
661- let $t01896219200 = if (withLoan)
692+ let $t01984720085 = if (withLoan)
662693 then $Tuple2(getIntegerValue(this, (pool + kPoolInterestLoan)), (totalAmountLoan + stakedAmount))
663694 else $Tuple2(getIntegerValue(this, (pool + kPoolInterestNoLoan)), totalAmountLoan)
664- let curPoolInterest = $t01896219200._1
665- let totalStakedWithLoan = $t01896219200._2
695+ let curPoolInterest = $t01984720085._1
696+ let totalStakedWithLoan = $t01984720085._2
666697 [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))]
667698 }
668699
708739
709740 func capitalize (pool,pType,tokenId,tokenAmount) = {
710741 let poolAddr = Address(fromBase58String(pool))
711- let $t02155121617 = getPoolData(poolAddr, pType)
712- let AId = $t02155121617._1
713- let BId = $t02155121617._2
714- let balA = $t02155121617._3
715- let balB = $t02155121617._4
716- let shareId = $t02155121617._5
742+ let $t02243622502 = getPoolData(poolAddr, pType)
743+ let AId = $t02243622502._1
744+ let BId = $t02243622502._2
745+ let balA = $t02243622502._3
746+ let balB = $t02243622502._4
747+ let shareId = $t02243622502._5
717748 if (if ((tokenId != AId))
718749 then (tokenId != BId)
719750 else false)
720751 then throw("Wrong asset")
721752 else {
722- let $t02170221782 = if ((tokenId == AId))
753+ let $t02258722667 = if ((tokenId == AId))
723754 then $Tuple2(tokenAmount, 0)
724755 else $Tuple2(0, tokenAmount)
725- let pmtA = $t02170221782._1
726- let pmtB = $t02170221782._2
727- let $t02178521889 = replenishByType(pType, pool, NO_FEE, pmtA, AId, pmtB, BId, balA, balB, shareId)
728- let stakedAmount = $t02178521889._1
729- let nf = $t02178521889._2
756+ let pmtA = $t02258722667._1
757+ let pmtB = $t02258722667._2
758+ let $t02267022774 = replenishByType(pType, pool, NO_FEE, pmtA, AId, pmtB, BId, balA, balB, shareId)
759+ let stakedAmount = $t02267022774._1
760+ let nf = $t02267022774._2
730761 let curPoolInterestLoan = valueOrElse(getInteger(this, (pool + kPoolInterestLoan)), 0)
731762 let curPoolInterestNoLoan = valueOrElse(getInteger(this, (pool + kPoolInterestNoLoan)), 0)
732763 let totalShareAmount = getPoolTotalShare(pool)
753784 func withdrawAmountCalc (pool,userCanWithdraw,debt,borrowAsset,stopLossFee) = {
754785 let poolAddr = Address(fromBase58String(pool))
755786 let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Unknown pool")
756- let $t02367923755 = getPoolData(poolAddr, pType)
757- let assetIdA = $t02367923755._1
758- let assetIdB = $t02367923755._2
759- let balA = $t02367923755._3
760- let balB = $t02367923755._4
761- let shareId = $t02367923755._5
787+ let $t02456424640 = getPoolData(poolAddr, pType)
788+ let assetIdA = $t02456424640._1
789+ let assetIdB = $t02456424640._2
790+ let balA = $t02456424640._3
791+ let balB = $t02456424640._4
792+ let shareId = $t02456424640._5
762793 let cBalABefore = accountBalance(assetIdFromStr(assetIdA))
763794 if ((cBalABefore == cBalABefore))
764795 then {
784815 then {
785816 let cBalAAfter = accountBalance(assetIdFromStr(assetIdA))
786817 let cBalBAfter = accountBalance(assetIdFromStr(assetIdB))
787- let $t02444824537 = $Tuple2((cBalAAfter - cBalABefore), (cBalBAfter - cBalBBefore))
788- let tokensAmountA = $t02444824537._1
789- let tokensAmountB = $t02444824537._2
790- let $t02454025394 = if ((debt > 0))
818+ let $t02533325422 = $Tuple2((cBalAAfter - cBalABefore), (cBalBAfter - cBalBBefore))
819+ let tokensAmountA = $t02533325422._1
820+ let tokensAmountB = $t02533325422._2
821+ let $t02542526279 = if ((debt > 0))
791822 then {
792823 let amountToGetEx = if (if ((borrowAsset == assetIdA))
793824 then (debt > tokensAmountA)
812843 else throw("Strict value is not equal to itself.")
813844 }
814845 else $Tuple2(tokensAmountA, tokensAmountB)
815- let toUserA = $t02454025394._1
816- let toUserB = $t02454025394._2
846+ let toUserA = $t02542526279._1
847+ let toUserB = $t02542526279._2
817848 $Tuple5(toUserA, assetIdA, toUserB, assetIdB, shareId)
818849 }
819850 else throw("Strict value is not equal to itself.")
841872 let poolTotalShare = getPoolTotalShare(pool)
842873 let userAddr = Address(fromBase58String(user))
843874 let borrowAsset = valueOrElse(getString(this, (((((pool + "_") + user) + "_") + posId) + kUserBorrowAssetId)), "")
844- let $t02659226826 = if ((borrowAmount > 0))
875+ let $t02747727711 = if ((borrowAmount > 0))
845876 then $Tuple2({
846877 let @ = invoke(getLendSrvAddr(), "getAssetDebt", [false, ((user + "_") + posId), borrowAsset], nil)
847878 if ($isInstanceOf(@, "Int"))
849880 else throw(($getType(@) + " couldn't be cast to Int"))
850881 }, STOPLOSS_LOAN)
851882 else $Tuple2(0, STOPLOSS_FEE_NO_LOAN)
852- let debt = $t02659226826._1
853- let feeType = $t02659226826._2
883+ let debt = $t02747727711._1
884+ let feeType = $t02747727711._2
854885 let stopLossFee = if (stopLoss)
855886 then fraction(userCanWithdraw, getAxlyFee(pool, feeType), FEE_SCALE6)
856887 else 0
857- let $t02694327099 = withdrawAmountCalc(pool, (userCanWithdraw - stopLossFee), debt, borrowAsset, stopLossFee)
858- if (($t02694327099 == $t02694327099))
888+ let $t02782827984 = withdrawAmountCalc(pool, (userCanWithdraw - stopLossFee), debt, borrowAsset, stopLossFee)
889+ if (($t02782827984 == $t02782827984))
859890 then {
860- let shareId = $t02694327099._5
861- let assetIdB = $t02694327099._4
862- let toUserAmountB = $t02694327099._3
863- let assetIdA = $t02694327099._2
864- let toUserAmountA = $t02694327099._1
891+ let shareId = $t02782827984._5
892+ let assetIdB = $t02782827984._4
893+ let toUserAmountB = $t02782827984._3
894+ let assetIdA = $t02782827984._2
895+ let toUserAmountA = $t02782827984._1
865896 let closeDbtInv = if ((debt > 0))
866897 then invoke(getLendSrvAddr(), "repayFor", [((user + "_") + posId)], [AttachedPayment(assetIdFromStr(borrowAsset), debt)])
867898 else 0
900931 let decPrA = pow(10, 0, getAssetDecimals(aId), 0, 0, DOWN)
901932 let decPrB = pow(10, 0, getAssetDecimals(bId), 0, 0, DOWN)
902933 let paydInDollar = (fraction(dPriceA, pmtA, decPrA) + fraction(dPriceB, pmtB, decPrB))
903- let $t02910429201 = if ((borrowId == aId))
934+ let $t02998930086 = if ((borrowId == aId))
904935 then $Tuple2(dPriceA, decPrA)
905936 else $Tuple2(dPriceB, decPrB)
906- let borrowPrice = $t02910429201._1
907- let borrowDecPr = $t02910429201._2
937+ let borrowPrice = $t02998930086._1
938+ let borrowDecPr = $t02998930086._2
908939 fraction(fraction(paydInDollar, (leverage - 100), 100), borrowDecPr, borrowPrice)
909940 }
910941
932963 }
933964
934965
966+func claimAndCheckAmntEx (pool,pType,claim,amountToExchange,change) = {
967+ let $t03110031387 = if (claim)
968+ then claimFarmed(pType, pool)
969+ else {
970+ let claimedAsset = if ((pType == SF_POOL))
971+ then SWOPID
972+ else if ((pType == WX_POOL))
973+ then WXID
974+ else unknownPoolType()
975+ $Tuple2(amountToExchange, claimedAsset)
976+ }
977+ let claimAmount = $t03110031387._1
978+ let claimAsset = $t03110031387._2
979+ if ((amountToExchange > (claimAmount + change)))
980+ then throw("To big amount to exchange")
981+ else $Tuple2(claimAmount, claimAsset)
982+ }
983+
984+
935985 @Callable(i)
936986 func getShareAssetPriceREADONLY (shareId) = {
937987 let sharePrices = getSharePrice(shareId)
9531003 @Callable(i)
9541004 func getUserPositionInDollarsREADONLY (user,pools,posNum) = {
9551005 func userPos (a,pool) = {
956- let $t03087130905 = a
957- let totalPos = $t03087130905._1
958- let posDebt = $t03087130905._2
959- let index = $t03087130905._3
1006+ let $t03228332317 = a
1007+ let totalPos = $t03228332317._1
1008+ let posDebt = $t03228332317._2
1009+ let index = $t03228332317._3
9601010 let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited")
961- let $t03099731087 = getPoolData(Address(fromBase58String(pool)), pType)
962- let AId = $t03099731087._1
963- let BId = $t03099731087._2
964- let balA = $t03099731087._3
965- let balB = $t03099731087._4
966- let shareId = $t03099731087._5
1011+ let $t03240932499 = getPoolData(Address(fromBase58String(pool)), pType)
1012+ let AId = $t03240932499._1
1013+ let BId = $t03240932499._2
1014+ let balA = $t03240932499._3
1015+ let balB = $t03240932499._4
1016+ let shareId = $t03240932499._5
9671017 let borrowAmount = valueOrElse(getInteger(this, (((((pool + "_") + user) + "_") + posNum[index]) + kUserBorrowAmount)), 0)
968- let userCanWithdraw = userCanWithdrawShareCalc(user, pool, posNum[index], (borrowAmount > 0))
969- let sharePrices = getSharePrice(shareId)
970- let decPrShare = pow(10, 0, getAssetDecimals(shareId), 0, 0, DOWN)
971- let shareD = fraction(userCanWithdraw, sharePrices, decPrShare)
972- if ((borrowAmount == 0))
973- then $Tuple3((totalPos :+ shareD), (posDebt :+ 0), (index + 1))
1018+ if (!(isDefined(getInteger(this, (((((pool + "_") + user) + "_") + posNum[index]) + kUserPosition)))))
1019+ then $Tuple3((totalPos :+ 0), (posDebt :+ 0), (index + 1))
9741020 else {
975- let borrowAsset = getStringValue(this, (((((pool + "_") + user) + "_") + posNum[index]) + kUserBorrowAssetId))
976- let debt = {
977- let @ = invoke(getLendSrvAddr(), "getAssetDebt", [false, ((user + "_") + posNum[index]), borrowAsset], nil)
978- if ($isInstanceOf(@, "Int"))
979- then @
980- else throw(($getType(@) + " couldn't be cast to Int"))
981- }
982- let borrowAssetPrice = getIntegerValue(priceOracleAddr, (borrowAsset + kPriceInOracle))
983- let decPrBorrowId = pow(10, 0, getAssetDecimals(borrowAsset), 0, 0, DOWN)
984- let debtD = fraction(debt, borrowAssetPrice, decPrBorrowId)
985- $Tuple3((totalPos :+ shareD), (posDebt :+ debtD), (index + 1))
1021+ let userCanWithdraw = userCanWithdrawShareCalc(user, pool, posNum[index], (borrowAmount > 0))
1022+ let sharePrices = getSharePrice(shareId)
1023+ let decPrShare = pow(10, 0, getAssetDecimals(shareId), 0, 0, DOWN)
1024+ let shareD = fraction(userCanWithdraw, sharePrices, decPrShare)
1025+ if ((borrowAmount == 0))
1026+ then $Tuple3((totalPos :+ shareD), (posDebt :+ 0), (index + 1))
1027+ else {
1028+ let borrowAsset = getStringValue(this, (((((pool + "_") + user) + "_") + posNum[index]) + kUserBorrowAssetId))
1029+ let debt = {
1030+ let @ = invoke(getLendSrvAddr(), "getAssetDebt", [false, ((user + "_") + posNum[index]), borrowAsset], nil)
1031+ if ($isInstanceOf(@, "Int"))
1032+ then @
1033+ else throw(($getType(@) + " couldn't be cast to Int"))
1034+ }
1035+ let borrowAssetPrice = getIntegerValue(priceOracleAddr, (borrowAsset + kPriceInOracle))
1036+ let decPrBorrowId = pow(10, 0, getAssetDecimals(borrowAsset), 0, 0, DOWN)
1037+ let debtD = fraction(debt, borrowAssetPrice, decPrBorrowId)
1038+ $Tuple3((totalPos :+ shareD), (posDebt :+ debtD), (index + 1))
1039+ }
9861040 }
9871041 }
9881042
989- let $t03210732162 = {
1043+ let $t03366333718 = {
9901044 let $l = pools
9911045 let $s = size($l)
9921046 let $acc0 = $Tuple3(nil, nil, 0)
10001054
10011055 $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)
10021056 }
1003- let pos = $t03210732162._1
1004- let debt = $t03210732162._2
1057+ let pos = $t03366333718._1
1058+ let debt = $t03366333718._2
10051059 $Tuple2(nil, $Tuple2(pos, debt))
10061060 }
10071061
10081062
10091063
10101064 @Callable(i)
1011-func replenish (pool,leverage,borrowId) = if (if ((100 > leverage))
1065+func replenish (pool,leverage,borrowId) = valueOrElse(isActiveForUsers(), if (if ((100 > leverage))
10121066 then true
10131067 else (leverage > 300))
10141068 then throw("Leverage can't be <100 and >300")
10181072 then throw("You can't borrow in this pool")
10191073 else {
10201074 let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited")
1021- let $t03260232692 = getPoolData(Address(fromBase58String(pool)), pType)
1022- let AId = $t03260232692._1
1023- let BId = $t03260232692._2
1024- let balA = $t03260232692._3
1025- let balB = $t03260232692._4
1026- let shareId = $t03260232692._5
1075+ let $t03418934279 = getPoolData(Address(fromBase58String(pool)), pType)
1076+ let AId = $t03418934279._1
1077+ let BId = $t03418934279._2
1078+ let balA = $t03418934279._3
1079+ let balB = $t03418934279._4
1080+ let shareId = $t03418934279._5
10271081 if (if ((borrowId != AId))
10281082 then (borrowId != BId)
10291083 else false)
10301084 then throw("Wrong borrow asset")
10311085 else {
1032- let $t03277332832 = parseReplenishPmts(i.payments, AId, BId)
1033- let pmtA = $t03277332832._1
1034- let pmtB = $t03277332832._2
1086+ let $t03436034419 = parseReplenishPmts(i.payments, AId, BId)
1087+ let pmtA = $t03436034419._1
1088+ let pmtB = $t03436034419._2
10351089 let user = toString(i.caller)
10361090 let newPosNum = getNewUserPositionNumber(user)
10371091 if ((leverage > 100))
10511105 if ((inv == inv))
10521106 then {
10531107 let userStaked = getIntegerValue(this, (((((pool + "_") + user) + "_") + toString(newPosNum)) + kUserPosition))
1054- let $t03382133915 = getPoolBalances(Address(fromBase58String(pool)), pType, AId, BId)
1055- if (($t03382133915 == $t03382133915))
1108+ let $t03540835502 = getPoolBalances(Address(fromBase58String(pool)), pType, AId, BId)
1109+ if (($t03540835502 == $t03540835502))
10561110 then {
1057- let newBalB = $t03382133915._2
1058- let newBalA = $t03382133915._1
1111+ let newBalB = $t03540835502._2
1112+ let newBalA = $t03540835502._1
10591113 let prImpact = calcPriceImpact(balA, balB, newBalA, newBalB)
1060- let $t03398534100 = calcWithdrawLPFromPoolVirt(Address(fromBase58String(pool)), pType, shareId, userStaked)
1061- let wAmountA = $t03398534100._1
1062- let wAmountB = $t03398534100._2
1114+ let $t03557235687 = calcWithdrawLPFromPoolVirt(Address(fromBase58String(pool)), pType, shareId, userStaked)
1115+ let wAmountA = $t03557235687._1
1116+ let wAmountB = $t03557235687._2
10631117 $Tuple2(nil, [prImpact, wAmountA, wAmountB])
10641118 }
10651119 else throw("Strict value is not equal to itself.")
10691123 else throw("Strict value is not equal to itself.")
10701124 }
10711125 else {
1072- let $t03415334268 = replenishByType(pType, pool, NO_LOAN_FEE, pmtA, AId, pmtB, BId, balA, balB, shareId)
1073- if (($t03415334268 == $t03415334268))
1126+ let $t03574035855 = replenishByType(pType, pool, NO_LOAN_FEE, pmtA, AId, pmtB, BId, balA, balB, shareId)
1127+ if (($t03574035855 == $t03574035855))
10741128 then {
1075- let axlyFee = $t03415334268._2
1076- let userStaked = $t03415334268._1
1077- let $t03427434368 = getPoolBalances(Address(fromBase58String(pool)), pType, AId, BId)
1078- if (($t03427434368 == $t03427434368))
1129+ let axlyFee = $t03574035855._2
1130+ let userStaked = $t03574035855._1
1131+ let $t03586135955 = getPoolBalances(Address(fromBase58String(pool)), pType, AId, BId)
1132+ if (($t03586135955 == $t03586135955))
10791133 then {
1080- let newBalB = $t03427434368._2
1081- let newBalA = $t03427434368._1
1134+ let newBalB = $t03586135955._2
1135+ let newBalA = $t03586135955._1
10821136 let prImpact = calcPriceImpact(balA, balB, newBalA, newBalB)
1083- let $t03443834553 = calcWithdrawLPFromPoolVirt(Address(fromBase58String(pool)), pType, shareId, userStaked)
1084- let wAmountA = $t03443834553._1
1085- let wAmountB = $t03443834553._2
1137+ let $t03602536140 = calcWithdrawLPFromPoolVirt(Address(fromBase58String(pool)), pType, shareId, userStaked)
1138+ let wAmountA = $t03602536140._1
1139+ let wAmountB = $t03602536140._2
10861140 $Tuple2((replenishEntries(pool, user, userStaked, axlyFee, newPosNum, shareId, pType, false) ++ getCursEntries(AId, BId, shareId, [toString(wAmountA), toString(wAmountB)])), [prImpact, wAmountA, wAmountB])
10871141 }
10881142 else throw("Strict value is not equal to itself.")
10901144 else throw("Strict value is not equal to itself.")
10911145 }
10921146 }
1093- }
1147+ })
10941148
10951149
10961150
10971151 @Callable(i)
1098-func withdraw (pool,posId) = withdrawToUser(toString(i.caller), pool, toString(posId), false)
1152+func withdraw (pool,posId) = valueOrElse(isActiveForUsers(), withdrawToUser(toString(i.caller), pool, toString(posId), false))
10991153
11001154
11011155
11021156 @Callable(i)
1103-func createUpdateStopLoss (posId,poolId,assetId,price) = {
1157+func createUpdateStopLoss (posId,poolId,assetId,price) = valueOrElse(isActiveForUsers(), {
11041158 let tokenOraclePrice = getIntegerValue(priceOracleAddr, (assetId + kPriceInOracle))
11051159 if (!(isDefined(getInteger(this, (((((poolId + "_") + toString(i.caller)) + "_") + toString(posId)) + kUserPosition)))))
11061160 then throw("There are no user position")
11091163 else if ((price > tokenOraclePrice))
11101164 then throw("Price must be less than current token price")
11111165 else [IntegerEntry((((((((toString(i.caller) + "_") + toString(posId)) + "_") + poolId) + "_") + assetId) + kUserStopLoss), price)]
1112- }
1166+ })
11131167
11141168
11151169
11161170 @Callable(i)
1117-func deleteStopLoss (posId,poolId,assetId) = if (!(isDefined(getInteger(this, (((((((toString(i.caller) + "_") + toString(posId)) + "_") + poolId) + "_") + assetId) + kUserStopLoss)))))
1171+func deleteStopLoss (posId,poolId,assetId) = valueOrElse(isActiveForUsers(), if (!(isDefined(getInteger(this, (((((((toString(i.caller) + "_") + toString(posId)) + "_") + poolId) + "_") + assetId) + kUserStopLoss)))))
11181172 then throw("No entry")
1119- else [DeleteEntry((((((((toString(i.caller) + "_") + toString(posId)) + "_") + poolId) + "_") + assetId) + kUserStopLoss))]
1173+ else [DeleteEntry((((((((toString(i.caller) + "_") + toString(posId)) + "_") + poolId) + "_") + assetId) + kUserStopLoss))])
11201174
11211175
11221176
11381192
11391193
11401194 @Callable(i)
1141-func replenishFromLand (requestId) = valueOrElse(isLandCall(i), {
1142- let $t03720037304 = parseRequest(requestId)
1143- let user = $t03720037304._1
1144- let pool = $t03720037304._2
1145- let pmtA = $t03720037304._3
1146- let AId = $t03720037304._4
1147- let pmtB = $t03720037304._5
1148- let BId = $t03720037304._6
1149- let balA = $t03720037304._7
1150- let balB = $t03720037304._8
1151- let shareId = $t03720037304._9
1152- let bwAsset = $t03720037304._10
1153- let bwAmount = $t03720037304._11
1195+func replenishFromLand (requestId) = valueOrElse(isActive(), valueOrElse(isLandCall(i), {
1196+ let $t03890939013 = parseRequest(requestId)
1197+ let user = $t03890939013._1
1198+ let pool = $t03890939013._2
1199+ let pmtA = $t03890939013._3
1200+ let AId = $t03890939013._4
1201+ let pmtB = $t03890939013._5
1202+ let BId = $t03890939013._6
1203+ let balA = $t03890939013._7
1204+ let balB = $t03890939013._8
1205+ let shareId = $t03890939013._9
1206+ let bwAsset = $t03890939013._10
1207+ let bwAmount = $t03890939013._11
11541208 if ((size(i.payments) != 1))
11551209 then throw("Wrong payment size")
11561210 else if (if ((assetIdToStr(i.payments[0].assetId) != bwAsset))
11581212 else (i.payments[0].amount != bwAmount))
11591213 then throw("Wrong payment")
11601214 else {
1161- let $t03749437594 = if ((AId == bwAsset))
1215+ let $t03920339303 = if ((AId == bwAsset))
11621216 then $Tuple2((pmtA + bwAmount), pmtB)
11631217 else $Tuple2(pmtA, (pmtB + bwAmount))
1164- let pmtAllA = $t03749437594._1
1165- let pmtAllB = $t03749437594._2
1218+ let pmtAllA = $t03920339303._1
1219+ let pmtAllB = $t03920339303._2
11661220 let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Unknown pool")
1167- let $t03767637791 = replenishByType(pType, pool, LOAN_FEE, pmtAllA, AId, pmtAllB, BId, balA, balB, shareId)
1168- let userStaked = $t03767637791._1
1169- let axlyFee = $t03767637791._2
1221+ let $t03938539500 = replenishByType(pType, pool, LOAN_FEE, pmtAllA, AId, pmtAllB, BId, balA, balB, shareId)
1222+ let userStaked = $t03938539500._1
1223+ let axlyFee = $t03938539500._2
11701224 let posNum = getNewUserPositionNumber(user)
11711225 let borrowEntries = [IntegerEntry((((((pool + "_") + user) + "_") + toString(posNum)) + kUserBorrowAmount), bwAmount), StringEntry((((((pool + "_") + user) + "_") + toString(posNum)) + kUserBorrowAssetId), bwAsset)]
11721226 let entries = replenishEntries(pool, user, userStaked, axlyFee, posNum, shareId, pType, true)
1173- let $t03815138266 = calcWithdrawLPFromPoolVirt(Address(fromBase58String(pool)), pType, shareId, userStaked)
1174- let wAmountA = $t03815138266._1
1175- let wAmountB = $t03815138266._2
1227+ let $t03986039975 = calcWithdrawLPFromPoolVirt(Address(fromBase58String(pool)), pType, shareId, userStaked)
1228+ let wAmountA = $t03986039975._1
1229+ let wAmountB = $t03986039975._2
11761230 $Tuple2((((entries ++ getCursEntries(AId, BId, shareId, [toString(wAmountA), toString(wAmountB)])) ++ borrowEntries) :+ DeleteEntry((requestId + kRequestId))), userStaked)
11771231 }
1178- })
1232+ }))
11791233
11801234
11811235
11821236 @Callable(i)
1183-func liquidate (user,posId,liquidateAmount) = valueOrElse(isLandCall(i), {
1237+func liquidate (user,posId,liquidateAmount) = valueOrElse(isActive(), valueOrElse(isLandCall(i), {
11841238 let pool = valueOrErrorMessage(getString(this, (((user + "_") + posId) + kUserPositionPool)), "no position")
11851239 let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited")
1186- let $t03876138851 = getPoolData(Address(fromBase58String(pool)), pType)
1187- let AId = $t03876138851._1
1188- let BId = $t03876138851._2
1189- let balA = $t03876138851._3
1190- let balB = $t03876138851._4
1191- let shareId = $t03876138851._5
1240+ let $t04049640586 = getPoolData(Address(fromBase58String(pool)), pType)
1241+ let AId = $t04049640586._1
1242+ let BId = $t04049640586._2
1243+ let balA = $t04049640586._3
1244+ let balB = $t04049640586._4
1245+ let shareId = $t04049640586._5
11921246 let amount = unstakeLP(pool, pType, shareId, liquidateAmount)
11931247 let borrowAmount = getIntegerValue(this, (((((pool + "_") + user) + "_") + posId) + kUserBorrowAmount))
11941248 let borrowAsset = getStringValue(this, (((((pool + "_") + user) + "_") + posId) + kUserBorrowAssetId))
11981252 else if ((borrowAmount == 0))
11991253 then throw("You can't liquidate position without borrow")
12001254 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))]
1201- })
1255+ }))
12021256
12031257
12041258
12051259 @Callable(i)
1206-func stopLoss (user,posId,pool,assetId) = valueOrElse(isAdminCall(i), {
1260+func stopLoss (user,posId,pool,assetId) = valueOrElse(isActive(), valueOrElse(isAdminCall(i), {
12071261 let tokenOraclePrice = getIntegerValue(priceOracleAddr, (assetId + kPriceInOracle))
12081262 if ((tokenOraclePrice > tokenOraclePrice))
12091263 then throw("Token price greater stop loss price")
12101264 else if (!(isDefined(getInteger(this, (((((((user + "_") + toString(posId)) + "_") + pool) + "_") + assetId) + kUserStopLoss)))))
12111265 then throw("No entry")
12121266 else (withdrawToUser(user, pool, toString(posId), true) :+ DeleteEntry((((((((user + "_") + toString(posId)) + "_") + pool) + "_") + assetId) + kUserStopLoss)))
1213- })
1267+ }))
12141268
12151269
12161270
12171271 @Callable(i)
1218-func capitalizeExKeeper (pool,tokenToId,amountToExchange,claim,amountsIn,addresses,assetsToReceive,estReceived,slippageTolerance,minReceived,options) = valueOrElse(isAdminCall(i), {
1272+func capitalizeExKeeper (pool,tokenToId,amountToExchange,claim,amountsIn,addresses,assetsToReceive,estReceived,slippageTolerance,minReceived,options) = valueOrElse(isActive(), valueOrElse(isAdminCall(i), {
12191273 let pType = getStringValue(this, (kPool + pool))
1220- let $t04082441115 = if (claim)
1221- then claimFarmed(pType, pool)
1222- else {
1223- let claimedAsset = if ((pType == SF_POOL))
1224- then SWOPID
1225- else if ((pType == WX_POOL))
1226- then WXID
1227- else unknownPoolType()
1228- $Tuple2(amountToExchange, claimedAsset)
1229- }
1230- let claimedAmount = $t04082441115._1
1231- let claimedAsset = $t04082441115._2
1274+ let change = valueOrElse(getInteger(this, (pool + kPoolCapChange)), 0)
1275+ let $t04268042781 = claimAndCheckAmntEx(pool, pType, claim, amountToExchange, change)
1276+ let claimedAmount = $t04268042781._1
1277+ let claimedAsset = $t04268042781._2
12321278 let exchangedAmount = exchangeKeeper(tokenToId, amountToExchange, claimedAsset, amountsIn, addresses, assetsToReceive, estReceived, slippageTolerance, minReceived, options)
1233- let change = (claimedAmount - amountToExchange)
1234- let changeEntry = if ((change > 0))
1235- then [IntegerEntry((pool + kPoolCapChange), (change + valueOrElse(getInteger(this, (pool + kPoolCapChange)), 0)))]
1279+ let newChange = ((claimedAmount + change) - amountToExchange)
1280+ let changeEntry = if ((newChange >= 0))
1281+ then [IntegerEntry((pool + kPoolCapChange), newChange)]
12361282 else nil
12371283 (capitalize(pool, pType, tokenToId, exchangedAmount) ++ changeEntry)
1238- })
1284+ }))
12391285
12401286
12411287
12421288 @Callable(i)
1243-func capitalizeExPuzzle (pool,tokenToId,amountToExchange,claim,routesStr,minToReceive,options) = valueOrElse(isAdminCall(i), {
1289+func capitalizeExPuzzle (pool,tokenToId,amountToExchange,claim,routesStr,minToReceive,options) = valueOrElse(isActive(), valueOrElse(isAdminCall(i), {
12441290 let pType = getStringValue(this, (kPool + pool))
1245- let $t04183242123 = if (claim)
1246- then claimFarmed(pType, pool)
1247- else {
1248- let claimedAsset = if ((pType == SF_POOL))
1249- then SWOPID
1250- else if ((pType == WX_POOL))
1251- then WXID
1252- else unknownPoolType()
1253- $Tuple2(amountToExchange, claimedAsset)
1254- }
1255- let claimedAmount = $t04183242123._1
1256- let claimedAsset = $t04183242123._2
1291+ let change = valueOrElse(getInteger(this, (pool + kPoolCapChange)), 0)
1292+ let $t04355643657 = claimAndCheckAmntEx(pool, pType, claim, amountToExchange, change)
1293+ let claimedAmount = $t04355643657._1
1294+ let claimedAsset = $t04355643657._2
12571295 let exchangedAmount = exchangePuzzle(tokenToId, amountToExchange, claimedAsset, routesStr, minToReceive, options)
1258- let change = (claimedAmount - amountToExchange)
1259- let changeEntry = if ((change > 0))
1260- then [IntegerEntry((pool + kPoolCapChange), (change + valueOrElse(getInteger(this, (pool + kPoolCapChange)), 0)))]
1296+ let newChange = ((claimedAmount + change) - amountToExchange)
1297+ let changeEntry = if ((newChange >= 0))
1298+ then [IntegerEntry((pool + kPoolCapChange), newChange)]
12611299 else nil
12621300 (capitalize(pool, pType, tokenToId, exchangedAmount) ++ changeEntry)
1263- })
1301+ }))
12641302
12651303
12661304
12671305 @Callable(i)
1268-func capitalizeExSwopFi (pool,tokenToId,amountToExchange,claim,exchangers,exchangersType,args1,args2,routingAssetsKeys,minAmountToReceive,options) = valueOrElse(isAdminCall(i), {
1306+func capitalizeExSwopFi (pool,tokenToId,amountToExchange,claim,exchangers,exchangersType,args1,args2,routingAssetsKeys,minAmountToReceive,options) = valueOrElse(isActive(), valueOrElse(isAdminCall(i), {
12691307 let pType = getStringValue(this, (kPool + pool))
1270- let $t04290743198 = if (claim)
1271- then claimFarmed(pType, pool)
1272- else {
1273- let claimedAsset = if ((pType == SF_POOL))
1274- then SWOPID
1275- else if ((pType == WX_POOL))
1276- then WXID
1277- else unknownPoolType()
1278- $Tuple2(amountToExchange, claimedAsset)
1279- }
1280- let claimedAmount = $t04290743198._1
1281- let claimedAsset = $t04290743198._2
1308+ let change = valueOrElse(getInteger(this, (pool + kPoolCapChange)), 0)
1309+ let $t04449944600 = claimAndCheckAmntEx(pool, pType, claim, amountToExchange, change)
1310+ let claimedAmount = $t04449944600._1
1311+ let claimedAsset = $t04449944600._2
12821312 let exchangedAmount = exchangeSwopFi(tokenToId, amountToExchange, claimedAsset, exchangers, exchangersType, args1, args2, routingAssetsKeys, minAmountToReceive, options)
1283- let change = (claimedAmount - amountToExchange)
1284- let changeEntry = if ((change > 0))
1285- then [IntegerEntry((pool + kPoolCapChange), (change + valueOrElse(getInteger(this, (pool + kPoolCapChange)), 0)))]
1313+ let newChange = ((claimedAmount + change) - amountToExchange)
1314+ let changeEntry = if ((newChange >= 0))
1315+ then [IntegerEntry((pool + kPoolCapChange), newChange)]
12861316 else nil
12871317 (capitalize(pool, pType, tokenToId, exchangedAmount) ++ changeEntry)
1288- })
1318+ }))
12891319
12901320
12911321
12921322 @Callable(i)
1293-func initNewPool (type,poolAddr,inFeeNoLoan,inFeeLoan,capFeeNoLoan,capFeeWithLoan,stoplossFeeNoLoan,stoplossFeeWithLoan,canBorrow) = valueOrElse(isAdminCall(i), if (if ((type != SF_POOL))
1323+func initNewPool (type,poolAddr,inFeeNoLoan,inFeeLoan,capFeeNoLoan,capFeeWithLoan,stoplossFeeNoLoan,stoplossFeeWithLoan,canBorrow) = valueOrElse(isActive(), valueOrElse(isAdminCall(i), if (if ((type != SF_POOL))
12941324 then (type != WX_POOL)
12951325 else false)
12961326 then throw("Wrong type")
12971327 else {
1298- let $t04394044034 = getPoolData(Address(fromBase58String(poolAddr)), type)
1299- let aId = $t04394044034._1
1300- let bId = $t04394044034._2
1301- let aBal = $t04394044034._3
1302- let bBal = $t04394044034._4
1303- let shareId = $t04394044034._5
1328+ let $t04533145425 = getPoolData(Address(fromBase58String(poolAddr)), type)
1329+ let aId = $t04533145425._1
1330+ let bId = $t04533145425._2
1331+ let aBal = $t04533145425._3
1332+ let bBal = $t04533145425._4
1333+ let shareId = $t04533145425._5
13041334 if ((0 > inFeeNoLoan))
13051335 then throw("inFeeNoLoan must be greater than 0")
13061336 else if ((0 > inFeeLoan))
13141344 else if ((0 > stoplossFeeWithLoan))
13151345 then throw("stoplossFeeWithLoan must be greater than 0")
13161346 else [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), BooleanEntry((poolAddr + kPoolCanBorrow), canBorrow)]
1317- })
1347+ }))
1348+
1349+
1350+
1351+@Callable(i)
1352+func activate () = valueOrElse(isAdminCall(i), if (valueOrElse(getBoolean(this, kActive), true))
1353+ then throw("dApp already active")
1354+ else [BooleanEntry(kActive, true)])
1355+
1356+
1357+
1358+@Callable(i)
1359+func shutdown () = valueOrElse(isAdminCall(i), if (!(valueOrElse(getBoolean(this, kActive), true)))
1360+ then throw("dApp already shutdown")
1361+ else [BooleanEntry(kActive, false)])
1362+
1363+
1364+
1365+@Callable(i)
1366+func activateForUsers () = valueOrElse(isAdminCall(i), if (valueOrElse(getBoolean(this, kActiveUsers), true))
1367+ then throw("dApp already active for users")
1368+ else [BooleanEntry(kActive, true)])
1369+
1370+
1371+
1372+@Callable(i)
1373+func shutdownForUsers () = valueOrElse(isAdminCall(i), if (!(valueOrElse(getBoolean(this, kActiveUsers), true)))
1374+ then throw("dApp already shutdown for users")
1375+ else [BooleanEntry(kActive, false)])
1376+
1377+
1378+
1379+@Callable(i)
1380+func activateSF () = valueOrElse(isAdminCall(i), if (valueOrElse(getBoolean(this, (SF_POOL + kActiveSFWX)), true))
1381+ then throw("SWOPFI already active")
1382+ else [BooleanEntry(kActive, true)])
1383+
1384+
1385+
1386+@Callable(i)
1387+func shutdownSF () = valueOrElse(isAdminCall(i), if (!(valueOrElse(getBoolean(this, (SF_POOL + kActiveSFWX)), true)))
1388+ then throw("SWOPFI already shutdown")
1389+ else [BooleanEntry(kActive, false)])
1390+
1391+
1392+
1393+@Callable(i)
1394+func activateWX () = valueOrElse(isAdminCall(i), if (valueOrElse(getBoolean(this, (WX_POOL + kActiveSFWX)), true))
1395+ then throw("WX already active")
1396+ else [BooleanEntry(kActive, true)])
1397+
1398+
1399+
1400+@Callable(i)
1401+func shutdownWX () = valueOrElse(isAdminCall(i), if (!(valueOrElse(getBoolean(this, (WX_POOL + kActiveSFWX)), true)))
1402+ then throw("WX already shutdown")
1403+ else [BooleanEntry(kActive, false)])
1404+
1405+
1406+
1407+@Callable(i)
1408+func activatePool (pool) = valueOrElse(isAdminCall(i), if (!(isDefined(getString(this, (kPool + pool)))))
1409+ then throw("Unknown pool")
1410+ else if (valueOrElse(getBoolean(this, (pool + kPoolActive)), true))
1411+ then throw("Pool already active")
1412+ else [BooleanEntry(kActive, true)])
1413+
1414+
1415+
1416+@Callable(i)
1417+func shutdownPool (pool) = valueOrElse(isAdminCall(i), if (!(isDefined(getString(this, (kPool + pool)))))
1418+ then throw("Unknown pool")
1419+ else if (!(valueOrElse(getBoolean(this, (pool + kPoolActive)), true)))
1420+ then throw("Pool already shutdown")
1421+ else [BooleanEntry(kActive, false)])
13181422
13191423
13201424 @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 SCALE16 = toBigInt(10000000000000000)
2727
2828 let FEE_SCALE6 = 1000000
2929
3030 let kSFPoolAAssetBalance = "A_asset_balance"
3131
3232 let kSFPoolBAssetBalance = "B_asset_balance"
3333
3434 let kSFPoolAAssetId = "A_asset_id"
3535
3636 let kSFPoolBAssetId = "B_asset_id"
3737
3838 let kSFPoolShareId = "share_asset_id"
3939
4040 let kSFPoolShareSupply = "share_asset_supply"
4141
4242 let kSFPoolFee = "commission"
4343
4444 let kUserPosition = "_userPosition"
4545
4646 let kUserPositionPool = "_userPositionPool"
4747
4848 let kUserBorrowAmount = "_userPositionBorrowAmount"
4949
5050 let kUserBorrowAssetId = "_userPositionBorrowAssetId"
5151
5252 let kUserPositionNum = "_userPositionNumber"
5353
5454 let kUserPositionInterest = "_userPositionInterest"
5555
5656 let kPoolTotal = "_poolTotal"
5757
5858 let kPoolTotalLoan = "_poolTotalLoan"
5959
6060 let kPoolInterestLoan = "_poolInterestLoan"
6161
6262 let kPoolInterestNoLoan = "_poolInterestNoLoan"
6363
6464 let kPoolCanBorrow = "_poolCanBorrow"
6565
6666 let kAxlyInFeeWithoutLoan = "_axlyFeeNoLoan"
6767
6868 let kAxlyInFeeWithLoan = "_axlyFeeWithLoan"
6969
7070 let kAxlyNoLoanCapFee = "_axlyFeeCapWithLoan"
7171
7272 let kAxlyWithLoanCapFee = "_axlyFeeCapNoLoan"
7373
7474 let kAxlyStopLossNoLoanFee = "_axlyFeeStoplossWithLoan"
7575
7676 let kAxlyStopLossLoanFee = "_axlyFeeStoplossNoLoan"
7777
7878 let kRequestId = "_request_id"
7979
8080 let kRequestIter = "requests_iter"
8181
8282 let kPool = "pool_"
8383
8484 let kSharePool = "_poolShareId"
8585
8686 let kPoolCapChange = "_poolCapChange"
8787
8888 let kTokenLastPrice = "last_price"
8989
9090 let kPriceInOracle = "_twap5B"
9191
92+let kActive = "active"
93+
94+let kActiveUsers = "activeUsers"
95+
96+let kActiveSFWX = "_active"
97+
98+let kPoolActive = "_activePool"
99+
92100 let kUserStopLoss = "_stopLoss"
93101
94102 let kMoneyBox = "axly_money_box"
95103
96104 let kSFFarmingAddr = "swopfi_farming_addr"
97105
98106 let kLendService = "lend_service_addr"
99107
100108 let kAdminCallPK = "admin_call_pub_key"
101109
102110 let kPriceOracle = "price_oracle"
103111
104112 let kExContract = "exchange_contract"
105113
106114 let kWxSwapContract = "wx_swap_contract"
107115
108116 let kSwopId = "swop_id"
109117
110118 let kWxId = "wx_id"
111119
112120 let moneyBox = Address(fromBase58String(valueOrErrorMessage(getString(this, kMoneyBox), "No axly moneyBox address")))
113121
114122 let exContract = Address(fromBase58String(valueOrErrorMessage(getString(this, kExContract), "No exchange contract address")))
115123
116124 let priceOracleAddr = Address(fromBase58String(valueOrErrorMessage(getString(this, kPriceOracle), "No price oracle address")))
117125
118126 let wxSwapContract = Address(fromBase58String(valueOrErrorMessage(getString(this, kWxSwapContract), "No wx swap address")))
119127
120128 let SWOPID = fromBase58String(valueOrErrorMessage(getString(this, kSwopId), "No swop id"))
121129
122130 let WXID = fromBase58String(valueOrErrorMessage(getString(this, kWxId), "No wx id"))
123131
124132 func unknownPoolType () = throw("Wrong pool type")
125133
126134
127135 func getLendSrvAddr () = Address(fromBase58String(valueOrErrorMessage(getString(this, kLendService), "Can't get lend service addr")))
128136
129137
130138 func getAdminCallAddr () = addressFromPublicKey(fromBase58String(valueOrErrorMessage(getString(this, kAdminCallPK), "Can't get admin addr")))
131139
132140
133141 func isAdminCall (i) = if ((i.caller == getAdminCallAddr()))
134142 then unit
135143 else throw("Only admin can call this function")
136144
137145
138146 func isSelfCall (i) = if ((i.caller == this))
139147 then unit
140148 else throw("Only contract itself can call this function")
141149
142150
143151 func isLandCall (i) = if ((i.caller == getLendSrvAddr()))
144152 then unit
145153 else throw("Only land contract can call this function")
146154
147155
156+func isActive () = if ((valueOrElse(getBoolean(this, kActive), true) == true))
157+ then unit
158+ else throw("DApp is inactive at this moment")
159+
160+
161+func isActiveForUsers () = if (if (valueOrElse(getBoolean(this, kActive), true))
162+ then (valueOrElse(getBoolean(this, kActiveUsers), true) == true)
163+ else false)
164+ then unit
165+ else throw("DApp is inactive for users at this moment")
166+
167+
168+func isPoolActive (pool,type) = {
169+ let WXSFActive = valueOrElse(getBoolean(this, (type + kActiveSFWX)), true)
170+ let poolActive = valueOrElse(getBoolean(this, (pool + kPoolActive)), true)
171+ if (if (WXSFActive)
172+ then poolActive
173+ else false)
174+ then true
175+ else false
176+ }
177+
178+
148179 func accountBalance (assetId) = match assetId {
149180 case id: ByteVector =>
150181 assetBalance(this, id)
151182 case waves: Unit =>
152183 wavesBalance(this).available
153184 case _ =>
154185 throw("Match error")
155186 }
156187
157188
158189 func getSFPoolBalances (poolAddr) = $Tuple2(valueOrErrorMessage(getInteger(poolAddr, kSFPoolAAssetBalance), "Can't get pool A asset balance"), valueOrErrorMessage(getInteger(poolAddr, kSFPoolBAssetBalance), "Can't get pool B asset balance"))
159190
160191
161192 func getWXPoolBalances (poolAddr,aId,bId) = $Tuple2({
162193 let @ = invoke(poolAddr, "getAccBalanceWrapperREADONLY", [aId], nil)
163194 if ($isInstanceOf(@, "Int"))
164195 then @
165196 else throw(($getType(@) + " couldn't be cast to Int"))
166197 }, {
167198 let @ = invoke(poolAddr, "getAccBalanceWrapperREADONLY", [bId], nil)
168199 if ($isInstanceOf(@, "Int"))
169200 then @
170201 else throw(($getType(@) + " couldn't be cast to Int"))
171202 })
172203
173204
174205 func getPoolBalances (poolAddr,type,aId,bId) = if ((type == SF_POOL))
175206 then getSFPoolBalances(poolAddr)
176207 else if ((type == WX_POOL))
177208 then getWXPoolBalances(poolAddr, aId, bId)
178209 else unknownPoolType()
179210
180211
181212 func getSFPoolData (poolAddr) = {
182- let $t061796228 = getSFPoolBalances(poolAddr)
183- if (($t061796228 == $t061796228))
213+ let $t070647113 = getSFPoolBalances(poolAddr)
214+ if (($t070647113 == $t070647113))
184215 then {
185- let balB = $t061796228._2
186- let balA = $t061796228._1
216+ let balB = $t070647113._2
217+ let balA = $t070647113._1
187218 $Tuple5(valueOrErrorMessage(getString(poolAddr, kSFPoolAAssetId), "Can't get pool A asset id"), valueOrErrorMessage(getString(poolAddr, kSFPoolBAssetId), "Can't get pool B asset id"), balA, balB, valueOrErrorMessage(getString(poolAddr, kSFPoolShareId), "Can't get share asset id"))
188219 }
189220 else throw("Strict value is not equal to itself.")
190221 }
191222
192223
193224 func getWXPoolData (poolAddr) = {
194225 let cfg = {
195226 let @ = invoke(poolAddr, "getPoolConfigWrapperREADONLY", nil, nil)
196227 if ($isInstanceOf(@, "List[Any]"))
197228 then @
198229 else throw(($getType(@) + " couldn't be cast to List[Any]"))
199230 }
200231 if ((cfg == cfg))
201232 then {
202233 let aId = valueOrErrorMessage({
203234 let @ = cfg[4]
204235 if ($isInstanceOf(@, "String"))
205236 then @
206237 else unit
207238 }, "Can't get pool A asset id")
208239 let bId = valueOrErrorMessage({
209240 let @ = cfg[5]
210241 if ($isInstanceOf(@, "String"))
211242 then @
212243 else unit
213244 }, "Can't get pool B asset id")
214245 let shareId = valueOrErrorMessage({
215246 let @ = cfg[3]
216247 if ($isInstanceOf(@, "String"))
217248 then @
218249 else unit
219250 }, "Can't get pool LP asset id")
220- let $t069256984 = getWXPoolBalances(poolAddr, aId, bId)
221- if (($t069256984 == $t069256984))
251+ let $t078107869 = getWXPoolBalances(poolAddr, aId, bId)
252+ if (($t078107869 == $t078107869))
222253 then {
223- let balB = $t069256984._2
224- let balA = $t069256984._1
254+ let balB = $t078107869._2
255+ let balA = $t078107869._1
225256 $Tuple5(aId, bId, balA, balB, shareId)
226257 }
227258 else throw("Strict value is not equal to itself.")
228259 }
229260 else throw("Strict value is not equal to itself.")
230261 }
231262
232263
233264 func getPoolData (poolAddr,type) = if ((type == SF_POOL))
234265 then getSFPoolData(poolAddr)
235266 else if ((type == WX_POOL))
236267 then getWXPoolData(poolAddr)
237268 else unknownPoolType()
238269
239270
240271 func getShareSupply (poolAddr,type,shareId) = if ((type == SF_POOL))
241272 then valueOrErrorMessage(getInteger(poolAddr, kSFPoolShareSupply), "Can't get share asset supply")
242273 else if ((type == WX_POOL))
243274 then valueOrErrorMessage(assetInfo(fromBase58String(shareId)), "Wrong ShareId").quantity
244275 else unknownPoolType()
245276
246277
247278 func getPoolTotalShare (pool) = valueOrElse(getInteger(this, (pool + kPoolTotal)), 0)
248279
249280
250281 func getPoolTotalShareWithLoan (pool) = valueOrElse(getInteger(this, (pool + kPoolTotalLoan)), 0)
251282
252283
253284 func getNewUserPositionNumber (user) = (valueOrElse(getInteger(this, (user + kUserPositionNum)), 0) + 1)
254285
255286
256287 func getAxlyFee (pool,feeType) = if ((feeType == CAP_FEE_LOAN))
257288 then getIntegerValue(this, (pool + kAxlyWithLoanCapFee))
258289 else if ((feeType == CAP_FEE_NO_LOAN))
259290 then getIntegerValue(this, (pool + kAxlyNoLoanCapFee))
260291 else if ((feeType == LOAN_FEE))
261292 then getIntegerValue(this, (pool + kAxlyInFeeWithLoan))
262293 else if ((feeType == NO_LOAN_FEE))
263294 then getIntegerValue(this, (pool + kAxlyInFeeWithoutLoan))
264295 else if ((feeType == NO_FEE))
265296 then 0
266297 else throw("Wrong fee type")
267298
268299
269300 func getSFFarmingAddr () = Address(fromBase58String(valueOrErrorMessage(getString(this, kSFFarmingAddr), "Can't get swopfi farming addr")))
270301
271302
272303 func getWXFarmingAddr (poolAddr) = {
273304 let fContract = Address(fromBase58String(valueOrErrorMessage(getString(poolAddr, "%s__factoryContract"), "Can't get WX factory contract addr")))
274305 let factroyCfg = split(valueOrErrorMessage(getString(fContract, "%s__factoryConfig"), "Can't get WX factory cfg"), "__")
275306 Address(fromBase58String(factroyCfg[1]))
276307 }
277308
278309
279310 func assetIdToStr (assetId) = match assetId {
280311 case id: ByteVector =>
281312 toBase58String(id)
282313 case waves: Unit =>
283314 "WAVES"
284315 case _ =>
285316 throw("Not Asset id")
286317 }
287318
288319
289320 func assetIdFromStr (assetId) = if ((assetId == "WAVES"))
290321 then unit
291322 else fromBase58String(assetId)
292323
293324
294325 func getAssetDecimals (assetId) = if ((assetId == "WAVES"))
295326 then 8
296327 else match assetInfo(fromBase58String(assetId)) {
297328 case asset: Asset =>
298329 asset.decimals
299330 case _ =>
300331 throw("Can't find asset")
301332 }
302333
303334
304335 func getAssetPrecition (assetId) = pow(10, 0, getAssetDecimals(assetId), 0, 0, DOWN)
305336
306337
307338 func getAssetsPrice (assetIds) = {
308339 func getPrices (a,assetId) = {
309340 let assetPrice = getIntegerValue(priceOracleAddr, (assetId + kPriceInOracle))
310341 (a :+ assetPrice)
311342 }
312343
313344 let $l = assetIds
314345 let $s = size($l)
315346 let $acc0 = nil
316347 func $f0_1 ($a,$i) = if (($i >= $s))
317348 then $a
318349 else getPrices($a, $l[$i])
319350
320351 func $f0_2 ($a,$i) = if (($i >= $s))
321352 then $a
322353 else throw("List size exceeds 50")
323354
324355 $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)
325356 }
326357
327358
328359 func getSharePrice (shareId) = {
329360 let pool = valueOrErrorMessage(getString(this, (shareId + kSharePool)), "Can't find pool addr by share id")
330361 let poolAddr = Address(fromBase58String(pool))
331362 let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited")
332- let $t0996210027 = getPoolData(poolAddr, pType)
333- let aId = $t0996210027._1
334- let bId = $t0996210027._2
335- let aBalance = $t0996210027._3
336- let bBalance = $t0996210027._4
363+ let $t01084710912 = getPoolData(poolAddr, pType)
364+ let aId = $t01084710912._1
365+ let bId = $t01084710912._2
366+ let aBalance = $t01084710912._3
367+ let bBalance = $t01084710912._4
337368 let dPriceA = getIntegerValue(priceOracleAddr, (aId + kPriceInOracle))
338369 let dPriceB = getIntegerValue(priceOracleAddr, (bId + kPriceInOracle))
339370 let shareSupply = getShareSupply(poolAddr, pType, shareId)
340371 let APrecision = pow(10, 0, getAssetDecimals(aId), 0, 0, DOWN)
341372 let BPrecision = pow(10, 0, getAssetDecimals(bId), 0, 0, DOWN)
342373 let sharePrecision = pow(10, 0, getAssetDecimals(shareId), 0, 0, DOWN)
343374 let sum = (fraction(aBalance, dPriceA, APrecision) + fraction(bBalance, dPriceB, BPrecision))
344375 fraction(sum, sharePrecision, shareSupply)
345376 }
346377
347378
348379 func getSharePrices (shareIds) = {
349380 func getPrices (a,shareId) = (a :+ getSharePrice(shareId))
350381
351382 let $l = shareIds
352383 let $s = size($l)
353384 let $acc0 = nil
354385 func $f0_1 ($a,$i) = if (($i >= $s))
355386 then $a
356387 else getPrices($a, $l[$i])
357388
358389 func $f0_2 ($a,$i) = if (($i >= $s))
359390 then $a
360391 else throw("List size exceeds 20")
361392
362393 $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)
363394 }
364395
365396
366397 func getCursEntries (aId,bId,shareId,wAmounts) = {
367398 let assetsPrices = getAssetsPrice([aId, bId])
368399 let sharePrice = getSharePrice(shareId)
369400 let prices = ([toString(assetsPrices[0]), toString(assetsPrices[1]), toString(sharePrice)] ++ wAmounts)
370401 [StringEntry(kTokenLastPrice, makeString(prices, ","))]
371402 }
372403
373404
374405 func calcReplenishByTwoTokens (pType,poolAddr,pmtA,aId,pmtB,bId,balA,balB) = if ((pType == SF_POOL))
375406 then {
376407 let repl = {
377408 let @ = invoke(poolAddr, "callFunction", ["calcLPReplenishTwoTokensREADONLY", [toString(pmtA), toString(pmtB)]], nil)
378409 if ($isInstanceOf(@, "List[Any]"))
379410 then @
380411 else throw(($getType(@) + " couldn't be cast to List[Any]"))
381412 }
382413 if ((repl == repl))
383414 then $Tuple5({
384415 let @ = repl[3]
385416 if ($isInstanceOf(@, "Int"))
386417 then @
387418 else throw(($getType(@) + " couldn't be cast to Int"))
388419 }, {
389420 let @ = repl[4]
390421 if ($isInstanceOf(@, "Int"))
391422 then @
392423 else throw(($getType(@) + " couldn't be cast to Int"))
393424 }, {
394425 let @ = repl[1]
395426 if ($isInstanceOf(@, "Int"))
396427 then @
397428 else throw(($getType(@) + " couldn't be cast to Int"))
398429 }, assetIdToStr(repl[2]), {
399430 let @ = repl[0]
400431 if ($isInstanceOf(@, "Int"))
401432 then @
402433 else throw(($getType(@) + " couldn't be cast to Int"))
403434 })
404435 else throw("Strict value is not equal to itself.")
405436 }
406437 else if ((pType == WX_POOL))
407438 then {
408- let $t01157211822 = $Tuple2(split({
439+ let $t01245712707 = $Tuple2(split({
409440 let @ = invoke(poolAddr, "evaluatePutByAmountAssetREADONLY", [pmtA], nil)
410441 if ($isInstanceOf(@, "String"))
411442 then @
412443 else throw(($getType(@) + " couldn't be cast to String"))
413444 }, "__"), split({
414445 let @ = invoke(poolAddr, "evaluatePutByPriceAssetREADONLY", [pmtB], nil)
415446 if ($isInstanceOf(@, "String"))
416447 then @
417448 else throw(($getType(@) + " couldn't be cast to String"))
418449 }, "__"))
419- if (($t01157211822 == $t01157211822))
450+ if (($t01245712707 == $t01245712707))
420451 then {
421- let evalPutInB = $t01157211822._2
422- let evalPutInA = $t01157211822._1
452+ let evalPutInB = $t01245712707._2
453+ let evalPutInA = $t01245712707._1
423454 let lpInA = parseIntValue(evalPutInA[1])
424455 let lpInB = parseIntValue(evalPutInB[1])
425456 if ((lpInB > lpInA))
426457 then {
427458 let pmt = parseIntValue(evalPutInA[8])
428459 $Tuple5(pmtA, pmt, (pmtB - pmt), bId, lpInB)
429460 }
430461 else {
431462 let pmt = parseIntValue(evalPutInB[7])
432463 $Tuple5(pmt, pmtB, (pmtA - pmt), aId, lpInA)
433464 }
434465 }
435466 else throw("Strict value is not equal to itself.")
436467 }
437468 else unknownPoolType()
438469
439470
440471 func replenishTwoTokensByType (poolAddr,pType,pmtA,aId,pmtB,bId) = {
441472 let payments = [AttachedPayment(assetIdFromStr(aId), pmtA), AttachedPayment(assetIdFromStr(bId), pmtB)]
442473 if ((pType == SF_POOL))
443474 then invoke(poolAddr, "callFunction", ["replenishWithTwoTokens", ["false", "0"]], payments)
444475 else if ((pType == WX_POOL))
445476 then invoke(poolAddr, "put", [1000000, false], payments)
446477 else unknownPoolType()
447478 }
448479
449480
450481 func replenishOneTokenByType (poolAddr,pType,pmt,pmtId) = {
451482 let payments = [AttachedPayment(assetIdFromStr(pmtId), pmt)]
452483 if ((pType == SF_POOL))
453484 then invoke(poolAddr, "callFunction", ["replenishWithOneToken", ["0", "false", "0"]], payments)
454485 else if ((pType == WX_POOL))
455486 then invoke(poolAddr, "putOneTkn", [0, false], payments)
456487 else unknownPoolType()
457488 }
458489
459490
460491 func stakeLP (pool,pType,shareId,amount) = {
461492 let payments = [AttachedPayment(fromBase58String(shareId), amount)]
462493 if ((pType == SF_POOL))
463494 then invoke(getSFFarmingAddr(), "lockShareTokens", [pool, 0], payments)
464495 else if ((pType == WX_POOL))
465496 then invoke(getWXFarmingAddr(addressFromStringValue(pool)), "stake", nil, payments)
466497 else unknownPoolType()
467498 }
468499
469500
470501 func unstakeLP (pool,pType,shareId,amount) = {
471- let $t01348113831 = if ((pType == SF_POOL))
502+ let $t01436614716 = if ((pType == SF_POOL))
472503 then $Tuple3(getSFFarmingAddr(), "withdrawShareTokens", [pool, amount])
473504 else if ((pType == WX_POOL))
474505 then $Tuple3(getWXFarmingAddr(Address(fromBase58String(pool))), "unstake", [shareId, amount])
475506 else unknownPoolType()
476- let farmAddr = $t01348113831._1
477- let fName = $t01348113831._2
478- let params = $t01348113831._3
507+ let farmAddr = $t01436614716._1
508+ let fName = $t01436614716._2
509+ let params = $t01436614716._3
479510 let inv = invoke(farmAddr, fName, params, nil)
480511 if ((inv == inv))
481512 then amount
482513 else throw("Strict value is not equal to itself.")
483514 }
484515
485516
486517 func calcAmountToPaySF (pool,assetIdA,assetIdB,balA,balB,amountTokenToGet,assetTokenToGet) = {
487518 let poolAddr = Address(fromBase58String(pool))
488519 let feeScale6 = 1000000
489520 let fee = getIntegerValue(poolAddr, kSFPoolFee)
490521 let amntGetNoFee = fraction(amountTokenToGet, feeScale6, (feeScale6 - fee), CEILING)
491- let $t01425314559 = if ((assetTokenToGet == assetIdA))
522+ let $t01513815444 = if ((assetTokenToGet == assetIdA))
492523 then {
493524 let amountToPay = fraction(amntGetNoFee, balB, (balA - amntGetNoFee), CEILING)
494525 $Tuple2(amountToPay, assetIdB)
495526 }
496527 else {
497528 let amountToPay = fraction(amntGetNoFee, balA, (balB - amntGetNoFee), CEILING)
498529 $Tuple2(amountToPay, assetIdA)
499530 }
500- let amountToPay = $t01425314559._1
501- let assetToPay = $t01425314559._2
531+ let amountToPay = $t01513815444._1
532+ let assetToPay = $t01513815444._2
502533 $Tuple2(assetToPay, amountToPay)
503534 }
504535
505536
506537 func calcAmountToPayWX (pool,assetIdA,assetIdB,balA,balB,amountTokenToGet,assetTokenToGet) = {
507538 let prFee = getIntegerValue(wxSwapContract, "%s__protocolFee")
508539 let pFee = getIntegerValue(wxSwapContract, "%s__poolFee")
509540 let feeScale = toBigInt(100000000)
510- let $t01489815206 = if ((assetTokenToGet == assetIdA))
541+ let $t01578316091 = if ((assetTokenToGet == assetIdA))
511542 then {
512543 let amountToPay = fraction(amountTokenToGet, balB, (balA - amountTokenToGet))
513544 $Tuple2(amountToPay, assetIdB)
514545 }
515546 else {
516547 let amountToPay = fraction(amountTokenToGet, balA, (balB - amountTokenToGet))
517548 $Tuple2(amountToPay, assetIdA)
518549 }
519- let amountToPay = $t01489815206._1
520- let assetToPay = $t01489815206._2
550+ let amountToPay = $t01578316091._1
551+ let assetToPay = $t01578316091._2
521552 let amountToPayWithFee = toInt(fraction(toBigInt(amountToPay), feeScale, (feeScale - toBigInt((prFee + pFee))), CEILING))
522553 $Tuple2(assetToPay, amountToPayWithFee)
523554 }
524555
525556
526557 func exchangeDirectly (pType,pool,assetIdA,assetIdB,balA,balB,amountTokenToGet,assetTokenToGet) = if ((pType == SF_POOL))
527558 then {
528- let $t01555315675 = calcAmountToPaySF(pool, assetIdA, assetIdB, balA, balB, amountTokenToGet, assetTokenToGet)
529- let assetToPay = $t01555315675._1
530- let amountToPay = $t01555315675._2
559+ let $t01643816560 = calcAmountToPaySF(pool, assetIdA, assetIdB, balA, balB, amountTokenToGet, assetTokenToGet)
560+ let assetToPay = $t01643816560._1
561+ let amountToPay = $t01643816560._2
531562 invoke(addressFromStringValue(pool), "callFunction", ["exchange", [toString(amountTokenToGet)]], [AttachedPayment(assetIdFromStr(assetToPay), amountToPay)])
532563 }
533564 else if ((pType == WX_POOL))
534565 then {
535- let $t01587515997 = calcAmountToPayWX(pool, assetIdA, assetIdB, balA, balB, amountTokenToGet, assetTokenToGet)
536- let assetToPay = $t01587515997._1
537- let amountToPay = $t01587515997._2
566+ let $t01676016882 = calcAmountToPayWX(pool, assetIdA, assetIdB, balA, balB, amountTokenToGet, assetTokenToGet)
567+ let assetToPay = $t01676016882._1
568+ let amountToPay = $t01676016882._2
538569 invoke(wxSwapContract, "swap", [amountTokenToGet, assetTokenToGet, toString(this)], [AttachedPayment(assetIdFromStr(assetToPay), amountToPay)])
539570 }
540571 else unknownPoolType()
541572
542573
543574 func calcWithdrawLPFromPoolVirt (poolAddr,pType,shareId,userCanWithdraw) = {
544- let $t01628416723 = if ((pType == SF_POOL))
575+ let $t01716917608 = if ((pType == SF_POOL))
545576 then {
546577 let inv = {
547578 let @ = invoke(poolAddr, "callFunction", ["withdrawREADONLY", [toString(userCanWithdraw)]], nil)
548579 if ($isInstanceOf(@, "(Int, Int)"))
549580 then @
550581 else throw(($getType(@) + " couldn't be cast to (Int, Int)"))
551582 }
552583 if ((inv == inv))
553584 then $Tuple2(inv._1, inv._2)
554585 else throw("Strict value is not equal to itself.")
555586 }
556587 else if ((pType == WX_POOL))
557588 then {
558589 let inv = split({
559590 let @ = invoke(poolAddr, "evaluateGetREADONLY", [shareId, userCanWithdraw], nil)
560591 if ($isInstanceOf(@, "String"))
561592 then @
562593 else throw(($getType(@) + " couldn't be cast to String"))
563594 }, "__")
564595 if ((inv == inv))
565596 then $Tuple2(parseIntValue(inv[1]), parseIntValue(inv[2]))
566597 else throw("Strict value is not equal to itself.")
567598 }
568599 else unknownPoolType()
569- let amountA = $t01628416723._1
570- let amountB = $t01628416723._2
600+ let amountA = $t01716917608._1
601+ let amountB = $t01716917608._2
571602 $Tuple2(amountA, amountB)
572603 }
573604
574605
575606 func claimFarmed (pType,pool) = if ((pType == SF_POOL))
576607 then {
577608 let balBefore = accountBalance(SWOPID)
578609 if ((balBefore == balBefore))
579610 then {
580611 let inv = invoke(getSFFarmingAddr(), "claim", [pool], nil)
581612 if ((inv == inv))
582613 then {
583614 let balAfter = accountBalance(SWOPID)
584615 $Tuple2((balAfter - balBefore), SWOPID)
585616 }
586617 else throw("Strict value is not equal to itself.")
587618 }
588619 else throw("Strict value is not equal to itself.")
589620 }
590621 else if ((pType == WX_POOL))
591622 then {
592623 let balBefore = accountBalance(WXID)
593624 if ((balBefore == balBefore))
594625 then {
595626 let inv = invoke(getWXFarmingAddr(Address(fromBase58String(pool))), "claimWX", [pool], nil)
596627 if ((inv == inv))
597628 then {
598629 let balAfter = accountBalance(WXID)
599630 $Tuple2((balAfter - balBefore), WXID)
600631 }
601632 else throw("Strict value is not equal to itself.")
602633 }
603634 else throw("Strict value is not equal to itself.")
604635 }
605636 else unknownPoolType()
606637
607638
608639 func replenishByType (pType,pool,feeType,pmtA,aId,pmtB,bId,balA,balB,LPId) = {
609640 let lpBalanceBefore = accountBalance(fromBase58String(LPId))
610641 if ((lpBalanceBefore == lpBalanceBefore))
611642 then {
612643 let poolAddr = addressFromStringValue(pool)
613- let $t01768818104 = if (if ((pmtA > 0))
644+ let $t01857318989 = if (if ((pmtA > 0))
614645 then (pmtB > 0)
615646 else false)
616647 then {
617- let $t01775417870 = calcReplenishByTwoTokens(pType, poolAddr, pmtA, aId, pmtB, bId, balA, balB)
618- let pmtInA = $t01775417870._1
619- let pmtInB = $t01775417870._2
620- let change = $t01775417870._3
621- let changeId = $t01775417870._4
648+ let $t01863918755 = calcReplenishByTwoTokens(pType, poolAddr, pmtA, aId, pmtB, bId, balA, balB)
649+ let pmtInA = $t01863918755._1
650+ let pmtInB = $t01863918755._2
651+ let change = $t01863918755._3
652+ let changeId = $t01863918755._4
622653 let inv = replenishTwoTokensByType(poolAddr, pType, pmtInA, aId, pmtInB, bId)
623654 if ((inv == inv))
624655 then $Tuple2(change, changeId)
625656 else throw("Strict value is not equal to itself.")
626657 }
627658 else if ((pmtA > 0))
628659 then $Tuple2(pmtA, aId)
629660 else if ((pmtB > 0))
630661 then $Tuple2(pmtB, bId)
631662 else throw("pmts must be > 0")
632- let change = $t01768818104._1
633- let changeId = $t01768818104._2
663+ let change = $t01857318989._1
664+ let changeId = $t01857318989._2
634665 let inv = if ((change > 0))
635666 then replenishOneTokenByType(poolAddr, pType, change, changeId)
636667 else nil
637668 if ((inv == inv))
638669 then {
639670 let lpBalanceAfter = accountBalance(fromBase58String(LPId))
640671 let totalStaked = (lpBalanceAfter - lpBalanceBefore)
641672 let axlyFeeAmount = fraction(totalStaked, getAxlyFee(pool, feeType), FEE_SCALE6)
642673 let userShareForStake = (totalStaked - axlyFeeAmount)
643674 if ((0 >= userShareForStake))
644675 then throw("amount of staked sharetokens must be > 0")
645676 else {
646677 let invLP = stakeLP(pool, pType, LPId, userShareForStake)
647678 if ((invLP == invLP))
648679 then $Tuple2(userShareForStake, axlyFeeAmount)
649680 else throw("Strict value is not equal to itself.")
650681 }
651682 }
652683 else throw("Strict value is not equal to itself.")
653684 }
654685 else throw("Strict value is not equal to itself.")
655686 }
656687
657688
658689 func replenishEntries (pool,user,stakedAmount,axlyFeeAmount,posNum,shareId,type,withLoan) = {
659690 let totalAmount = getPoolTotalShare(pool)
660691 let totalAmountLoan = getPoolTotalShareWithLoan(pool)
661- let $t01896219200 = if (withLoan)
692+ let $t01984720085 = if (withLoan)
662693 then $Tuple2(getIntegerValue(this, (pool + kPoolInterestLoan)), (totalAmountLoan + stakedAmount))
663694 else $Tuple2(getIntegerValue(this, (pool + kPoolInterestNoLoan)), totalAmountLoan)
664- let curPoolInterest = $t01896219200._1
665- let totalStakedWithLoan = $t01896219200._2
695+ let curPoolInterest = $t01984720085._1
696+ let totalStakedWithLoan = $t01984720085._2
666697 [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))]
667698 }
668699
669700
670701 func exchangeKeeper (toToken,pmtAmount,pmtAsset,amountsIn,addresses,assetsToReceive,estReceived,slippageTolerance,minReceived,options) = {
671702 let tokenBalanceBefore = accountBalance(assetIdFromStr(toToken))
672703 if ((tokenBalanceBefore == tokenBalanceBefore))
673704 then {
674705 let inv = invoke(exContract, "swap", [amountsIn, addresses, assetsToReceive, estReceived, slippageTolerance, minReceived, options], [AttachedPayment(pmtAsset, pmtAmount)])
675706 if ((inv == inv))
676707 then (accountBalance(assetIdFromStr(toToken)) - tokenBalanceBefore)
677708 else throw("Strict value is not equal to itself.")
678709 }
679710 else throw("Strict value is not equal to itself.")
680711 }
681712
682713
683714 func exchangePuzzle (toToken,pmtAmount,pmtAsset,routesStr,minToReceive,options) = {
684715 let tokenBalanceBefore = accountBalance(assetIdFromStr(toToken))
685716 if ((tokenBalanceBefore == tokenBalanceBefore))
686717 then {
687718 let inv = invoke(exContract, "puzzleSwap", [routesStr, minToReceive, options], [AttachedPayment(pmtAsset, pmtAmount)])
688719 if ((inv == inv))
689720 then (accountBalance(assetIdFromStr(toToken)) - tokenBalanceBefore)
690721 else throw("Strict value is not equal to itself.")
691722 }
692723 else throw("Strict value is not equal to itself.")
693724 }
694725
695726
696727 func exchangeSwopFi (toToken,pmtAmount,pmtAsset,exchangers,exchangersType,args1,args2,routingAssetsKeys,minAmountToReceive,options) = {
697728 let tokenBalanceBefore = accountBalance(assetIdFromStr(toToken))
698729 if ((tokenBalanceBefore == tokenBalanceBefore))
699730 then {
700731 let inv = invoke(exContract, "swopfiSwap", [exchangers, exchangersType, args1, args2, routingAssetsKeys, minAmountToReceive, options], [AttachedPayment(pmtAsset, pmtAmount)])
701732 if ((inv == inv))
702733 then (accountBalance(assetIdFromStr(toToken)) - tokenBalanceBefore)
703734 else throw("Strict value is not equal to itself.")
704735 }
705736 else throw("Strict value is not equal to itself.")
706737 }
707738
708739
709740 func capitalize (pool,pType,tokenId,tokenAmount) = {
710741 let poolAddr = Address(fromBase58String(pool))
711- let $t02155121617 = getPoolData(poolAddr, pType)
712- let AId = $t02155121617._1
713- let BId = $t02155121617._2
714- let balA = $t02155121617._3
715- let balB = $t02155121617._4
716- let shareId = $t02155121617._5
742+ let $t02243622502 = getPoolData(poolAddr, pType)
743+ let AId = $t02243622502._1
744+ let BId = $t02243622502._2
745+ let balA = $t02243622502._3
746+ let balB = $t02243622502._4
747+ let shareId = $t02243622502._5
717748 if (if ((tokenId != AId))
718749 then (tokenId != BId)
719750 else false)
720751 then throw("Wrong asset")
721752 else {
722- let $t02170221782 = if ((tokenId == AId))
753+ let $t02258722667 = if ((tokenId == AId))
723754 then $Tuple2(tokenAmount, 0)
724755 else $Tuple2(0, tokenAmount)
725- let pmtA = $t02170221782._1
726- let pmtB = $t02170221782._2
727- let $t02178521889 = replenishByType(pType, pool, NO_FEE, pmtA, AId, pmtB, BId, balA, balB, shareId)
728- let stakedAmount = $t02178521889._1
729- let nf = $t02178521889._2
756+ let pmtA = $t02258722667._1
757+ let pmtB = $t02258722667._2
758+ let $t02267022774 = replenishByType(pType, pool, NO_FEE, pmtA, AId, pmtB, BId, balA, balB, shareId)
759+ let stakedAmount = $t02267022774._1
760+ let nf = $t02267022774._2
730761 let curPoolInterestLoan = valueOrElse(getInteger(this, (pool + kPoolInterestLoan)), 0)
731762 let curPoolInterestNoLoan = valueOrElse(getInteger(this, (pool + kPoolInterestNoLoan)), 0)
732763 let totalShareAmount = getPoolTotalShare(pool)
733764 let totalShareAmountWithLoan = getPoolTotalShareWithLoan(pool)
734765 let loanPercent = fraction(totalShareAmountWithLoan, SCALE8, totalShareAmount)
735766 let stakedLoan = fraction(stakedAmount, loanPercent, SCALE8)
736767 let stakedNoLoan = (stakedAmount - stakedLoan)
737768 let newInterestLoan = if ((totalShareAmountWithLoan > 0))
738769 then (curPoolInterestLoan + fraction(stakedLoan, SCALE10, totalShareAmountWithLoan))
739770 else 0
740771 let newInterestNoLoan = if (((totalShareAmount - totalShareAmountWithLoan) > 0))
741772 then (curPoolInterestNoLoan + fraction(stakedNoLoan, SCALE10, (totalShareAmount - totalShareAmountWithLoan)))
742773 else 0
743774 let axlyFeeLoan = fraction(stakedLoan, getAxlyFee(pool, CAP_FEE_LOAN), FEE_SCALE6)
744775 let axlyFeeNoLoan = fraction(stakedNoLoan, getAxlyFee(pool, CAP_FEE_NO_LOAN), FEE_SCALE6)
745776 let axlyFee = unstakeLP(pool, pType, shareId, (axlyFeeLoan + axlyFeeNoLoan))
746777 if ((axlyFee == axlyFee))
747778 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, nil))
748779 else throw("Strict value is not equal to itself.")
749780 }
750781 }
751782
752783
753784 func withdrawAmountCalc (pool,userCanWithdraw,debt,borrowAsset,stopLossFee) = {
754785 let poolAddr = Address(fromBase58String(pool))
755786 let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Unknown pool")
756- let $t02367923755 = getPoolData(poolAddr, pType)
757- let assetIdA = $t02367923755._1
758- let assetIdB = $t02367923755._2
759- let balA = $t02367923755._3
760- let balB = $t02367923755._4
761- let shareId = $t02367923755._5
787+ let $t02456424640 = getPoolData(poolAddr, pType)
788+ let assetIdA = $t02456424640._1
789+ let assetIdB = $t02456424640._2
790+ let balA = $t02456424640._3
791+ let balB = $t02456424640._4
792+ let shareId = $t02456424640._5
762793 let cBalABefore = accountBalance(assetIdFromStr(assetIdA))
763794 if ((cBalABefore == cBalABefore))
764795 then {
765796 let cBalBBefore = accountBalance(assetIdFromStr(assetIdB))
766797 if ((cBalBBefore == cBalBBefore))
767798 then {
768799 let inv = if ((pType == SF_POOL))
769800 then {
770801 let inv = unstakeLP(pool, pType, shareId, stopLossFee)
771802 if ((inv == inv))
772803 then invoke(poolAddr, "callFunction", ["withdraw", [toString(userCanWithdraw)]], nil)
773804 else throw("Strict value is not equal to itself.")
774805 }
775806 else if ((pType == WX_POOL))
776807 then {
777808 let inv = unstakeLP(pool, pType, shareId, (userCanWithdraw + stopLossFee))
778809 if ((inv == inv))
779810 then invoke(poolAddr, "get", nil, [AttachedPayment(assetIdFromStr(shareId), userCanWithdraw)])
780811 else throw("Strict value is not equal to itself.")
781812 }
782813 else unknownPoolType()
783814 if ((inv == inv))
784815 then {
785816 let cBalAAfter = accountBalance(assetIdFromStr(assetIdA))
786817 let cBalBAfter = accountBalance(assetIdFromStr(assetIdB))
787- let $t02444824537 = $Tuple2((cBalAAfter - cBalABefore), (cBalBAfter - cBalBBefore))
788- let tokensAmountA = $t02444824537._1
789- let tokensAmountB = $t02444824537._2
790- let $t02454025394 = if ((debt > 0))
818+ let $t02533325422 = $Tuple2((cBalAAfter - cBalABefore), (cBalBAfter - cBalBBefore))
819+ let tokensAmountA = $t02533325422._1
820+ let tokensAmountB = $t02533325422._2
821+ let $t02542526279 = if ((debt > 0))
791822 then {
792823 let amountToGetEx = if (if ((borrowAsset == assetIdA))
793824 then (debt > tokensAmountA)
794825 else false)
795826 then (debt - tokensAmountA)
796827 else if (if ((borrowAsset == assetIdB))
797828 then (debt > tokensAmountB)
798829 else false)
799830 then (debt - tokensAmountB)
800831 else 0
801832 let exInv = if ((amountToGetEx > 0))
802833 then exchangeDirectly(pType, pool, assetIdA, assetIdB, (balA - tokensAmountA), (balB - tokensAmountB), amountToGetEx, borrowAsset)
803834 else nil
804835 if ((exInv == exInv))
805836 then {
806837 let cBalAAfterRepay = accountBalance(assetIdFromStr(assetIdA))
807838 let cBalBAfterRepay = accountBalance(assetIdFromStr(assetIdB))
808839 if ((borrowAsset == assetIdA))
809840 then $Tuple2(((cBalAAfterRepay - cBalABefore) - debt), (cBalBAfterRepay - cBalBBefore))
810841 else $Tuple2((cBalAAfterRepay - cBalABefore), ((cBalBAfterRepay - cBalBBefore) - debt))
811842 }
812843 else throw("Strict value is not equal to itself.")
813844 }
814845 else $Tuple2(tokensAmountA, tokensAmountB)
815- let toUserA = $t02454025394._1
816- let toUserB = $t02454025394._2
846+ let toUserA = $t02542526279._1
847+ let toUserB = $t02542526279._2
817848 $Tuple5(toUserA, assetIdA, toUserB, assetIdB, shareId)
818849 }
819850 else throw("Strict value is not equal to itself.")
820851 }
821852 else throw("Strict value is not equal to itself.")
822853 }
823854 else throw("Strict value is not equal to itself.")
824855 }
825856
826857
827858 func userCanWithdrawShareCalc (user,pool,posId,borrowed) = {
828859 let pAmount = valueOrErrorMessage(getInteger(this, (((((pool + "_") + user) + "_") + posId) + kUserPosition)), "Unknown position")
829860 let userInterest = getIntegerValue(this, (((((pool + "_") + user) + "_") + posId) + kUserPositionInterest))
830861 let poolInterest = if (borrowed)
831862 then getIntegerValue(this, (pool + kPoolInterestLoan))
832863 else getIntegerValue(this, (pool + kPoolInterestNoLoan))
833864 (pAmount + fraction(pAmount, (poolInterest - userInterest), SCALE10))
834865 }
835866
836867
837868 func withdrawToUser (user,pool,posId,stopLoss) = {
838869 let pAmount = valueOrErrorMessage(getInteger(this, (((((pool + "_") + user) + "_") + posId) + kUserPosition)), "Unknown position")
839870 let borrowAmount = valueOrElse(getInteger(this, (((((pool + "_") + user) + "_") + posId) + kUserBorrowAmount)), 0)
840871 let userCanWithdraw = userCanWithdrawShareCalc(user, pool, posId, (borrowAmount > 0))
841872 let poolTotalShare = getPoolTotalShare(pool)
842873 let userAddr = Address(fromBase58String(user))
843874 let borrowAsset = valueOrElse(getString(this, (((((pool + "_") + user) + "_") + posId) + kUserBorrowAssetId)), "")
844- let $t02659226826 = if ((borrowAmount > 0))
875+ let $t02747727711 = if ((borrowAmount > 0))
845876 then $Tuple2({
846877 let @ = invoke(getLendSrvAddr(), "getAssetDebt", [false, ((user + "_") + posId), borrowAsset], nil)
847878 if ($isInstanceOf(@, "Int"))
848879 then @
849880 else throw(($getType(@) + " couldn't be cast to Int"))
850881 }, STOPLOSS_LOAN)
851882 else $Tuple2(0, STOPLOSS_FEE_NO_LOAN)
852- let debt = $t02659226826._1
853- let feeType = $t02659226826._2
883+ let debt = $t02747727711._1
884+ let feeType = $t02747727711._2
854885 let stopLossFee = if (stopLoss)
855886 then fraction(userCanWithdraw, getAxlyFee(pool, feeType), FEE_SCALE6)
856887 else 0
857- let $t02694327099 = withdrawAmountCalc(pool, (userCanWithdraw - stopLossFee), debt, borrowAsset, stopLossFee)
858- if (($t02694327099 == $t02694327099))
888+ let $t02782827984 = withdrawAmountCalc(pool, (userCanWithdraw - stopLossFee), debt, borrowAsset, stopLossFee)
889+ if (($t02782827984 == $t02782827984))
859890 then {
860- let shareId = $t02694327099._5
861- let assetIdB = $t02694327099._4
862- let toUserAmountB = $t02694327099._3
863- let assetIdA = $t02694327099._2
864- let toUserAmountA = $t02694327099._1
891+ let shareId = $t02782827984._5
892+ let assetIdB = $t02782827984._4
893+ let toUserAmountB = $t02782827984._3
894+ let assetIdA = $t02782827984._2
895+ let toUserAmountA = $t02782827984._1
865896 let closeDbtInv = if ((debt > 0))
866897 then invoke(getLendSrvAddr(), "repayFor", [((user + "_") + posId)], [AttachedPayment(assetIdFromStr(borrowAsset), debt)])
867898 else 0
868899 if ((closeDbtInv == closeDbtInv))
869900 then ([DeleteEntry((((((pool + "_") + user) + "_") + posId) + kUserPosition)), DeleteEntry((((user + "_") + posId) + kUserPositionPool)), DeleteEntry((((((pool + "_") + user) + "_") + posId) + kUserBorrowAmount)), DeleteEntry((((((pool + "_") + user) + "_") + posId) + kUserBorrowAssetId)), DeleteEntry((((((pool + "_") + user) + "_") + posId) + kUserPositionInterest)), IntegerEntry((pool + kPoolTotal), ((poolTotalShare - userCanWithdraw) - stopLossFee)), ScriptTransfer(userAddr, toUserAmountA, assetIdFromStr(assetIdA)), ScriptTransfer(userAddr, toUserAmountB, assetIdFromStr(assetIdB)), ScriptTransfer(moneyBox, stopLossFee, fromBase58String(shareId))] ++ getCursEntries(assetIdA, assetIdB, shareId, nil))
870901 else throw("Strict value is not equal to itself.")
871902 }
872903 else throw("Strict value is not equal to itself.")
873904 }
874905
875906
876907 func parseRequest (requestId) = {
877908 let request = split(valueOrErrorMessage(getString(this, (requestId + kRequestId)), ("No request with id " + requestId)), ",")
878909 let user = request[0]
879910 let pool = request[1]
880911 let pmtA = parseIntValue(request[2])
881912 let AId = request[3]
882913 let pmtB = parseIntValue(request[4])
883914 let BId = request[5]
884915 let balA = parseIntValue(request[6])
885916 let balB = parseIntValue(request[7])
886917 let shareId = request[8]
887918 let bwAsset = request[9]
888919 let bwAmount = parseIntValue(request[10])
889920 $Tuple11(user, pool, pmtA, AId, pmtB, BId, balA, balB, shareId, bwAsset, bwAmount)
890921 }
891922
892923
893924 func calcBorrowAmount (pmtA,pmtB,aId,bId,leverage,borrowId) = if (if ((borrowId != aId))
894925 then (borrowId != bId)
895926 else false)
896927 then throw("Wrong borrow asset")
897928 else {
898929 let dPriceA = getIntegerValue(priceOracleAddr, (aId + kPriceInOracle))
899930 let dPriceB = getIntegerValue(priceOracleAddr, (bId + kPriceInOracle))
900931 let decPrA = pow(10, 0, getAssetDecimals(aId), 0, 0, DOWN)
901932 let decPrB = pow(10, 0, getAssetDecimals(bId), 0, 0, DOWN)
902933 let paydInDollar = (fraction(dPriceA, pmtA, decPrA) + fraction(dPriceB, pmtB, decPrB))
903- let $t02910429201 = if ((borrowId == aId))
934+ let $t02998930086 = if ((borrowId == aId))
904935 then $Tuple2(dPriceA, decPrA)
905936 else $Tuple2(dPriceB, decPrB)
906- let borrowPrice = $t02910429201._1
907- let borrowDecPr = $t02910429201._2
937+ let borrowPrice = $t02998930086._1
938+ let borrowDecPr = $t02998930086._2
908939 fraction(fraction(paydInDollar, (leverage - 100), 100), borrowDecPr, borrowPrice)
909940 }
910941
911942
912943 func parseReplenishPmts (pmts,AId,BId) = if ((size(pmts) == 2))
913944 then if ((assetIdToStr(pmts[0].assetId) != AId))
914945 then throw("Wrong payment asset A")
915946 else if ((assetIdToStr(pmts[1].assetId) != BId))
916947 then throw("Wrong payment asset B")
917948 else $Tuple2(pmts[0].amount, pmts[1].amount)
918949 else if ((size(pmts) == 1))
919950 then if ((assetIdToStr(pmts[0].assetId) == AId))
920951 then $Tuple2(pmts[0].amount, 0)
921952 else if ((assetIdToStr(pmts[0].assetId) == BId))
922953 then $Tuple2(0, pmts[0].amount)
923954 else throw("Wrong payment")
924955 else throw("One or two payments expected")
925956
926957
927958 func calcPriceImpact (balA,balB,newBalA,newBalB) = {
928959 let pri = ((SCALE8 - fraction(fraction(balB, SCALE8, balA), SCALE8, fraction(newBalB, SCALE8, newBalA))) * 100)
929960 if ((0 > pri))
930961 then (pri * -1)
931962 else pri
932963 }
933964
934965
966+func claimAndCheckAmntEx (pool,pType,claim,amountToExchange,change) = {
967+ let $t03110031387 = if (claim)
968+ then claimFarmed(pType, pool)
969+ else {
970+ let claimedAsset = if ((pType == SF_POOL))
971+ then SWOPID
972+ else if ((pType == WX_POOL))
973+ then WXID
974+ else unknownPoolType()
975+ $Tuple2(amountToExchange, claimedAsset)
976+ }
977+ let claimAmount = $t03110031387._1
978+ let claimAsset = $t03110031387._2
979+ if ((amountToExchange > (claimAmount + change)))
980+ then throw("To big amount to exchange")
981+ else $Tuple2(claimAmount, claimAsset)
982+ }
983+
984+
935985 @Callable(i)
936986 func getShareAssetPriceREADONLY (shareId) = {
937987 let sharePrices = getSharePrice(shareId)
938988 $Tuple2(nil, sharePrices)
939989 }
940990
941991
942992
943993 @Callable(i)
944994 func getUserPositionShareAmountREADONLY (user,posNum) = {
945995 let pool = valueOrErrorMessage(getString(this, (((user + "_") + posNum) + kUserPositionPool)), "Unknown position")
946996 let borrowAmount = getIntegerValue(this, (((((pool + "_") + user) + "_") + posNum) + kUserBorrowAmount))
947997 let userCanWithdraw = userCanWithdrawShareCalc(user, pool, posNum, (borrowAmount > 0))
948998 $Tuple2(nil, userCanWithdraw)
949999 }
9501000
9511001
9521002
9531003 @Callable(i)
9541004 func getUserPositionInDollarsREADONLY (user,pools,posNum) = {
9551005 func userPos (a,pool) = {
956- let $t03087130905 = a
957- let totalPos = $t03087130905._1
958- let posDebt = $t03087130905._2
959- let index = $t03087130905._3
1006+ let $t03228332317 = a
1007+ let totalPos = $t03228332317._1
1008+ let posDebt = $t03228332317._2
1009+ let index = $t03228332317._3
9601010 let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited")
961- let $t03099731087 = getPoolData(Address(fromBase58String(pool)), pType)
962- let AId = $t03099731087._1
963- let BId = $t03099731087._2
964- let balA = $t03099731087._3
965- let balB = $t03099731087._4
966- let shareId = $t03099731087._5
1011+ let $t03240932499 = getPoolData(Address(fromBase58String(pool)), pType)
1012+ let AId = $t03240932499._1
1013+ let BId = $t03240932499._2
1014+ let balA = $t03240932499._3
1015+ let balB = $t03240932499._4
1016+ let shareId = $t03240932499._5
9671017 let borrowAmount = valueOrElse(getInteger(this, (((((pool + "_") + user) + "_") + posNum[index]) + kUserBorrowAmount)), 0)
968- let userCanWithdraw = userCanWithdrawShareCalc(user, pool, posNum[index], (borrowAmount > 0))
969- let sharePrices = getSharePrice(shareId)
970- let decPrShare = pow(10, 0, getAssetDecimals(shareId), 0, 0, DOWN)
971- let shareD = fraction(userCanWithdraw, sharePrices, decPrShare)
972- if ((borrowAmount == 0))
973- then $Tuple3((totalPos :+ shareD), (posDebt :+ 0), (index + 1))
1018+ if (!(isDefined(getInteger(this, (((((pool + "_") + user) + "_") + posNum[index]) + kUserPosition)))))
1019+ then $Tuple3((totalPos :+ 0), (posDebt :+ 0), (index + 1))
9741020 else {
975- let borrowAsset = getStringValue(this, (((((pool + "_") + user) + "_") + posNum[index]) + kUserBorrowAssetId))
976- let debt = {
977- let @ = invoke(getLendSrvAddr(), "getAssetDebt", [false, ((user + "_") + posNum[index]), borrowAsset], nil)
978- if ($isInstanceOf(@, "Int"))
979- then @
980- else throw(($getType(@) + " couldn't be cast to Int"))
981- }
982- let borrowAssetPrice = getIntegerValue(priceOracleAddr, (borrowAsset + kPriceInOracle))
983- let decPrBorrowId = pow(10, 0, getAssetDecimals(borrowAsset), 0, 0, DOWN)
984- let debtD = fraction(debt, borrowAssetPrice, decPrBorrowId)
985- $Tuple3((totalPos :+ shareD), (posDebt :+ debtD), (index + 1))
1021+ let userCanWithdraw = userCanWithdrawShareCalc(user, pool, posNum[index], (borrowAmount > 0))
1022+ let sharePrices = getSharePrice(shareId)
1023+ let decPrShare = pow(10, 0, getAssetDecimals(shareId), 0, 0, DOWN)
1024+ let shareD = fraction(userCanWithdraw, sharePrices, decPrShare)
1025+ if ((borrowAmount == 0))
1026+ then $Tuple3((totalPos :+ shareD), (posDebt :+ 0), (index + 1))
1027+ else {
1028+ let borrowAsset = getStringValue(this, (((((pool + "_") + user) + "_") + posNum[index]) + kUserBorrowAssetId))
1029+ let debt = {
1030+ let @ = invoke(getLendSrvAddr(), "getAssetDebt", [false, ((user + "_") + posNum[index]), borrowAsset], nil)
1031+ if ($isInstanceOf(@, "Int"))
1032+ then @
1033+ else throw(($getType(@) + " couldn't be cast to Int"))
1034+ }
1035+ let borrowAssetPrice = getIntegerValue(priceOracleAddr, (borrowAsset + kPriceInOracle))
1036+ let decPrBorrowId = pow(10, 0, getAssetDecimals(borrowAsset), 0, 0, DOWN)
1037+ let debtD = fraction(debt, borrowAssetPrice, decPrBorrowId)
1038+ $Tuple3((totalPos :+ shareD), (posDebt :+ debtD), (index + 1))
1039+ }
9861040 }
9871041 }
9881042
989- let $t03210732162 = {
1043+ let $t03366333718 = {
9901044 let $l = pools
9911045 let $s = size($l)
9921046 let $acc0 = $Tuple3(nil, nil, 0)
9931047 func $f0_1 ($a,$i) = if (($i >= $s))
9941048 then $a
9951049 else userPos($a, $l[$i])
9961050
9971051 func $f0_2 ($a,$i) = if (($i >= $s))
9981052 then $a
9991053 else throw("List size exceeds 20")
10001054
10011055 $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)
10021056 }
1003- let pos = $t03210732162._1
1004- let debt = $t03210732162._2
1057+ let pos = $t03366333718._1
1058+ let debt = $t03366333718._2
10051059 $Tuple2(nil, $Tuple2(pos, debt))
10061060 }
10071061
10081062
10091063
10101064 @Callable(i)
1011-func replenish (pool,leverage,borrowId) = if (if ((100 > leverage))
1065+func replenish (pool,leverage,borrowId) = valueOrElse(isActiveForUsers(), if (if ((100 > leverage))
10121066 then true
10131067 else (leverage > 300))
10141068 then throw("Leverage can't be <100 and >300")
10151069 else if (if (!(getBooleanValue(this, (pool + kPoolCanBorrow))))
10161070 then (leverage > 100)
10171071 else false)
10181072 then throw("You can't borrow in this pool")
10191073 else {
10201074 let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited")
1021- let $t03260232692 = getPoolData(Address(fromBase58String(pool)), pType)
1022- let AId = $t03260232692._1
1023- let BId = $t03260232692._2
1024- let balA = $t03260232692._3
1025- let balB = $t03260232692._4
1026- let shareId = $t03260232692._5
1075+ let $t03418934279 = getPoolData(Address(fromBase58String(pool)), pType)
1076+ let AId = $t03418934279._1
1077+ let BId = $t03418934279._2
1078+ let balA = $t03418934279._3
1079+ let balB = $t03418934279._4
1080+ let shareId = $t03418934279._5
10271081 if (if ((borrowId != AId))
10281082 then (borrowId != BId)
10291083 else false)
10301084 then throw("Wrong borrow asset")
10311085 else {
1032- let $t03277332832 = parseReplenishPmts(i.payments, AId, BId)
1033- let pmtA = $t03277332832._1
1034- let pmtB = $t03277332832._2
1086+ let $t03436034419 = parseReplenishPmts(i.payments, AId, BId)
1087+ let pmtA = $t03436034419._1
1088+ let pmtB = $t03436034419._2
10351089 let user = toString(i.caller)
10361090 let newPosNum = getNewUserPositionNumber(user)
10371091 if ((leverage > 100))
10381092 then {
10391093 let borrowAmount = calcBorrowAmount(pmtA, pmtB, AId, BId, leverage, borrowId)
10401094 let request = makeString([user, pool, toString(pmtA), AId, toString(pmtB), BId, toString(balA), toString(balB), shareId, borrowId, toString(borrowAmount)], ",")
10411095 let newRequestId = {
10421096 let @ = invoke(this, "createNewRequest", [request], nil)
10431097 if ($isInstanceOf(@, "Int"))
10441098 then @
10451099 else throw(($getType(@) + " couldn't be cast to Int"))
10461100 }
10471101 if ((newRequestId == newRequestId))
10481102 then {
10491103 let args = [((user + "_") + toString(newPosNum)), shareId, borrowId, borrowAmount, toString(this), "replenishFromLand", toString(valueOrErrorMessage(newRequestId, "Can't create new request"))]
10501104 let inv = reentrantInvoke(getLendSrvAddr(), "flashPosition", args, nil)
10511105 if ((inv == inv))
10521106 then {
10531107 let userStaked = getIntegerValue(this, (((((pool + "_") + user) + "_") + toString(newPosNum)) + kUserPosition))
1054- let $t03382133915 = getPoolBalances(Address(fromBase58String(pool)), pType, AId, BId)
1055- if (($t03382133915 == $t03382133915))
1108+ let $t03540835502 = getPoolBalances(Address(fromBase58String(pool)), pType, AId, BId)
1109+ if (($t03540835502 == $t03540835502))
10561110 then {
1057- let newBalB = $t03382133915._2
1058- let newBalA = $t03382133915._1
1111+ let newBalB = $t03540835502._2
1112+ let newBalA = $t03540835502._1
10591113 let prImpact = calcPriceImpact(balA, balB, newBalA, newBalB)
1060- let $t03398534100 = calcWithdrawLPFromPoolVirt(Address(fromBase58String(pool)), pType, shareId, userStaked)
1061- let wAmountA = $t03398534100._1
1062- let wAmountB = $t03398534100._2
1114+ let $t03557235687 = calcWithdrawLPFromPoolVirt(Address(fromBase58String(pool)), pType, shareId, userStaked)
1115+ let wAmountA = $t03557235687._1
1116+ let wAmountB = $t03557235687._2
10631117 $Tuple2(nil, [prImpact, wAmountA, wAmountB])
10641118 }
10651119 else throw("Strict value is not equal to itself.")
10661120 }
10671121 else throw("Strict value is not equal to itself.")
10681122 }
10691123 else throw("Strict value is not equal to itself.")
10701124 }
10711125 else {
1072- let $t03415334268 = replenishByType(pType, pool, NO_LOAN_FEE, pmtA, AId, pmtB, BId, balA, balB, shareId)
1073- if (($t03415334268 == $t03415334268))
1126+ let $t03574035855 = replenishByType(pType, pool, NO_LOAN_FEE, pmtA, AId, pmtB, BId, balA, balB, shareId)
1127+ if (($t03574035855 == $t03574035855))
10741128 then {
1075- let axlyFee = $t03415334268._2
1076- let userStaked = $t03415334268._1
1077- let $t03427434368 = getPoolBalances(Address(fromBase58String(pool)), pType, AId, BId)
1078- if (($t03427434368 == $t03427434368))
1129+ let axlyFee = $t03574035855._2
1130+ let userStaked = $t03574035855._1
1131+ let $t03586135955 = getPoolBalances(Address(fromBase58String(pool)), pType, AId, BId)
1132+ if (($t03586135955 == $t03586135955))
10791133 then {
1080- let newBalB = $t03427434368._2
1081- let newBalA = $t03427434368._1
1134+ let newBalB = $t03586135955._2
1135+ let newBalA = $t03586135955._1
10821136 let prImpact = calcPriceImpact(balA, balB, newBalA, newBalB)
1083- let $t03443834553 = calcWithdrawLPFromPoolVirt(Address(fromBase58String(pool)), pType, shareId, userStaked)
1084- let wAmountA = $t03443834553._1
1085- let wAmountB = $t03443834553._2
1137+ let $t03602536140 = calcWithdrawLPFromPoolVirt(Address(fromBase58String(pool)), pType, shareId, userStaked)
1138+ let wAmountA = $t03602536140._1
1139+ let wAmountB = $t03602536140._2
10861140 $Tuple2((replenishEntries(pool, user, userStaked, axlyFee, newPosNum, shareId, pType, false) ++ getCursEntries(AId, BId, shareId, [toString(wAmountA), toString(wAmountB)])), [prImpact, wAmountA, wAmountB])
10871141 }
10881142 else throw("Strict value is not equal to itself.")
10891143 }
10901144 else throw("Strict value is not equal to itself.")
10911145 }
10921146 }
1093- }
1147+ })
10941148
10951149
10961150
10971151 @Callable(i)
1098-func withdraw (pool,posId) = withdrawToUser(toString(i.caller), pool, toString(posId), false)
1152+func withdraw (pool,posId) = valueOrElse(isActiveForUsers(), withdrawToUser(toString(i.caller), pool, toString(posId), false))
10991153
11001154
11011155
11021156 @Callable(i)
1103-func createUpdateStopLoss (posId,poolId,assetId,price) = {
1157+func createUpdateStopLoss (posId,poolId,assetId,price) = valueOrElse(isActiveForUsers(), {
11041158 let tokenOraclePrice = getIntegerValue(priceOracleAddr, (assetId + kPriceInOracle))
11051159 if (!(isDefined(getInteger(this, (((((poolId + "_") + toString(i.caller)) + "_") + toString(posId)) + kUserPosition)))))
11061160 then throw("There are no user position")
11071161 else if ((0 >= price))
11081162 then throw("Price must be greater than 0")
11091163 else if ((price > tokenOraclePrice))
11101164 then throw("Price must be less than current token price")
11111165 else [IntegerEntry((((((((toString(i.caller) + "_") + toString(posId)) + "_") + poolId) + "_") + assetId) + kUserStopLoss), price)]
1112- }
1166+ })
11131167
11141168
11151169
11161170 @Callable(i)
1117-func deleteStopLoss (posId,poolId,assetId) = if (!(isDefined(getInteger(this, (((((((toString(i.caller) + "_") + toString(posId)) + "_") + poolId) + "_") + assetId) + kUserStopLoss)))))
1171+func deleteStopLoss (posId,poolId,assetId) = valueOrElse(isActiveForUsers(), if (!(isDefined(getInteger(this, (((((((toString(i.caller) + "_") + toString(posId)) + "_") + poolId) + "_") + assetId) + kUserStopLoss)))))
11181172 then throw("No entry")
1119- else [DeleteEntry((((((((toString(i.caller) + "_") + toString(posId)) + "_") + poolId) + "_") + assetId) + kUserStopLoss))]
1173+ else [DeleteEntry((((((((toString(i.caller) + "_") + toString(posId)) + "_") + poolId) + "_") + assetId) + kUserStopLoss))])
11201174
11211175
11221176
11231177 @Callable(i)
11241178 func init (moneyBoxAddr,sfFarmingAddr,lendAddr,priceOracleAddr,keeperExContract,wxSwapContract,swopAssetId,wxAssetId,adminPubKey) = if ((toString(i.caller) != "3PG42y6FgT8zM3uX5tEDxJF5rqX8AKGJRAR"))
11251179 then throw("Only admin can call this function")
11261180 else if (isDefined(getString(kAdminCallPK)))
11271181 then throw("Already inited")
11281182 else [StringEntry(kMoneyBox, moneyBoxAddr), StringEntry(kSFFarmingAddr, sfFarmingAddr), StringEntry(kLendService, lendAddr), StringEntry(kPriceOracle, priceOracleAddr), StringEntry(kExContract, keeperExContract), StringEntry(kWxSwapContract, wxSwapContract), StringEntry(kSwopId, swopAssetId), StringEntry(kWxId, wxAssetId), StringEntry(kAdminCallPK, adminPubKey)]
11291183
11301184
11311185
11321186 @Callable(i)
11331187 func createNewRequest (params) = valueOrElse(isSelfCall(i), {
11341188 let newRequestId = (valueOrElse(getInteger(this, kRequestIter), 0) + 1)
11351189 $Tuple2([StringEntry((toString(newRequestId) + kRequestId), params), IntegerEntry(kRequestIter, newRequestId)], newRequestId)
11361190 })
11371191
11381192
11391193
11401194 @Callable(i)
1141-func replenishFromLand (requestId) = valueOrElse(isLandCall(i), {
1142- let $t03720037304 = parseRequest(requestId)
1143- let user = $t03720037304._1
1144- let pool = $t03720037304._2
1145- let pmtA = $t03720037304._3
1146- let AId = $t03720037304._4
1147- let pmtB = $t03720037304._5
1148- let BId = $t03720037304._6
1149- let balA = $t03720037304._7
1150- let balB = $t03720037304._8
1151- let shareId = $t03720037304._9
1152- let bwAsset = $t03720037304._10
1153- let bwAmount = $t03720037304._11
1195+func replenishFromLand (requestId) = valueOrElse(isActive(), valueOrElse(isLandCall(i), {
1196+ let $t03890939013 = parseRequest(requestId)
1197+ let user = $t03890939013._1
1198+ let pool = $t03890939013._2
1199+ let pmtA = $t03890939013._3
1200+ let AId = $t03890939013._4
1201+ let pmtB = $t03890939013._5
1202+ let BId = $t03890939013._6
1203+ let balA = $t03890939013._7
1204+ let balB = $t03890939013._8
1205+ let shareId = $t03890939013._9
1206+ let bwAsset = $t03890939013._10
1207+ let bwAmount = $t03890939013._11
11541208 if ((size(i.payments) != 1))
11551209 then throw("Wrong payment size")
11561210 else if (if ((assetIdToStr(i.payments[0].assetId) != bwAsset))
11571211 then true
11581212 else (i.payments[0].amount != bwAmount))
11591213 then throw("Wrong payment")
11601214 else {
1161- let $t03749437594 = if ((AId == bwAsset))
1215+ let $t03920339303 = if ((AId == bwAsset))
11621216 then $Tuple2((pmtA + bwAmount), pmtB)
11631217 else $Tuple2(pmtA, (pmtB + bwAmount))
1164- let pmtAllA = $t03749437594._1
1165- let pmtAllB = $t03749437594._2
1218+ let pmtAllA = $t03920339303._1
1219+ let pmtAllB = $t03920339303._2
11661220 let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Unknown pool")
1167- let $t03767637791 = replenishByType(pType, pool, LOAN_FEE, pmtAllA, AId, pmtAllB, BId, balA, balB, shareId)
1168- let userStaked = $t03767637791._1
1169- let axlyFee = $t03767637791._2
1221+ let $t03938539500 = replenishByType(pType, pool, LOAN_FEE, pmtAllA, AId, pmtAllB, BId, balA, balB, shareId)
1222+ let userStaked = $t03938539500._1
1223+ let axlyFee = $t03938539500._2
11701224 let posNum = getNewUserPositionNumber(user)
11711225 let borrowEntries = [IntegerEntry((((((pool + "_") + user) + "_") + toString(posNum)) + kUserBorrowAmount), bwAmount), StringEntry((((((pool + "_") + user) + "_") + toString(posNum)) + kUserBorrowAssetId), bwAsset)]
11721226 let entries = replenishEntries(pool, user, userStaked, axlyFee, posNum, shareId, pType, true)
1173- let $t03815138266 = calcWithdrawLPFromPoolVirt(Address(fromBase58String(pool)), pType, shareId, userStaked)
1174- let wAmountA = $t03815138266._1
1175- let wAmountB = $t03815138266._2
1227+ let $t03986039975 = calcWithdrawLPFromPoolVirt(Address(fromBase58String(pool)), pType, shareId, userStaked)
1228+ let wAmountA = $t03986039975._1
1229+ let wAmountB = $t03986039975._2
11761230 $Tuple2((((entries ++ getCursEntries(AId, BId, shareId, [toString(wAmountA), toString(wAmountB)])) ++ borrowEntries) :+ DeleteEntry((requestId + kRequestId))), userStaked)
11771231 }
1178- })
1232+ }))
11791233
11801234
11811235
11821236 @Callable(i)
1183-func liquidate (user,posId,liquidateAmount) = valueOrElse(isLandCall(i), {
1237+func liquidate (user,posId,liquidateAmount) = valueOrElse(isActive(), valueOrElse(isLandCall(i), {
11841238 let pool = valueOrErrorMessage(getString(this, (((user + "_") + posId) + kUserPositionPool)), "no position")
11851239 let pType = valueOrErrorMessage(getString(this, (kPool + pool)), "Pool is not inited")
1186- let $t03876138851 = getPoolData(Address(fromBase58String(pool)), pType)
1187- let AId = $t03876138851._1
1188- let BId = $t03876138851._2
1189- let balA = $t03876138851._3
1190- let balB = $t03876138851._4
1191- let shareId = $t03876138851._5
1240+ let $t04049640586 = getPoolData(Address(fromBase58String(pool)), pType)
1241+ let AId = $t04049640586._1
1242+ let BId = $t04049640586._2
1243+ let balA = $t04049640586._3
1244+ let balB = $t04049640586._4
1245+ let shareId = $t04049640586._5
11921246 let amount = unstakeLP(pool, pType, shareId, liquidateAmount)
11931247 let borrowAmount = getIntegerValue(this, (((((pool + "_") + user) + "_") + posId) + kUserBorrowAmount))
11941248 let borrowAsset = getStringValue(this, (((((pool + "_") + user) + "_") + posId) + kUserBorrowAssetId))
11951249 let userCanWithdraw = userCanWithdrawShareCalc(user, pool, posId, (borrowAmount > 0))
11961250 if ((liquidateAmount > userCanWithdraw))
11971251 then throw("You can't liquidate more than user have")
11981252 else if ((borrowAmount == 0))
11991253 then throw("You can't liquidate position without borrow")
12001254 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))]
1201- })
1255+ }))
12021256
12031257
12041258
12051259 @Callable(i)
1206-func stopLoss (user,posId,pool,assetId) = valueOrElse(isAdminCall(i), {
1260+func stopLoss (user,posId,pool,assetId) = valueOrElse(isActive(), valueOrElse(isAdminCall(i), {
12071261 let tokenOraclePrice = getIntegerValue(priceOracleAddr, (assetId + kPriceInOracle))
12081262 if ((tokenOraclePrice > tokenOraclePrice))
12091263 then throw("Token price greater stop loss price")
12101264 else if (!(isDefined(getInteger(this, (((((((user + "_") + toString(posId)) + "_") + pool) + "_") + assetId) + kUserStopLoss)))))
12111265 then throw("No entry")
12121266 else (withdrawToUser(user, pool, toString(posId), true) :+ DeleteEntry((((((((user + "_") + toString(posId)) + "_") + pool) + "_") + assetId) + kUserStopLoss)))
1213- })
1267+ }))
12141268
12151269
12161270
12171271 @Callable(i)
1218-func capitalizeExKeeper (pool,tokenToId,amountToExchange,claim,amountsIn,addresses,assetsToReceive,estReceived,slippageTolerance,minReceived,options) = valueOrElse(isAdminCall(i), {
1272+func capitalizeExKeeper (pool,tokenToId,amountToExchange,claim,amountsIn,addresses,assetsToReceive,estReceived,slippageTolerance,minReceived,options) = valueOrElse(isActive(), valueOrElse(isAdminCall(i), {
12191273 let pType = getStringValue(this, (kPool + pool))
1220- let $t04082441115 = if (claim)
1221- then claimFarmed(pType, pool)
1222- else {
1223- let claimedAsset = if ((pType == SF_POOL))
1224- then SWOPID
1225- else if ((pType == WX_POOL))
1226- then WXID
1227- else unknownPoolType()
1228- $Tuple2(amountToExchange, claimedAsset)
1229- }
1230- let claimedAmount = $t04082441115._1
1231- let claimedAsset = $t04082441115._2
1274+ let change = valueOrElse(getInteger(this, (pool + kPoolCapChange)), 0)
1275+ let $t04268042781 = claimAndCheckAmntEx(pool, pType, claim, amountToExchange, change)
1276+ let claimedAmount = $t04268042781._1
1277+ let claimedAsset = $t04268042781._2
12321278 let exchangedAmount = exchangeKeeper(tokenToId, amountToExchange, claimedAsset, amountsIn, addresses, assetsToReceive, estReceived, slippageTolerance, minReceived, options)
1233- let change = (claimedAmount - amountToExchange)
1234- let changeEntry = if ((change > 0))
1235- then [IntegerEntry((pool + kPoolCapChange), (change + valueOrElse(getInteger(this, (pool + kPoolCapChange)), 0)))]
1279+ let newChange = ((claimedAmount + change) - amountToExchange)
1280+ let changeEntry = if ((newChange >= 0))
1281+ then [IntegerEntry((pool + kPoolCapChange), newChange)]
12361282 else nil
12371283 (capitalize(pool, pType, tokenToId, exchangedAmount) ++ changeEntry)
1238- })
1284+ }))
12391285
12401286
12411287
12421288 @Callable(i)
1243-func capitalizeExPuzzle (pool,tokenToId,amountToExchange,claim,routesStr,minToReceive,options) = valueOrElse(isAdminCall(i), {
1289+func capitalizeExPuzzle (pool,tokenToId,amountToExchange,claim,routesStr,minToReceive,options) = valueOrElse(isActive(), valueOrElse(isAdminCall(i), {
12441290 let pType = getStringValue(this, (kPool + pool))
1245- let $t04183242123 = if (claim)
1246- then claimFarmed(pType, pool)
1247- else {
1248- let claimedAsset = if ((pType == SF_POOL))
1249- then SWOPID
1250- else if ((pType == WX_POOL))
1251- then WXID
1252- else unknownPoolType()
1253- $Tuple2(amountToExchange, claimedAsset)
1254- }
1255- let claimedAmount = $t04183242123._1
1256- let claimedAsset = $t04183242123._2
1291+ let change = valueOrElse(getInteger(this, (pool + kPoolCapChange)), 0)
1292+ let $t04355643657 = claimAndCheckAmntEx(pool, pType, claim, amountToExchange, change)
1293+ let claimedAmount = $t04355643657._1
1294+ let claimedAsset = $t04355643657._2
12571295 let exchangedAmount = exchangePuzzle(tokenToId, amountToExchange, claimedAsset, routesStr, minToReceive, options)
1258- let change = (claimedAmount - amountToExchange)
1259- let changeEntry = if ((change > 0))
1260- then [IntegerEntry((pool + kPoolCapChange), (change + valueOrElse(getInteger(this, (pool + kPoolCapChange)), 0)))]
1296+ let newChange = ((claimedAmount + change) - amountToExchange)
1297+ let changeEntry = if ((newChange >= 0))
1298+ then [IntegerEntry((pool + kPoolCapChange), newChange)]
12611299 else nil
12621300 (capitalize(pool, pType, tokenToId, exchangedAmount) ++ changeEntry)
1263- })
1301+ }))
12641302
12651303
12661304
12671305 @Callable(i)
1268-func capitalizeExSwopFi (pool,tokenToId,amountToExchange,claim,exchangers,exchangersType,args1,args2,routingAssetsKeys,minAmountToReceive,options) = valueOrElse(isAdminCall(i), {
1306+func capitalizeExSwopFi (pool,tokenToId,amountToExchange,claim,exchangers,exchangersType,args1,args2,routingAssetsKeys,minAmountToReceive,options) = valueOrElse(isActive(), valueOrElse(isAdminCall(i), {
12691307 let pType = getStringValue(this, (kPool + pool))
1270- let $t04290743198 = if (claim)
1271- then claimFarmed(pType, pool)
1272- else {
1273- let claimedAsset = if ((pType == SF_POOL))
1274- then SWOPID
1275- else if ((pType == WX_POOL))
1276- then WXID
1277- else unknownPoolType()
1278- $Tuple2(amountToExchange, claimedAsset)
1279- }
1280- let claimedAmount = $t04290743198._1
1281- let claimedAsset = $t04290743198._2
1308+ let change = valueOrElse(getInteger(this, (pool + kPoolCapChange)), 0)
1309+ let $t04449944600 = claimAndCheckAmntEx(pool, pType, claim, amountToExchange, change)
1310+ let claimedAmount = $t04449944600._1
1311+ let claimedAsset = $t04449944600._2
12821312 let exchangedAmount = exchangeSwopFi(tokenToId, amountToExchange, claimedAsset, exchangers, exchangersType, args1, args2, routingAssetsKeys, minAmountToReceive, options)
1283- let change = (claimedAmount - amountToExchange)
1284- let changeEntry = if ((change > 0))
1285- then [IntegerEntry((pool + kPoolCapChange), (change + valueOrElse(getInteger(this, (pool + kPoolCapChange)), 0)))]
1313+ let newChange = ((claimedAmount + change) - amountToExchange)
1314+ let changeEntry = if ((newChange >= 0))
1315+ then [IntegerEntry((pool + kPoolCapChange), newChange)]
12861316 else nil
12871317 (capitalize(pool, pType, tokenToId, exchangedAmount) ++ changeEntry)
1288- })
1318+ }))
12891319
12901320
12911321
12921322 @Callable(i)
1293-func initNewPool (type,poolAddr,inFeeNoLoan,inFeeLoan,capFeeNoLoan,capFeeWithLoan,stoplossFeeNoLoan,stoplossFeeWithLoan,canBorrow) = valueOrElse(isAdminCall(i), if (if ((type != SF_POOL))
1323+func initNewPool (type,poolAddr,inFeeNoLoan,inFeeLoan,capFeeNoLoan,capFeeWithLoan,stoplossFeeNoLoan,stoplossFeeWithLoan,canBorrow) = valueOrElse(isActive(), valueOrElse(isAdminCall(i), if (if ((type != SF_POOL))
12941324 then (type != WX_POOL)
12951325 else false)
12961326 then throw("Wrong type")
12971327 else {
1298- let $t04394044034 = getPoolData(Address(fromBase58String(poolAddr)), type)
1299- let aId = $t04394044034._1
1300- let bId = $t04394044034._2
1301- let aBal = $t04394044034._3
1302- let bBal = $t04394044034._4
1303- let shareId = $t04394044034._5
1328+ let $t04533145425 = getPoolData(Address(fromBase58String(poolAddr)), type)
1329+ let aId = $t04533145425._1
1330+ let bId = $t04533145425._2
1331+ let aBal = $t04533145425._3
1332+ let bBal = $t04533145425._4
1333+ let shareId = $t04533145425._5
13041334 if ((0 > inFeeNoLoan))
13051335 then throw("inFeeNoLoan must be greater than 0")
13061336 else if ((0 > inFeeLoan))
13071337 then throw("inFeeLoan must be greater than 0")
13081338 else if ((0 > capFeeNoLoan))
13091339 then throw("capFeeNoLoan must be greater than 0")
13101340 else if ((0 > capFeeWithLoan))
13111341 then throw("capFeeWithLoan must be greater than 0")
13121342 else if ((0 > stoplossFeeNoLoan))
13131343 then throw("stoplossFeeNoLoan must be greater than 0")
13141344 else if ((0 > stoplossFeeWithLoan))
13151345 then throw("stoplossFeeWithLoan must be greater than 0")
13161346 else [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), BooleanEntry((poolAddr + kPoolCanBorrow), canBorrow)]
1317- })
1347+ }))
1348+
1349+
1350+
1351+@Callable(i)
1352+func activate () = valueOrElse(isAdminCall(i), if (valueOrElse(getBoolean(this, kActive), true))
1353+ then throw("dApp already active")
1354+ else [BooleanEntry(kActive, true)])
1355+
1356+
1357+
1358+@Callable(i)
1359+func shutdown () = valueOrElse(isAdminCall(i), if (!(valueOrElse(getBoolean(this, kActive), true)))
1360+ then throw("dApp already shutdown")
1361+ else [BooleanEntry(kActive, false)])
1362+
1363+
1364+
1365+@Callable(i)
1366+func activateForUsers () = valueOrElse(isAdminCall(i), if (valueOrElse(getBoolean(this, kActiveUsers), true))
1367+ then throw("dApp already active for users")
1368+ else [BooleanEntry(kActive, true)])
1369+
1370+
1371+
1372+@Callable(i)
1373+func shutdownForUsers () = valueOrElse(isAdminCall(i), if (!(valueOrElse(getBoolean(this, kActiveUsers), true)))
1374+ then throw("dApp already shutdown for users")
1375+ else [BooleanEntry(kActive, false)])
1376+
1377+
1378+
1379+@Callable(i)
1380+func activateSF () = valueOrElse(isAdminCall(i), if (valueOrElse(getBoolean(this, (SF_POOL + kActiveSFWX)), true))
1381+ then throw("SWOPFI already active")
1382+ else [BooleanEntry(kActive, true)])
1383+
1384+
1385+
1386+@Callable(i)
1387+func shutdownSF () = valueOrElse(isAdminCall(i), if (!(valueOrElse(getBoolean(this, (SF_POOL + kActiveSFWX)), true)))
1388+ then throw("SWOPFI already shutdown")
1389+ else [BooleanEntry(kActive, false)])
1390+
1391+
1392+
1393+@Callable(i)
1394+func activateWX () = valueOrElse(isAdminCall(i), if (valueOrElse(getBoolean(this, (WX_POOL + kActiveSFWX)), true))
1395+ then throw("WX already active")
1396+ else [BooleanEntry(kActive, true)])
1397+
1398+
1399+
1400+@Callable(i)
1401+func shutdownWX () = valueOrElse(isAdminCall(i), if (!(valueOrElse(getBoolean(this, (WX_POOL + kActiveSFWX)), true)))
1402+ then throw("WX already shutdown")
1403+ else [BooleanEntry(kActive, false)])
1404+
1405+
1406+
1407+@Callable(i)
1408+func activatePool (pool) = valueOrElse(isAdminCall(i), if (!(isDefined(getString(this, (kPool + pool)))))
1409+ then throw("Unknown pool")
1410+ else if (valueOrElse(getBoolean(this, (pool + kPoolActive)), true))
1411+ then throw("Pool already active")
1412+ else [BooleanEntry(kActive, true)])
1413+
1414+
1415+
1416+@Callable(i)
1417+func shutdownPool (pool) = valueOrElse(isAdminCall(i), if (!(isDefined(getString(this, (kPool + pool)))))
1418+ then throw("Unknown pool")
1419+ else if (!(valueOrElse(getBoolean(this, (pool + kPoolActive)), true)))
1420+ then throw("Pool already shutdown")
1421+ else [BooleanEntry(kActive, false)])
13181422
13191423
13201424 @Verifier(tx)
13211425 func verify () = sigVerify(tx.bodyBytes, tx.proofs[0], tx.senderPublicKey)
13221426

github/deemru/w8io/3ef1775 
375.52 ms