tx · 28aSmpGDfKD9GV8CHW9zg3RFD3scEZibnKivKdKXpU85 3P2mUshsGaj2B5A9rSD4wwXk47fHB16Sidk: -0.04200000 Waves 2024.03.01 22:42 [4065215] smart account 3P2mUshsGaj2B5A9rSD4wwXk47fHB16Sidk > SELF 0.00000000 Waves
{ "type": 13, "id": "28aSmpGDfKD9GV8CHW9zg3RFD3scEZibnKivKdKXpU85", "fee": 4200000, "feeAssetId": null, "timestamp": 1709322107951, "version": 2, "chainId": 87, "sender": "3P2mUshsGaj2B5A9rSD4wwXk47fHB16Sidk", "senderPublicKey": "46pxd1r6gmScNqdp82uEJMs2AZ1F9q2z1VtXZPFAtHYy", "proofs": [ "3Y9skCB3QTCg8uNjxt29RMpY4xgGrsd2nNVgmSkvd3gLyF2QnXonQWZiZ7it1mZA2KeY2v1HP4G3AJiduYrVB5bE" ], "script": "base64:BgICCAI2AAVXYXZlcwIFV0FWRVMABlNjYWxlNgDAhD0ABlNjYWxlOACAwtcvAAlTY2FsZThCaWcJALYCAQCAwtcvAAdTY2FsZTEwAIDIr6AlAAdTY2FsZTE2AICAhP6m3uERAApTY2FsZTE2QmlnCQC2AgEAgICE/qbe4REACWRheUJsb2NrcwCgCwAKeWVhckJsb2NrcwCgiiAADXllYXJCbG9ja3NCaWcJALYCAQCgiiAAC3Jlc2VydmVGdW5kABQABWFycjEyCQDMCAIAAAkAzAgCAAEJAMwIAgACCQDMCAIAAwkAzAgCAAQJAMwIAgAFCQDMCAIABgkAzAgCAAcJAMwIAgAICQDMCAIACQkAzAgCAAoJAMwIAgALBQNuaWwACXVzZHRJZFN0cgIsOXdjM0xYTkE0VEVCc1h5S3RvTEU5bXJiREQ3V01IWHZYckNqWnZhYkxBc2kACXVzZGNJZFN0cgIsSEdnYWJUcVVTOFd0VkZVSnpmbXJURE1nRWNjSnVaTEJQaEZnUUZ4dm5zb1cACXJvbWVJZFN0cgIsQVA0Q2I1eExZR0g2WmlnSHJlQ1pIb1hwUVRXRGtQc0cyQkhxZkRVeDZ0YUoAEG9yYWNsZUFkZHJlc3NTdHICIzNQOGQxRTFCTEtvRDUyeTNiUUoxYkRUZDJURDFncGFMbjl0AAtheGx5QWRkcmVzcwkBB0FkZHJlc3MBARoBV8/Idd4LdvyJm/d7rwlIRGcJKlBHPw9CLQAHYXhseUxQcwkAzAgCAiw3S1piSnJWb3B3SmhrZHdiZTFlRkRCYmV4NGRrWTYzTXhqVE5qcVh0cnpqMQkAzAgCAixCdHczRzFqNHdRZ2RwNDlQVHhhRmtOdm43NWRRdHFHRE03ZWpRcHBIbldDMQkAzAgCAixCaVN6RmU4blNMNzhvWmFlYmZvaW41dkJaNVB6ZTZkN2thZWlqTHFyNXhaZQkAzAgCAixGMkFLa0E1MTNrNXlIRUprTHNVNnZXeENZWWs4MTFHcGpMaHdFdjJXR3daOQkAzAgCAiw0Q1E1Q1BHTFhMYldCVXMySkJqS1VhUnFGNDlDbUtIa3d6dlBnU3ZRcEFRVgkAzAgCAiw2aU1CNkxLU3Jndjl3YUV2RW5ONllkeXg3ZGZ4UG5HY1R3ODMxOFdWbTViUgUDbmlsAQxnZXRSYXRlQ3VydmUCCmFzc2V0SWRTdHIJbWFya2V0U3RyBA1tYXJrZXRBZGRyZXNzCQERQGV4dHJOYXRpdmUoMTA2MikBBQltYXJrZXRTdHIEDnNldHVwUmF0ZUN1cnZlCQCdCAIFDW1hcmtldEFkZHJlc3MJAKwCAgIQc2V0dXBfcmF0ZUN1cnZlXwUKYXNzZXRJZFN0cgMJAQlpc0RlZmluZWQBBQ5zZXR1cFJhdGVDdXJ2ZQQIY3VydmVBcnIJALwJAgkBBXZhbHVlAQUOc2V0dXBSYXRlQ3VydmUCASwJAJYKBAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCGN1cnZlQXJyAAAJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQhjdXJ2ZUFycgABCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUIY3VydmVBcnIAAgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCGN1cnZlQXJyAAMEByRtYXRjaDAFCW1hcmtldFN0cgMJAAACAiMzUDR1QTVldG5aaTRBbUJhYktpbnEyYk1pV1U4S2NuSFpkSAUHJG1hdGNoMAQHJG1hdGNoMQUKYXNzZXRJZFN0cgMJAAACAiw5d2MzTFhOQTRURUJzWHlLdG9MRTltcmJERDdXTUhYdlhyQ2padmFiTEFzaQUHJG1hdGNoMQkAlgoEAICJegDA8PULAIDokiYAgMLXLwMJAAACAixIR2dhYlRxVVM4V3RWRlVKemZtclRETWdFY2NKdVpMQlBoRmdRRnh2bnNvVwUHJG1hdGNoMQkAlgoEAICJegDA8PULAIDokiYAgMLXLwMJAAACAiwzNE45WWNFRVRMV245M3FZUTY0RXNQMXg4OXRTcnVKVTQ0UnJFTVNYWEVQSgUHJG1hdGNoMQkAlgoEAICJegDA8PULAIDokiYAgMLXLwMJAAACAiw2WHRIanBYYnM5UlJKUDJTcjlHVXlWcXpBQ2NieTlUa1RoSFhualZDNUNESgUHJG1hdGNoMQkAlgoEAICJegDA8PULAIDokiYAgMLXLwMJAAACAixERzJ4RmtQZER3S1VvQmt6R0FoUXRMcFNHemZYTGlDWVBFemVLSDJBZDI0cAUHJG1hdGNoMQkAlgoEAICJegDA8PULAIDokiYAgMLXLwMJAAACAixBanNvNm5UVGpwdHUyVUhMeDZoZlNYVnRIRnRSQkpDa0tZZDVTQXlqN3pmNQUHJG1hdGNoMQkAlgoEAICJegCAtIkTAIDokiYAgKPDRwMJAAACAixIRUI4UWF3OXhyV3BXczh0SHNpQVRZR0JXREJ0UDJTN2tjUEFMck11NDNBUwUHJG1hdGNoMQkAlgoEAAAAgMLXLwCA6JImAICI3r4BAwkAAAICBVdBVkVTBQckbWF0Y2gxCQCWCgQAgIl6AICHpw4AgOiSJgCAlfUqAwkAAAICLEF0cXY1OUVZempGR3VpdEtWbk1SazZIOEZ1a2pvVjNrdFBvcmJFeXMyNW9uBQckbWF0Y2gxCQCWCgQAAACA2sQJAIDokiYAgLSJEwMJAAACAixEU2JiaExzU1RlRGc1THNpdWZrMkFuZWgzRGpWcUp1UHIyTTl1VTFnd3k1cAUHJG1hdGNoMQkAlgoEAAAAgNrECQCA6JImAIDC1y8DCQAAAgIsOHQ0RFBXVHdQenBhdEhBOUFrVHhXQUI0N1RIbll6QnNEbm9ZN2ZRcWJHOTEFByRtYXRjaDEJAJYKBAAAAICHpw4AgOiSJgCAtIkTAwkAAAICLEF0OEQ2TkZGcGhlQ2J2S1ZualZvZUxMODRFbzhOWm42b3ZNYW54ZkxhRldMBQckbWF0Y2gxCQCWCgQAAADA8PULAIDokiYAgLSJEwMJAAACAiw4TFFXOGY3UDVkNVBaTTdHdFpFQmdhcVJQR1N6UzNEZlB1aVhyVVJKNEFKUwUHJG1hdGNoMQkAlgoEAICJegCAh6cOAIDokiYAgOHrFwMJAAACAiw0NzRqVGVZeDJyMlZhMzU3OTR0Q1NjQVhXSkc5aFUySGNneHpNb3dhWlVudQUHJG1hdGNoMQkAlgoEAICJegCAh6cOAIDokiYAgOHrFwMJAAACAiw1VVlCUHBxNFdvVTVuNE13cEZrZ0puVzNGcTRCMXUzdWtwSzMzaWs0UWVyUgUHJG1hdGNoMQkAlgoEAICJegCAh6cOAIDokiYAgOHrFwMJAAACAiwydGhzQUN1SG16RE11TmV6UE0zMndnOWEzQndVekJXRGVTS2FrZ3ozY3cyMQUHJG1hdGNoMQkAlgoEAICJegCAtIkTAIDokiYAgMLXLwMJAAACAitZaU5ib2ZGekMxN2pFSEhDTXdyUmNweTlNcnJqYWJNTUxaeGc4ZzV4bWY3BQckbWF0Y2gxCQCWCgQAgIl6AICHpw4AgOiSJgCA6JImAwkAAAICLDl3YzNMWE5BNFRFQnNYeUt0b0xFOW1yYkREN1dNSFh2WHJDalp2YWJMQXNpBQckbWF0Y2gxCQCWCgQAAACA4esXAIDokiYAgISvXwMJAAACAiwzVnVWNVdUbUR6NDdEbWRuM1FwY1lqemJTZGlwalFFNEpNZE5lMXhacFgxMwUHJG1hdGNoMQkAlgoEAAAAgMLXLwCA6JImAICI3r4BCQCWCgQAAACA2sQJAIDokiYAgOiSJgMJAAACAiMzUDhEZjJiN3l3SHRMQkhCZThQQlZRWWQzQTVNZEVFSkFvdQUHJG1hdGNoMAkAlgoEAIDaxAkAgMLXLwCAjs4cAICI3r4BAwkAAAICIzNQNERLNVZ6RHdMM3ZmYzVhaFVFaHRvZTVCeVpOeWFjSjNYBQckbWF0Y2gwBAckbWF0Y2gxBQphc3NldElkU3RyAwkAAAICLDl3YzNMWE5BNFRFQnNYeUt0b0xFOW1yYkREN1dNSFh2WHJDalp2YWJMQXNpBQckbWF0Y2gxCQCWCgQAgIl6AMDw9QsAgOiSJgCAwtcvAwkAAAICLEhHZ2FiVHFVUzhXdFZGVUp6Zm1yVERNZ0VjY0p1WkxCUGhGZ1FGeHZuc29XBQckbWF0Y2gxCQCWCgQAgIl6AMDw9QsAgOiSJgCAwtcvAwkAAAICLDM0TjlZY0VFVExXbjkzcVlRNjRFc1AxeDg5dFNydUpVNDRSckVNU1hYRVBKBQckbWF0Y2gxCQCWCgQAgIl6AMDw9QsAgOiSJgCAwtcvAwkAAAICLDZYdEhqcFhiczlSUkpQMlNyOUdVeVZxekFDY2J5OVRrVGhIWG5qVkM1Q0RKBQckbWF0Y2gxCQCWCgQAgIl6AMDw9QsAgOiSJgCAwtcvAwkAAAICLERHMnhGa1BkRHdLVW9Ca3pHQWhRdExwU0d6ZlhMaUNZUEV6ZUtIMkFkMjRwBQckbWF0Y2gxCQCWCgQAgIl6AMDw9QsAgOiSJgCAwtcvAwkAAAICLEFqc282blRUanB0dTJVSEx4NmhmU1hWdEhGdFJCSkNrS1lkNVNBeWo3emY1BQckbWF0Y2gxCQCWCgQAgIl6AIC0iRMAgOiSJgCAo8NHAwkAAAICLEhFQjhRYXc5eHJXcFdzOHRIc2lBVFlHQldEQnRQMlM3a2NQQUxyTXU0M0FTBQckbWF0Y2gxCQCWCgQAAACA4esXAIDokiYAgIjevgEDCQAAAgIFV0FWRVMFByRtYXRjaDEJAJYKBACAiXoAgIenDgCA6JImAIDokiYDCQAAAgIsQXRxdjU5RVl6akZHdWl0S1ZuTVJrNkg4RnVram9WM2t0UG9yYkV5czI1b24FByRtYXRjaDEJAJYKBAAAAIDaxAkAgOiSJgCAtIkTAwkAAAICLERTYmJoTHNTVGVEZzVMc2l1ZmsyQW5laDNEalZxSnVQcjJNOXVVMWd3eTVwBQckbWF0Y2gxCQCWCgQAAACA2sQJAIDokiYAgMLXLwMJAAACAiw4dDREUFdUd1B6cGF0SEE5QWtUeFdBQjQ3VEhuWXpCc0Rub1k3ZlFxYkc5MQUHJG1hdGNoMQkAlgoEAAAAgIenDgCA6JImAIC0iRMDCQAAAgIsQXQ4RDZORkZwaGVDYnZLVm5qVm9lTEw4NEVvOE5abjZvdk1hbnhmTGFGV0wFByRtYXRjaDEJAJYKBAAAAMDw9QsAgOiSJgCAtIkTAwkAAAICLDhMUVc4ZjdQNWQ1UFpNN0d0WkVCZ2FxUlBHU3pTM0RmUHVpWHJVUko0QUpTBQckbWF0Y2gxCQCWCgQAgIl6AICHpw4AgOiSJgCA4esXAwkAAAICLDQ3NGpUZVl4MnIyVmEzNTc5NHRDU2NBWFdKRzloVTJIY2d4ek1vd2FaVW51BQckbWF0Y2gxCQCWCgQAgIl6AICHpw4AgOiSJgCA4esXAwkAAAICLDVVWUJQcHE0V29VNW40TXdwRmtnSm5XM0ZxNEIxdTN1a3BLMzNpazRRZXJSBQckbWF0Y2gxCQCWCgQAgIl6AICHpw4AgOiSJgCA4esXAwkAAAICLDJ0aHNBQ3VIbXpETXVOZXpQTTMyd2c5YTNCd1V6QldEZVNLYWtnejNjdzIxBQckbWF0Y2gxCQCWCgQAgIl6AIC0iRMAgOiSJgCAwtcvAwkAAAICK1lpTmJvZkZ6QzE3akVISENNd3JSY3B5OU1ycmphYk1NTFp4ZzhnNXhtZjcFByRtYXRjaDEJAJYKBACAiXoAgIenDgCA6JImAIDokiYDCQAAAgIsOXdjM0xYTkE0VEVCc1h5S3RvTEU5bXJiREQ3V01IWHZYckNqWnZhYkxBc2kFByRtYXRjaDEJAJYKBAAAAIDh6xcAgOiSJgCAhK9fAwkAAAICLDNWdVY1V1RtRHo0N0RtZG4zUXBjWWp6YlNkaXBqUUU0Sk1kTmUxeFpwWDEzBQckbWF0Y2gxCQCWCgQAAACAwtcvAIDokiYAgIjevgEJAJYKBAAAAIDaxAkAgOiSJgCA6JImAwkAAAICIzNQSHB1UVVQVlVvUjNBWXpGZUp6ZVdKZllMc0xUbVdzc1ZIBQckbWF0Y2gwCQCWCgQAgNrECQCAwtcvAICOzhwAgIjevgEDCQAAAgIjM1BBZDlBcWczY1FTenUyNk1GWVdRWWNqU1hQVkNKdHVmNVYFByRtYXRjaDAEByRtYXRjaDEFCmFzc2V0SWRTdHIDCQAAAgIsOXdjM0xYTkE0VEVCc1h5S3RvTEU5bXJiREQ3V01IWHZYckNqWnZhYkxBc2kFByRtYXRjaDEJAJYKBACAiXoAwPD1CwCA6JImAIDC1y8DCQAAAgIsSEdnYWJUcVVTOFd0VkZVSnpmbXJURE1nRWNjSnVaTEJQaEZnUUZ4dm5zb1cFByRtYXRjaDEJAJYKBACAiXoAwPD1CwCA6JImAIDC1y8DCQAAAgIsMzROOVljRUVUTFduOTNxWVE2NEVzUDF4ODl0U3J1SlU0NFJyRU1TWFhFUEoFByRtYXRjaDEJAJYKBACAiXoAwPD1CwCA6JImAIDC1y8DCQAAAgIsNlh0SGpwWGJzOVJSSlAyU3I5R1V5VnF6QUNjYnk5VGtUaEhYbmpWQzVDREoFByRtYXRjaDEJAJYKBACAiXoAwPD1CwCA6JImAIDC1y8DCQAAAgIsREcyeEZrUGREd0tVb0JrekdBaFF0THBTR3pmWExpQ1lQRXplS0gyQWQyNHAFByRtYXRjaDEJAJYKBACAiXoAwPD1CwCA6JImAIDC1y8DCQAAAgIsQWpzbzZuVFRqcHR1MlVITHg2aGZTWFZ0SEZ0UkJKQ2tLWWQ1U0F5ajd6ZjUFByRtYXRjaDEJAJYKBACAiXoAgLSJEwCA6JImAICjw0cDCQAAAgIsSEVCOFFhdzl4cldwV3M4dEhzaUFUWUdCV0RCdFAyUzdrY1BBTHJNdTQzQVMFByRtYXRjaDEJAJYKBAAAAIDaxAkAgOiSJgCAtIkTAwkAAAICBVdBVkVTBQckbWF0Y2gxCQCWCgQAgIl6AICHpw4AgOiSJgCA4esXAwkAAAICLEF0cXY1OUVZempGR3VpdEtWbk1SazZIOEZ1a2pvVjNrdFBvcmJFeXMyNW9uBQckbWF0Y2gxCQCWCgQAAACA2sQJAIDokiYAgLSJEwMJAAACAixEU2JiaExzU1RlRGc1THNpdWZrMkFuZWgzRGpWcUp1UHIyTTl1VTFnd3k1cAUHJG1hdGNoMQkAlgoEAAAAgNrECQCA6JImAIDC1y8DCQAAAgIsOHQ0RFBXVHdQenBhdEhBOUFrVHhXQUI0N1RIbll6QnNEbm9ZN2ZRcWJHOTEFByRtYXRjaDEJAJYKBAAAAICHpw4AgOiSJgCAtIkTAwkAAAICLEF0OEQ2TkZGcGhlQ2J2S1ZualZvZUxMODRFbzhOWm42b3ZNYW54ZkxhRldMBQckbWF0Y2gxCQCWCgQAAADA8PULAIDokiYAgLSJEwMJAAACAiw4TFFXOGY3UDVkNVBaTTdHdFpFQmdhcVJQR1N6UzNEZlB1aVhyVVJKNEFKUwUHJG1hdGNoMQkAlgoEAICJegCAh6cOAIDokiYAgOHrFwMJAAACAiw0NzRqVGVZeDJyMlZhMzU3OTR0Q1NjQVhXSkc5aFUySGNneHpNb3dhWlVudQUHJG1hdGNoMQkAlgoEAICJegCAh6cOAIDokiYAgOHrFwMJAAACAiw1VVlCUHBxNFdvVTVuNE13cEZrZ0puVzNGcTRCMXUzdWtwSzMzaWs0UWVyUgUHJG1hdGNoMQkAlgoEAICJegCAh6cOAIDokiYAgOHrFwMJAAACAiwydGhzQUN1SG16RE11TmV6UE0zMndnOWEzQndVekJXRGVTS2FrZ3ozY3cyMQUHJG1hdGNoMQkAlgoEAICJegCAtIkTAIDokiYAgMLXLwMJAAACAitZaU5ib2ZGekMxN2pFSEhDTXdyUmNweTlNcnJqYWJNTUxaeGc4ZzV4bWY3BQckbWF0Y2gxCQCWCgQAgIl6AICHpw4AgOiSJgCA6JImCQCWCgQAAACA2sQJAIDokiYAgOiSJgkAAgECDlVua25vd24gbWFya2V0AQNzdW0CBHNpemUEZGF0YQoBBGZvbGQCBWFjY3VtBG5leHQDCQBnAgUEbmV4dAUEc2l6ZQUFYWNjdW0JAGQCBQVhY2N1bQkAkQMCBQRkYXRhBQRuZXh0CgACJGwFBWFycjEyCgACJHMJAJADAQUCJGwKAAUkYWNjMAAACgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQRmb2xkAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMgkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKAAsADAEOZ2V0U2V0dXBUb2tlbnMBDW1hcmtldEFkZHJlc3MJALwJAgkBEUBleHRyTmF0aXZlKDEwNTMpAgUNbWFya2V0QWRkcmVzcwIMc2V0dXBfdG9rZW5zAgEsAQ1nZXRUb2tlblByaWNlAg1tYXJrZXRBZGRyZXNzCmFzc2V0SWRTdHIECW9yYWNsZVN0cgkBC3ZhbHVlT3JFbHNlAgkAnQgCBQ1tYXJrZXRBZGRyZXNzAgZvcmFjbGUFEG9yYWNsZUFkZHJlc3NTdHIEDW9yYWNsZUFkZHJlc3MJARFAZXh0ck5hdGl2ZSgxMDYyKQEFCW9yYWNsZVN0cgQHc3RhYmxlcwkAvAkCCQELdmFsdWVPckVsc2UCCQCdCAIFDW1hcmtldEFkZHJlc3MCEHNldHVwX3N0YWJsZXNJZHMCWTl3YzNMWE5BNFRFQnNYeUt0b0xFOW1yYkREN1dNSFh2WHJDalp2YWJMQXNpLEhHZ2FiVHFVUzhXdFZGVUp6Zm1yVERNZ0VjY0p1WkxCUGhGZ1FGeHZuc29XAgEsAwkBAiE9AgkAzwgCBQdzdGFibGVzBQphc3NldElkU3RyBQR1bml0AMCEPQMDAwkAAAIFCmFzc2V0SWRTdHIFCXVzZHRJZFN0cgYJAAACBQphc3NldElkU3RyBQl1c2RjSWRTdHIGCQAAAgUKYXNzZXRJZFN0cgUJcm9tZUlkU3RyAMCEPQMJAQ9jb250YWluc0VsZW1lbnQCBQdheGx5TFBzBQphc3NldElkU3RyCgABQAkA/AcEBQtheGx5QWRkcmVzcwIaZ2V0U2hhcmVBc3NldFByaWNlUkVBRE9OTFkJAMwIAgUKYXNzZXRJZFN0cgUDbmlsBQNuaWwDCQABAgUBQAIDSW50BQFACQACAQkArAICCQADAQUBQAIYIGNvdWxkbid0IGJlIGNhc3QgdG8gSW50BAVwcmljZQkBEUBleHRyTmF0aXZlKDEwNTApAgUNb3JhY2xlQWRkcmVzcwkArAICBQphc3NldElkU3RyAgdfdHdhcDVCBQVwcmljZQENZ2V0QXNzZXRTY2FsZQEKYXNzZXRJZFN0cgQIZGVjaW1hbHMDCQAAAgUKYXNzZXRJZFN0cgIFV0FWRVMACAgJAQV2YWx1ZQEJAOwHAQkA2QQBBQphc3NldElkU3RyCGRlY2ltYWxzCQBsBgAKAAAFCGRlY2ltYWxzAAAAAAUERE9XTgERZ2V0TGFzdFJhdGVIZWlnaHQBDW1hcmtldEFkZHJlc3MJAQt2YWx1ZU9yRWxzZQIJAJoIAgUNbWFya2V0QWRkcmVzcwIObGFzdFJhdGVIZWlnaHQAAAEWZ2V0T3V0ZGF0ZWRUb3RhbFN1cHBseQINbWFya2V0QWRkcmVzcwphc3NldElkU3RyCQELdmFsdWVPckVsc2UCCQCaCAIFDW1hcmtldEFkZHJlc3MJAKwCAgIPdG90YWxfc3VwcGxpZWRfBQphc3NldElkU3RyAAABFmdldE91dGRhdGVkVG90YWxCb3Jyb3cCDW1hcmtldEFkZHJlc3MKYXNzZXRJZFN0cgkBC3ZhbHVlT3JFbHNlAgkAmggCBQ1tYXJrZXRBZGRyZXNzCQCsAgICD3RvdGFsX2JvcnJvd2VkXwUKYXNzZXRJZFN0cgAAARBnZXRPdXRkYXRlZFNSYXRlAg1tYXJrZXRBZGRyZXNzCmFzc2V0SWRTdHIJAQt2YWx1ZU9yRWxzZQIJAJoIAgUNbWFya2V0QWRkcmVzcwkArAICBQphc3NldElkU3RyAgZfc1JhdGUAAAEQZ2V0T3V0ZGF0ZWRCUmF0ZQINbWFya2V0QWRkcmVzcwphc3NldElkU3RyCQELdmFsdWVPckVsc2UCCQCaCAIFDW1hcmtldEFkZHJlc3MJAKwCAgUKYXNzZXRJZFN0cgIGX2JSYXRlAAABDWdldE91dGRhdGVkVXIEE291dGRhdGVkVG90YWxTdXBwbHkTb3V0ZGF0ZWRUb3RhbEJvcnJvdw1vdXRkYXRlZFNSYXRlDW91dGRhdGVkQlJhdGUEBGRvd24JAGsDBRNvdXRkYXRlZFRvdGFsU3VwcGx5BQ1vdXRkYXRlZFNSYXRlBQdTY2FsZTE2AwkAAAIFBGRvd24AAAAACQBrAwUGU2NhbGU4CQBrAwUTb3V0ZGF0ZWRUb3RhbEJvcnJvdwUNb3V0ZGF0ZWRCUmF0ZQUHU2NhbGUxNgUEZG93bgEHZ2V0UmF0ZQMKb3V0ZGF0ZWRVcgphc3NldElkU3RyCW1hcmtldFN0cgQFY3VydmUJAQxnZXRSYXRlQ3VydmUCBQphc3NldElkU3RyBQltYXJrZXRTdHIJAGQCCAUFY3VydmUCXzEDCQBnAggFBWN1cnZlAl8zBQpvdXRkYXRlZFVyCQBrAwUKb3V0ZGF0ZWRVcggFBWN1cnZlAl8yCAUFY3VydmUCXzMJAGQCCAUFY3VydmUCXzIJAGsDCQBlAgUKb3V0ZGF0ZWRVcggFBWN1cnZlAl8zCAUFY3VydmUCXzQJAGUCAIDC1y8IBQVjdXJ2ZQJfMwELZ2V0SW50ZXJlc3QBBHJhdGUJAJYDAQkAzAgCCQBrAwUEcmF0ZQUGU2NhbGU4BQp5ZWFyQmxvY2tzCQDMCAIAAQUDbmlsAQ1nZXRBc3NldEluZGV4AgtzZXR1cFRva2Vucwphc3NldElkU3RyCQEFdmFsdWUBCQDPCAIFC3NldHVwVG9rZW5zBQphc3NldElkU3RyARFnZXRBc3NldFBhcmFtdGVycwIQbWFya2V0UGFyYW1ldGVycwphc3NldEluZGV4CQCVCgMJAJEDAggFEG1hcmtldFBhcmFtZXRlcnMCXzEFCmFzc2V0SW5kZXgJAJEDAggFEG1hcmtldFBhcmFtZXRlcnMCXzIFCmFzc2V0SW5kZXgJAJEDAggFEG1hcmtldFBhcmFtZXRlcnMCXzMFCmFzc2V0SW5kZXgBE2dldE1hcmtldFBhcmFtZXRlcnMCDW1hcmtldEFkZHJlc3MLc2V0dXBUb2tlbnMEB3NldHVwQ2YJALwJAgkBEUBleHRyTmF0aXZlKDEwNTMpAgUNbWFya2V0QWRkcmVzcwIKc2V0dXBfbHR2cwIBLAQHc2V0dXBMdAkAvAkCCQERQGV4dHJOYXRpdmUoMTA1MykCBQ1tYXJrZXRBZGRyZXNzAglzZXR1cF9sdHMCASwEDHNldHVwUGVuYWx0eQkAvAkCCQERQGV4dHJOYXRpdmUoMTA1MykCBQ1tYXJrZXRBZGRyZXNzAg9zZXR1cF9wZW5hbHRpZXMCASwECnRva2Vuc1NpemUJAJADAQULc2V0dXBUb2tlbnMKAQRmb2xkAgVhY2N1bQRuZXh0AwkAZwIFBG5leHQFCnRva2Vuc1NpemUFBWFjY3VtCQCVCgMJAM0IAggFBWFjY3VtAl8xCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUHc2V0dXBDZgUEbmV4dAkAzQgCCAUFYWNjdW0CXzIJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQdzZXR1cEx0BQRuZXh0CQDNCAIIBQVhY2N1bQJfMwkBDXBhcnNlSW50VmFsdWUBCQCRAwIFDHNldHVwUGVuYWx0eQUEbmV4dAoAAiRsBQVhcnIxMgoAAiRzCQCQAwEFAiRsCgAFJGFjYzAJAJUKAwUDbmlsBQNuaWwFA25pbAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEEZm9sZAIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMTIJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgALAAwBDGdldE1heFN1cHBseQINbWFya2V0QWRkcmVzcwphc3NldElkU3RyCQENcGFyc2VJbnRWYWx1ZQEJAQt2YWx1ZU9yRWxzZQIJAJ0IAgUNbWFya2V0QWRkcmVzcwkArAICAhBzZXR1cF9tYXhTdXBwbHlfBQphc3NldElkU3RyAgEwAQ5nZXRBY3R1YWxTUmF0ZQQObGFzdFJhdGVIZWlnaHQIaW50ZXJlc3QKb3V0ZGF0ZWRVcg1vdXRkYXRlZFNSYXRlBAlsYXN0U1JhdGUJAJYDAQkAzAgCBQ1vdXRkYXRlZFNSYXRlCQDMCAIFB1NjYWxlMTYFA25pbAQIbmV3U1JhdGUJAGQCBQlsYXN0U1JhdGUJAGkCCQBoAgkAaAIJAGUCBQZoZWlnaHQFDmxhc3RSYXRlSGVpZ2h0CQBrAwUIaW50ZXJlc3QFCm91dGRhdGVkVXIFBlNjYWxlOAkAZQIAZAULcmVzZXJ2ZUZ1bmQAZAUIbmV3U1JhdGUBDmdldEFjdHVhbEJSYXRlAw5sYXN0UmF0ZUhlaWdodAhpbnRlcmVzdA1vdXRkYXRlZEJSYXRlBAlsYXN0QlJhdGUJAJYDAQkAzAgCBQ1vdXRkYXRlZEJSYXRlCQDMCAIFB1NjYWxlMTYFA25pbAQIbmV3QlJhdGUJAGQCBQlsYXN0QlJhdGUJAGgCCQBlAgUGaGVpZ2h0BQ5sYXN0UmF0ZUhlaWdodAUIaW50ZXJlc3QFCG5ld0JSYXRlAQtnZXRBY3R1YWxVcgIMYWN0dWFsU3VwcGx5DGFjdHVhbEJvcnJvdwMJAAACBQxhY3R1YWxTdXBwbHkAAAAACQBrAwUMYWN0dWFsQm9ycm93BQZTY2FsZTgFDGFjdHVhbFN1cHBseQEPZ2V0QWN0dWFsQW1vdW50Ag5vdXRkYXRlZEFtb3VudAphY3R1YWxSYXRlCQBrAwUOb3V0ZGF0ZWRBbW91bnQFCmFjdHVhbFJhdGUFB1NjYWxlMTYBCGdldEluVXNkAwxhY3R1YWxBbW91bnQKYXNzZXRTY2FsZQVwcmljZQkAawMFDGFjdHVhbEFtb3VudAUFcHJpY2UFCmFzc2V0U2NhbGUBDGdldFN1cHBseUFweQIEcmF0ZQhhY3R1YWxVcgQKc3VwcGx5UmF0ZQkAawMJAGsDBQRyYXRlAFAAZAUIYWN0dWFsVXIFBlNjYWxlOAkAZQIJAKADAQkAdgYJALcCAgUKU2NhbGUxNkJpZwkAvAIDCQC2AgEFCnN1cHBseVJhdGUFCVNjYWxlOEJpZwUNeWVhckJsb2Nrc0JpZwAQBQ15ZWFyQmxvY2tzQmlnAAAACAUERE9XTgUGU2NhbGU4AQxnZXRCb3Jyb3dBcHkBBHJhdGUJAGUCCQCgAwEJAHYGCQC3AgIFClNjYWxlMTZCaWcJALwCAwkAtgIBBQRyYXRlBQlTY2FsZThCaWcFDXllYXJCbG9ja3NCaWcAEAUNeWVhckJsb2Nrc0JpZwAAAAgFBERPV04FBlNjYWxlOAEPZ2V0V2FsbGV0U3VwcGx5BA1tYXJrZXRBZGRyZXNzCmFzc2V0SWRTdHIGd2FsbGV0C2FjdHVhbFNSYXRlBBRvdXRkYXRlZFdhbGxldFN1cHBseQkBC3ZhbHVlT3JFbHNlAgkAmggCBQ1tYXJrZXRBZGRyZXNzCQCsAgIJAKwCAgUGd2FsbGV0Agpfc3VwcGxpZWRfBQphc3NldElkU3RyAAAJAQ9nZXRBY3R1YWxBbW91bnQCBRRvdXRkYXRlZFdhbGxldFN1cHBseQULYWN0dWFsU1JhdGUBD2dldFdhbGxldEJvcnJvdwQNbWFya2V0QWRkcmVzcwphc3NldElkU3RyBndhbGxldAthY3R1YWxCUmF0ZQQUb3V0ZGF0ZWRXYWxsZXRCb3Jyb3cJAQt2YWx1ZU9yRWxzZQIJAJoIAgUNbWFya2V0QWRkcmVzcwkArAICCQCsAgIFBndhbGxldAIKX2JvcnJvd2VkXwUKYXNzZXRJZFN0cgAACQEPZ2V0QWN0dWFsQW1vdW50AgUUb3V0ZGF0ZWRXYWxsZXRCb3Jyb3cFC2FjdHVhbEJSYXRlARBnZXREYWlseVBlcmNlbnRzAgNhcHkIcXVhbnRpdHkJAGsDCQBrAwkAZQIJAKADAQkAdgYJALcCAgUJU2NhbGU4QmlnCQC2AgEFA2FweQAICQC6AgIFClNjYWxlMTZCaWcFDXllYXJCbG9ja3NCaWcAEAAQBQRET1dOBQdTY2FsZTE2BQlkYXlCbG9ja3MFBlNjYWxlOAUIcXVhbnRpdHkFBlNjYWxlOAEQZ2V0QWNjb3VudEhlYWx0aAIbdG90YWxXYWxsZXRCb3Jyb3dMaW1pdEluVXNkG3RvdGFsV2FsbGV0Qm9ycm93VXNhZ2VJblVzZAMJAAACBRt0b3RhbFdhbGxldEJvcnJvd0xpbWl0SW5Vc2QAAAUGU2NhbGU4CQBlAgUGU2NhbGU4CQBrAwUbdG90YWxXYWxsZXRCb3Jyb3dVc2FnZUluVXNkBQZTY2FsZTgFG3RvdGFsV2FsbGV0Qm9ycm93TGltaXRJblVzZAEJZ2V0TmV0QXB5AxZ0b3RhbFdhbGxldFN1cHBseUluVXNkFnRvdGFsV2FsbGV0Qm9ycm93SW5Vc2QWdG90YWxXYWxsZXRNYXJnaW5JblVzZAMJAAACBRZ0b3RhbFdhbGxldE1hcmdpbkluVXNkAAAAAAMJAGYCBRZ0b3RhbFdhbGxldE1hcmdpbkluVXNkAAAJAGsDBRZ0b3RhbFdhbGxldE1hcmdpbkluVXNkBQZTY2FsZTgFFnRvdGFsV2FsbGV0U3VwcGx5SW5Vc2QJAGsDBRZ0b3RhbFdhbGxldE1hcmdpbkluVXNkBQZTY2FsZTgFFnRvdGFsV2FsbGV0Qm9ycm93SW5Vc2QBC2Fzc2V0VG9Kc29uAgphc3NldElkU3RyCHF1YW50aXR5BA0kdDAxNTM0MzE1NTM4AwkAAAIFCmFzc2V0SWRTdHIFBVdhdmVzCQCUCgIACAIFV0FWRVMEBWFzc2V0CQEFdmFsdWUBCQDsBwEJANkEAQUKYXNzZXRJZFN0cgkAlAoCCAUFYXNzZXQIZGVjaW1hbHMIBQVhc3NldARuYW1lBAhkZWNpbWFscwgFDSR0MDE1MzQzMTU1MzgCXzEEBG5hbWUIBQ0kdDAxNTM0MzE1NTM4Al8yCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgIMeyJxdWFudGl0eSI6CQCkAwEFCHF1YW50aXR5AgwsImRlY2ltYWxzIjoJAKQDAQUIZGVjaW1hbHMCCSwibmFtZSI6IgUEbmFtZQIIIiwiaWQiOiIFCmFzc2V0SWRTdHICAiJ9AQ9hbW91bnRUb0RlY2ltYWwCBmFtb3VudAhkZWNpbWFscwkArAICCQCsAgIJAKwCAgkArAICAgx7InF1YW50aXR5IjoJAKQDAQUGYW1vdW50AgwsImRlY2ltYWxzIjoJAKQDAQUIZGVjaW1hbHMCEywibmFtZSI6IiIsImlkIjoiIn0BDWdldE1hcmtldEpzb24DC21hcmtldEluZGV4BndhbGxldAVkZWJ1ZwQJbWFya2V0U3RyCQERQGV4dHJOYXRpdmUoMTA1OCkBCQCsAgICB21hcmtldF8JAKQDAQULbWFya2V0SW5kZXgEDW1hcmtldEFkZHJlc3MJARFAZXh0ck5hdGl2ZSgxMDYyKQEFCW1hcmtldFN0cgQKbWFya2V0TmFtZQkBEUBleHRyTmF0aXZlKDEwNTgpAQkArAICAgxtYXJrZXRfbmFtZV8FCW1hcmtldFN0cgQGYWN0aXZlCQELdmFsdWVPckVsc2UCCQCbCAIFDW1hcmtldEFkZHJlc3MCDHNldHVwX2FjdGl2ZQYEC3NldHVwVG9rZW5zCQEOZ2V0U2V0dXBUb2tlbnMBBQ1tYXJrZXRBZGRyZXNzBAthc3NldHNDb3VudAkAkAMBBQtzZXR1cFRva2VucwQObGFzdFJhdGVIZWlnaHQJARFnZXRMYXN0UmF0ZUhlaWdodAEFDW1hcmtldEFkZHJlc3MKAQphc3NldHNGb2xkAgVhY2N1bQRuZXh0AwkAZwIFBG5leHQFC2Fzc2V0c0NvdW50BQVhY2N1bQQKYXNzZXRJZFN0cgkAkQMCBQtzZXR1cFRva2VucwUEbmV4dAQFcHJpY2UJAQ1nZXRUb2tlblByaWNlAgUNbWFya2V0QWRkcmVzcwUKYXNzZXRJZFN0cgQKYXNzZXRTY2FsZQkBDWdldEFzc2V0U2NhbGUBBQphc3NldElkU3RyBBNvdXRkYXRlZFRvdGFsU3VwcGx5CQEWZ2V0T3V0ZGF0ZWRUb3RhbFN1cHBseQIFDW1hcmtldEFkZHJlc3MFCmFzc2V0SWRTdHIEE291dGRhdGVkVG90YWxCb3Jyb3cJARZnZXRPdXRkYXRlZFRvdGFsQm9ycm93AgUNbWFya2V0QWRkcmVzcwUKYXNzZXRJZFN0cgQNb3V0ZGF0ZWRTUmF0ZQkBEGdldE91dGRhdGVkU1JhdGUCBQ1tYXJrZXRBZGRyZXNzBQphc3NldElkU3RyBA1vdXRkYXRlZEJSYXRlCQEQZ2V0T3V0ZGF0ZWRCUmF0ZQIFDW1hcmtldEFkZHJlc3MFCmFzc2V0SWRTdHIECm91dGRhdGVkVXIJAQ1nZXRPdXRkYXRlZFVyBAUTb3V0ZGF0ZWRUb3RhbFN1cHBseQUTb3V0ZGF0ZWRUb3RhbEJvcnJvdwUNb3V0ZGF0ZWRTUmF0ZQUNb3V0ZGF0ZWRCUmF0ZQQEcmF0ZQkBB2dldFJhdGUDBQpvdXRkYXRlZFVyBQphc3NldElkU3RyBQltYXJrZXRTdHIECGludGVyZXN0CQELZ2V0SW50ZXJlc3QBBQRyYXRlBAVzUmF0ZQkBDmdldEFjdHVhbFNSYXRlBAUObGFzdFJhdGVIZWlnaHQFCGludGVyZXN0BQpvdXRkYXRlZFVyBQ1vdXRkYXRlZFNSYXRlBAViUmF0ZQkBDmdldEFjdHVhbEJSYXRlAwUObGFzdFJhdGVIZWlnaHQFCGludGVyZXN0BQ1vdXRkYXRlZEJSYXRlBAZzdXBwbHkJAQ9nZXRBY3R1YWxBbW91bnQCBRNvdXRkYXRlZFRvdGFsU3VwcGx5BQVzUmF0ZQQGYm9ycm93CQEPZ2V0QWN0dWFsQW1vdW50AgUTb3V0ZGF0ZWRUb3RhbEJvcnJvdwUFYlJhdGUEC3N1cHBseUluVXNkCQEIZ2V0SW5Vc2QDBQZzdXBwbHkFCmFzc2V0U2NhbGUFBXByaWNlBAtib3Jyb3dJblVzZAkBCGdldEluVXNkAwUGYm9ycm93BQphc3NldFNjYWxlBQVwcmljZQQIcmVzZXJ2ZXMJAGUCBQZzdXBwbHkFBmJvcnJvdwQNcmVzZXJ2ZXNJblVzZAkBCGdldEluVXNkAwUIcmVzZXJ2ZXMFCmFzc2V0U2NhbGUFBXByaWNlBAJ1cgkBC2dldEFjdHVhbFVyAgUGc3VwcGx5BQZib3Jyb3cECXN1cHBseUFweQkBDGdldFN1cHBseUFweQIFBHJhdGUFAnVyBAlib3Jyb3dBcHkJAQxnZXRCb3Jyb3dBcHkBBQRyYXRlBA9tYXJrZXRBc3NldEpzb24JAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgIBewIJInN1cHBseSI6CQELYXNzZXRUb0pzb24CBQphc3NldElkU3RyBQZzdXBwbHkCDywic3VwcGx5SW5Vc2QiOgkBC2Fzc2V0VG9Kc29uAgUJdXNkdElkU3RyBQtzdXBwbHlJblVzZAIKLCJib3Jyb3ciOgkBC2Fzc2V0VG9Kc29uAgUKYXNzZXRJZFN0cgUGYm9ycm93Ag8sImJvcnJvd0luVXNkIjoJAQthc3NldFRvSnNvbgIFCXVzZHRJZFN0cgULYm9ycm93SW5Vc2QCDCwicmVzZXJ2ZXMiOgkBC2Fzc2V0VG9Kc29uAgUKYXNzZXRJZFN0cgUIcmVzZXJ2ZXMCESwicmVzZXJ2ZXNJblVzZCI6CQELYXNzZXRUb0pzb24CBQl1c2R0SWRTdHIFDXJlc2VydmVzSW5Vc2QCCSwicHJpY2UiOgkBC2Fzc2V0VG9Kc29uAgUJdXNkdElkU3RyBQVwcmljZQINLCJzdXBwbHlBcHkiOgkBD2Ftb3VudFRvRGVjaW1hbAIFCXN1cHBseUFweQAIAg0sImJvcnJvd0FweSI6CQEPYW1vdW50VG9EZWNpbWFsAgUJYm9ycm93QXB5AAgCFCwidXRpbGl6YXRpb25SYXRpbyI6CQEPYW1vdW50VG9EZWNpbWFsAgUCdXIACAIJLCJzUmF0ZSI6CQEPYW1vdW50VG9EZWNpbWFsAgUFc1JhdGUAEAIJLCJiUmF0ZSI6CQEPYW1vdW50VG9EZWNpbWFsAgUFYlJhdGUAEAIBfQkAlgoECQBkAggFBWFjY3VtAl8xBQtzdXBwbHlJblVzZAkAZAIIBQVhY2N1bQJfMgULYm9ycm93SW5Vc2QJAGQCCAUFYWNjdW0CXzMFDXJlc2VydmVzSW5Vc2QJAM0IAggFBWFjY3VtAl80BQ9tYXJrZXRBc3NldEpzb24EDSR0MDE4OTUxMTkwNTkKAAIkbAUFYXJyMTIKAAIkcwkAkAMBBQIkbAoABSRhY2MwCQCWCgQAAAAAAAAFA25pbAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEKYXNzZXRzRm9sZAIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMTIJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgALAAwEC3N1cHBseUluVXNkCAUNJHQwMTg5NTExOTA1OQJfMQQLYm9ycm93SW5Vc2QIBQ0kdDAxODk1MTE5MDU5Al8yBA1yZXNlcnZlc0luVXNkCAUNJHQwMTg5NTExOTA1OQJfMwQQbWFya2V0QXNzZXRzSnNvbggFDSR0MDE4OTUxMTkwNTkCXzQEDG1hcmtldHNDb3VudAkBEUBleHRyTmF0aXZlKDEwNTUpAQIHbWFya2V0cwoBC21hcmtldHNGb2xkAgVhY2N1bQRuZXh0AwkAZwIFBG5leHQFDG1hcmtldHNDb3VudAUFYWNjdW0EF2N1cnJlbnRNYXJrZXRBZGRyZXNzU3RyCQERQGV4dHJOYXRpdmUoMTA1OCkBCQCsAgICB21hcmtldF8JAKQDAQUEbmV4dAQRY3VycmVudE1hcmtldE5hbWUJARFAZXh0ck5hdGl2ZSgxMDU4KQEJAKwCAgIMbWFya2V0X25hbWVfBRdjdXJyZW50TWFya2V0QWRkcmVzc1N0cgQKc2ltcGxlSnNvbgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAgF7AggiaW5kZXgiOgkApAMBBQRuZXh0AgksIm5hbWUiOiIFEWN1cnJlbnRNYXJrZXROYW1lAgEiAg8sInN1cHBseUluVXNkIjoJAQthc3NldFRvSnNvbgIFCXVzZHRJZFN0cgAAAhEsImFjY291bnRIZWFsdGgiOgkBD2Ftb3VudFRvRGVjaW1hbAIAAAAIAgF9AwkAAAIFBndhbGxldAIACQDNCAIFBWFjY3VtBQpzaW1wbGVKc29uBBRjdXJyZW50TWFya2V0QWRkcmVzcwkBEUBleHRyTmF0aXZlKDEwNjIpAQUXY3VycmVudE1hcmtldEFkZHJlc3NTdHIEEmN1cnJlbnRTZXR1cFRva2VucwkBDmdldFNldHVwVG9rZW5zAQUUY3VycmVudE1hcmtldEFkZHJlc3MEEmN1cnJlbnRBc3NldHNDb3VudAkAkAMBBRJjdXJyZW50U2V0dXBUb2tlbnMEFmN1cnJlbnRNYXJrZXRTaG9ydE5hbWUJARFAZXh0ck5hdGl2ZSgxMDU4KQEJAKwCAgIRbWFya2V0X3Nob3J0bmFtZV8FF2N1cnJlbnRNYXJrZXRBZGRyZXNzU3RyBAdzZXR1cENmCQC8CQIJARFAZXh0ck5hdGl2ZSgxMDUzKQIFFGN1cnJlbnRNYXJrZXRBZGRyZXNzAgpzZXR1cF9sdHZzAgEsBAdzZXR1cEx0CQC8CQIJARFAZXh0ck5hdGl2ZSgxMDUzKQIFFGN1cnJlbnRNYXJrZXRBZGRyZXNzAglzZXR1cF9sdHMCASwEFWN1cnJlbnRMYXN0UmF0ZUhlaWdodAkBEWdldExhc3RSYXRlSGVpZ2h0AQUUY3VycmVudE1hcmtldEFkZHJlc3MKARBtYXJrZXRBc3NldHNGb2xkAgVhY2N1bQRuZXh0AwkAZwIFBG5leHQFEmN1cnJlbnRBc3NldHNDb3VudAUFYWNjdW0ECmFzc2V0SWRTdHIJAJEDAgUSY3VycmVudFNldHVwVG9rZW5zBQRuZXh0BAJjZgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFB3NldHVwQ2YFBG5leHQEAmx0CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUHc2V0dXBMdAUEbmV4dAQFcHJpY2UJAQ1nZXRUb2tlblByaWNlAgUNbWFya2V0QWRkcmVzcwUKYXNzZXRJZFN0cgQKYXNzZXRTY2FsZQkBDWdldEFzc2V0U2NhbGUBBQphc3NldElkU3RyBBNvdXRkYXRlZFRvdGFsU3VwcGx5CQEWZ2V0T3V0ZGF0ZWRUb3RhbFN1cHBseQIFFGN1cnJlbnRNYXJrZXRBZGRyZXNzBQphc3NldElkU3RyBBNvdXRkYXRlZFRvdGFsQm9ycm93CQEWZ2V0T3V0ZGF0ZWRUb3RhbEJvcnJvdwIFFGN1cnJlbnRNYXJrZXRBZGRyZXNzBQphc3NldElkU3RyBA1vdXRkYXRlZFNSYXRlCQEQZ2V0T3V0ZGF0ZWRTUmF0ZQIFFGN1cnJlbnRNYXJrZXRBZGRyZXNzBQphc3NldElkU3RyBA1vdXRkYXRlZEJSYXRlCQEQZ2V0T3V0ZGF0ZWRCUmF0ZQIFFGN1cnJlbnRNYXJrZXRBZGRyZXNzBQphc3NldElkU3RyBApvdXRkYXRlZFVyCQENZ2V0T3V0ZGF0ZWRVcgQFE291dGRhdGVkVG90YWxTdXBwbHkFE291dGRhdGVkVG90YWxCb3Jyb3cFDW91dGRhdGVkU1JhdGUFDW91dGRhdGVkQlJhdGUEBHJhdGUJAQdnZXRSYXRlAwUKb3V0ZGF0ZWRVcgUKYXNzZXRJZFN0cgUJbWFya2V0U3RyBAhpbnRlcmVzdAkBC2dldEludGVyZXN0AQUEcmF0ZQQFc1JhdGUJAQ5nZXRBY3R1YWxTUmF0ZQQFFWN1cnJlbnRMYXN0UmF0ZUhlaWdodAUIaW50ZXJlc3QFCm91dGRhdGVkVXIFDW91dGRhdGVkU1JhdGUEBWJSYXRlCQEOZ2V0QWN0dWFsQlJhdGUDBRVjdXJyZW50TGFzdFJhdGVIZWlnaHQFCGludGVyZXN0BQ1vdXRkYXRlZEJSYXRlBAx3YWxsZXRTdXBwbHkJAQ9nZXRXYWxsZXRTdXBwbHkEBRRjdXJyZW50TWFya2V0QWRkcmVzcwUKYXNzZXRJZFN0cgUGd2FsbGV0BQVzUmF0ZQQRd2FsbGV0U3VwcGx5SW5Vc2QJAQhnZXRJblVzZAMFDHdhbGxldFN1cHBseQUKYXNzZXRTY2FsZQUFcHJpY2UEDHdhbGxldEJvcnJvdwkBD2dldFdhbGxldEJvcnJvdwQFFGN1cnJlbnRNYXJrZXRBZGRyZXNzBQphc3NldElkU3RyBQZ3YWxsZXQFBWJSYXRlBBF3YWxsZXRCb3Jyb3dJblVzZAkBCGdldEluVXNkAwUMd2FsbGV0Qm9ycm93BQphc3NldFNjYWxlBQVwcmljZQQWd2FsbGV0Qm9ycm93TGltaXRJblVzZAkAawMFEXdhbGxldFN1cHBseUluVXNkBQJjZgUGU2NhbGU4BBZ3YWxsZXRCb3Jyb3dVc2FnZUluVXNkCQBrAwURd2FsbGV0Qm9ycm93SW5Vc2QFBlNjYWxlOAUCbHQJAJYKBAkAZAIIBQVhY2N1bQJfMQURd2FsbGV0U3VwcGx5SW5Vc2QJAGQCCAUFYWNjdW0CXzIFEXdhbGxldEJvcnJvd0luVXNkCQBkAggFBWFjY3VtAl8zBRZ3YWxsZXRCb3Jyb3dMaW1pdEluVXNkCQBkAggFBWFjY3VtAl80BRZ3YWxsZXRCb3Jyb3dVc2FnZUluVXNkBA0kdDAyMjYzNjIyNzk2CgACJGwFBWFycjEyCgACJHMJAJADAQUCJGwKAAUkYWNjMAkAlgoEAAAAAAAAAAAKAQUkZjFfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBEG1hcmtldEFzc2V0c0ZvbGQCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjFfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDEyCQEFJGYxXzICCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoACwAMBBZ0b3RhbFdhbGxldFN1cHBseUluVXNkCAUNJHQwMjI2MzYyMjc5NgJfMQQWdG90YWxXYWxsZXRCb3Jyb3dJblVzZAgFDSR0MDIyNjM2MjI3OTYCXzIEG3RvdGFsV2FsbGV0Qm9ycm93TGltaXRJblVzZAgFDSR0MDIyNjM2MjI3OTYCXzMEG3RvdGFsV2FsbGV0Qm9ycm93VXNhZ2VJblVzZAgFDSR0MDIyNjM2MjI3OTYCXzQEDWFjY291bnRIZWFsdGgJARBnZXRBY2NvdW50SGVhbHRoAgUbdG90YWxXYWxsZXRCb3Jyb3dMaW1pdEluVXNkBRt0b3RhbFdhbGxldEJvcnJvd1VzYWdlSW5Vc2QECGZ1bGxKc29uCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAgF7AggiaW5kZXgiOgkApAMBBQRuZXh0AgksIm5hbWUiOiIFFmN1cnJlbnRNYXJrZXRTaG9ydE5hbWUCASICDywic3VwcGx5SW5Vc2QiOgkBC2Fzc2V0VG9Kc29uAgUJdXNkdElkU3RyBRZ0b3RhbFdhbGxldFN1cHBseUluVXNkAg8sImJvcnJvd0luVXNkIjoJAQthc3NldFRvSnNvbgIFCXVzZHRJZFN0cgUWdG90YWxXYWxsZXRCb3Jyb3dJblVzZAIRLCJhY2NvdW50SGVhbHRoIjoJAQ9hbW91bnRUb0RlY2ltYWwCBQ1hY2NvdW50SGVhbHRoAAgCAX0JAM0IAgUFYWNjdW0FCGZ1bGxKc29uBAttYXJrZXRzSnNvbgoAAiRsBQVhcnIxMgoAAiRzCQCQAwEFAiRsCgAFJGFjYzAFA25pbAoBBSRmMV8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQELbWFya2V0c0ZvbGQCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjFfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDEyCQEFJGYxXzICCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECCQEFJGYxXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoACwAMBARqc29uCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgIBewIIImluZGV4IjoJAKQDAQULbWFya2V0SW5kZXgCCSwibmFtZSI6IgUKbWFya2V0TmFtZQIBIgIMLCJhZGRyZXNzIjoiBQltYXJrZXRTdHICASICCiwiYWN0aXZlIjoJAKUDAQUGYWN0aXZlAg8sInN1cHBseUluVXNkIjoJAQthc3NldFRvSnNvbgIFCXVzZHRJZFN0cgULc3VwcGx5SW5Vc2QCDywiYm9ycm93SW5Vc2QiOgkBC2Fzc2V0VG9Kc29uAgUJdXNkdElkU3RyBQtib3Jyb3dJblVzZAIRLCJyZXNlcnZlc0luVXNkIjoJAQthc3NldFRvSnNvbgIFCXVzZHRJZFN0cgUNcmVzZXJ2ZXNJblVzZAILLCJhc3NldHMiOlsJALsJAgUQbWFya2V0QXNzZXRzSnNvbgIBLAIBXQIMLCJtYXJrZXRzIjpbCQC7CQIFC21hcmtldHNKc29uAgEsAgFdAgF9AwUFZGVidWcJAAIBBQRqc29uBQRqc29uAQtnZXRNZW51SnNvbgEFZGVidWcEDG1hcmtldHNDb3VudAkBEUBleHRyTmF0aXZlKDEwNTUpAQIHbWFya2V0cwoBC21hcmtldHNGb2xkAgVhY2N1bQRuZXh0AwkAZwIFBG5leHQFDG1hcmtldHNDb3VudAUFYWNjdW0ECW1hcmtldFN0cgkBEUBleHRyTmF0aXZlKDEwNTgpAQkArAICAgdtYXJrZXRfCQCkAwEFBG5leHQEDW1hcmtldEFkZHJlc3MJARFAZXh0ck5hdGl2ZSgxMDYyKQEFCW1hcmtldFN0cgQLc2V0dXBUb2tlbnMJAQ5nZXRTZXR1cFRva2VucwEFDW1hcmtldEFkZHJlc3MEC2Fzc2V0c0NvdW50CQCQAwEFC3NldHVwVG9rZW5zBA5sYXN0UmF0ZUhlaWdodAkBEWdldExhc3RSYXRlSGVpZ2h0AQUNbWFya2V0QWRkcmVzcwoBCmFzc2V0c0ZvbGQCBWFjY3VtBG5leHQDCQBnAgUEbmV4dAULYXNzZXRzQ291bnQFBWFjY3VtBAphc3NldElkU3RyCQCRAwIFC3NldHVwVG9rZW5zBQRuZXh0BAVwcmljZQkBDWdldFRva2VuUHJpY2UCBQ1tYXJrZXRBZGRyZXNzBQphc3NldElkU3RyBAphc3NldFNjYWxlCQENZ2V0QXNzZXRTY2FsZQEFCmFzc2V0SWRTdHIEE291dGRhdGVkVG90YWxTdXBwbHkJARZnZXRPdXRkYXRlZFRvdGFsU3VwcGx5AgUNbWFya2V0QWRkcmVzcwUKYXNzZXRJZFN0cgQTb3V0ZGF0ZWRUb3RhbEJvcnJvdwkBFmdldE91dGRhdGVkVG90YWxCb3Jyb3cCBQ1tYXJrZXRBZGRyZXNzBQphc3NldElkU3RyBA1vdXRkYXRlZFNSYXRlCQEQZ2V0T3V0ZGF0ZWRTUmF0ZQIFDW1hcmtldEFkZHJlc3MFCmFzc2V0SWRTdHIEDW91dGRhdGVkQlJhdGUJARBnZXRPdXRkYXRlZEJSYXRlAgUNbWFya2V0QWRkcmVzcwUKYXNzZXRJZFN0cgQKb3V0ZGF0ZWRVcgkBDWdldE91dGRhdGVkVXIEBRNvdXRkYXRlZFRvdGFsU3VwcGx5BRNvdXRkYXRlZFRvdGFsQm9ycm93BQ1vdXRkYXRlZFNSYXRlBQ1vdXRkYXRlZEJSYXRlBARyYXRlCQEHZ2V0UmF0ZQMFCm91dGRhdGVkVXIFCmFzc2V0SWRTdHIFCW1hcmtldFN0cgQIaW50ZXJlc3QJAQtnZXRJbnRlcmVzdAEFBHJhdGUEBXNSYXRlCQEOZ2V0QWN0dWFsU1JhdGUEBQ5sYXN0UmF0ZUhlaWdodAUIaW50ZXJlc3QFCm91dGRhdGVkVXIFDW91dGRhdGVkU1JhdGUEBWJSYXRlCQEOZ2V0QWN0dWFsQlJhdGUDBQ5sYXN0UmF0ZUhlaWdodAUIaW50ZXJlc3QFDW91dGRhdGVkQlJhdGUEBnN1cHBseQkBD2dldEFjdHVhbEFtb3VudAIFE291dGRhdGVkVG90YWxTdXBwbHkFBXNSYXRlBAZib3Jyb3cJAQ9nZXRBY3R1YWxBbW91bnQCBRNvdXRkYXRlZFRvdGFsQm9ycm93BQViUmF0ZQQLc3VwcGx5SW5Vc2QJAQhnZXRJblVzZAMFBnN1cHBseQUKYXNzZXRTY2FsZQUFcHJpY2UEC2JvcnJvd0luVXNkCQEIZ2V0SW5Vc2QDBQZib3Jyb3cFCmFzc2V0U2NhbGUFBXByaWNlBAhyZXNlcnZlcwkAZQIFBnN1cHBseQUGYm9ycm93BA1yZXNlcnZlc0luVXNkCQEIZ2V0SW5Vc2QDBQhyZXNlcnZlcwUKYXNzZXRTY2FsZQUFcHJpY2UED21hcmtldEFzc2V0SnNvbgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgIBewIIImFzc2V0IjoJAQthc3NldFRvSnNvbgIFCmFzc2V0SWRTdHIAAAIJLCJwcmljZSI6CQELYXNzZXRUb0pzb24CBQl1c2R0SWRTdHIFBXByaWNlAgksInNSYXRlIjoJAQ9hbW91bnRUb0RlY2ltYWwCBQVzUmF0ZQAQAgksImJSYXRlIjoJAQ9hbW91bnRUb0RlY2ltYWwCBQViUmF0ZQAQAgF9CQCWCgQJAGQCCAUFYWNjdW0CXzEFC3N1cHBseUluVXNkCQBkAggFBWFjY3VtAl8yBQtib3Jyb3dJblVzZAkAZAIIBQVhY2N1bQJfMwUNcmVzZXJ2ZXNJblVzZAkAzQgCCAUFYWNjdW0CXzQFD21hcmtldEFzc2V0SnNvbgQNJHQwMjY3MzAyNjgzOAoAAiRsBQVhcnIxMgoAAiRzCQCQAwEFAiRsCgAFJGFjYzAJAJYKBAAAAAAAAAUDbmlsCgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQphc3NldHNGb2xkAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMgkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKAAsADAQLc3VwcGx5SW5Vc2QIBQ0kdDAyNjczMDI2ODM4Al8xBAtib3Jyb3dJblVzZAgFDSR0MDI2NzMwMjY4MzgCXzIEDXJlc2VydmVzSW5Vc2QIBQ0kdDAyNjczMDI2ODM4Al8zBBBtYXJrZXRBc3NldHNKc29uCAUNJHQwMjY3MzAyNjgzOAJfNAQKbWFya2V0SnNvbgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAgF7AgsiYWRkcmVzcyI6IgUJbWFya2V0U3RyAgEiAgssImFzc2V0cyI6WwkAuwkCBRBtYXJrZXRBc3NldHNKc29uAgEsAgFdAgF9CQCWCgQJAGQCCAUFYWNjdW0CXzEFC3N1cHBseUluVXNkCQBkAggFBWFjY3VtAl8yBQtib3Jyb3dJblVzZAkAZAIIBQVhY2N1bQJfMwUNcmVzZXJ2ZXNJblVzZAkAzQgCCAUFYWNjdW0CXzQFCm1hcmtldEpzb24EDSR0MDI3MjI5MjczNDgKAAIkbAUFYXJyMTIKAAIkcwkAkAMBBQIkbAoABSRhY2MwCQCWCgQAAAAAAAAFA25pbAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQELbWFya2V0c0ZvbGQCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDEyCQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoACwAMBBB0b3RhbFN1cHBseUluVXNkCAUNJHQwMjcyMjkyNzM0OAJfMQQQdG90YWxCb3Jyb3dJblVzZAgFDSR0MDI3MjI5MjczNDgCXzIEEnRvdGFsUmVzZXJ2ZXNJblVzZAgFDSR0MDI3MjI5MjczNDgCXzMEC21hcmtldHNKc29uCAUNJHQwMjcyMjkyNzM0OAJfNAQEanNvbgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAgF7Ag4ic3VwcGx5SW5Vc2QiOgkBC2Fzc2V0VG9Kc29uAgUJdXNkdElkU3RyBRB0b3RhbFN1cHBseUluVXNkAg8sImJvcnJvd0luVXNkIjoJAQthc3NldFRvSnNvbgIFCXVzZHRJZFN0cgUQdG90YWxCb3Jyb3dJblVzZAIRLCJyZXNlcnZlc0luVXNkIjoJAQthc3NldFRvSnNvbgIFCXVzZHRJZFN0cgUSdG90YWxSZXNlcnZlc0luVXNkAgwsIm1hcmtldHMiOlsJALsJAgULbWFya2V0c0pzb24CASwCAV0CAX0DBQVkZWJ1ZwkAAgEFBGpzb24FBGpzb24BDWdldFdhbGxldEpzb24DC21hcmtldEluZGV4BndhbGxldAVkZWJ1ZwQJbWFya2V0U3RyCQERQGV4dHJOYXRpdmUoMTA1OCkBCQCsAgICB21hcmtldF8JAKQDAQULbWFya2V0SW5kZXgEDW1hcmtldEFkZHJlc3MJARFAZXh0ck5hdGl2ZSgxMDYyKQEFCW1hcmtldFN0cgQKbWFya2V0TmFtZQkBEUBleHRyTmF0aXZlKDEwNTgpAQkArAICAgxtYXJrZXRfbmFtZV8FCW1hcmtldFN0cgQMbWFya2V0c0NvdW50CQERQGV4dHJOYXRpdmUoMTA1NSkBAgdtYXJrZXRzCgELbWFya2V0c0ZvbGQCBWFjY3VtBG5leHQDCQBnAgUEbmV4dAUMbWFya2V0c0NvdW50BQVhY2N1bQQXY3VycmVudE1hcmtldEFkZHJlc3NTdHIJARFAZXh0ck5hdGl2ZSgxMDU4KQEJAKwCAgIHbWFya2V0XwkApAMBBQRuZXh0BBFjdXJyZW50TWFya2V0TmFtZQkBEUBleHRyTmF0aXZlKDEwNTgpAQkArAICAgxtYXJrZXRfbmFtZV8FF2N1cnJlbnRNYXJrZXRBZGRyZXNzU3RyBBRjdXJyZW50TWFya2V0QWRkcmVzcwkBEUBleHRyTmF0aXZlKDEwNjIpAQUXY3VycmVudE1hcmtldEFkZHJlc3NTdHIEEmN1cnJlbnRTZXR1cFRva2VucwkBDmdldFNldHVwVG9rZW5zAQUUY3VycmVudE1hcmtldEFkZHJlc3MEEmN1cnJlbnRBc3NldHNDb3VudAkAkAMBBRJjdXJyZW50U2V0dXBUb2tlbnMEFmN1cnJlbnRNYXJrZXRTaG9ydE5hbWUJARFAZXh0ck5hdGl2ZSgxMDU4KQEJAKwCAgIRbWFya2V0X3Nob3J0bmFtZV8FF2N1cnJlbnRNYXJrZXRBZGRyZXNzU3RyBAdzZXR1cENmCQC8CQIJARFAZXh0ck5hdGl2ZSgxMDUzKQIFFGN1cnJlbnRNYXJrZXRBZGRyZXNzAgpzZXR1cF9sdHZzAgEsBAdzZXR1cEx0CQC8CQIJARFAZXh0ck5hdGl2ZSgxMDUzKQIFFGN1cnJlbnRNYXJrZXRBZGRyZXNzAglzZXR1cF9sdHMCASwEFWN1cnJlbnRMYXN0UmF0ZUhlaWdodAkBEWdldExhc3RSYXRlSGVpZ2h0AQUUY3VycmVudE1hcmtldEFkZHJlc3MKARBtYXJrZXRBc3NldHNGb2xkAgVhY2N1bQRuZXh0AwkAZwIFBG5leHQFEmN1cnJlbnRBc3NldHNDb3VudAUFYWNjdW0ECmFzc2V0SWRTdHIJAJEDAgUSY3VycmVudFNldHVwVG9rZW5zBQRuZXh0BAJjZgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFB3NldHVwQ2YFBG5leHQEAmx0CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUHc2V0dXBMdAUEbmV4dAQFcHJpY2UJAQ1nZXRUb2tlblByaWNlAgUNbWFya2V0QWRkcmVzcwUKYXNzZXRJZFN0cgQKYXNzZXRTY2FsZQkBDWdldEFzc2V0U2NhbGUBBQphc3NldElkU3RyBBNvdXRkYXRlZFRvdGFsU3VwcGx5CQEWZ2V0T3V0ZGF0ZWRUb3RhbFN1cHBseQIFFGN1cnJlbnRNYXJrZXRBZGRyZXNzBQphc3NldElkU3RyBBNvdXRkYXRlZFRvdGFsQm9ycm93CQEWZ2V0T3V0ZGF0ZWRUb3RhbEJvcnJvdwIFFGN1cnJlbnRNYXJrZXRBZGRyZXNzBQphc3NldElkU3RyBA1vdXRkYXRlZFNSYXRlCQEQZ2V0T3V0ZGF0ZWRTUmF0ZQIFFGN1cnJlbnRNYXJrZXRBZGRyZXNzBQphc3NldElkU3RyBA1vdXRkYXRlZEJSYXRlCQEQZ2V0T3V0ZGF0ZWRCUmF0ZQIFFGN1cnJlbnRNYXJrZXRBZGRyZXNzBQphc3NldElkU3RyBApvdXRkYXRlZFVyCQENZ2V0T3V0ZGF0ZWRVcgQFE291dGRhdGVkVG90YWxTdXBwbHkFE291dGRhdGVkVG90YWxCb3Jyb3cFDW91dGRhdGVkU1JhdGUFDW91dGRhdGVkQlJhdGUEBHJhdGUJAQdnZXRSYXRlAwUKb3V0ZGF0ZWRVcgUKYXNzZXRJZFN0cgUJbWFya2V0U3RyBAhpbnRlcmVzdAkBC2dldEludGVyZXN0AQUEcmF0ZQQFc1JhdGUJAQ5nZXRBY3R1YWxTUmF0ZQQFFWN1cnJlbnRMYXN0UmF0ZUhlaWdodAUIaW50ZXJlc3QFCm91dGRhdGVkVXIFDW91dGRhdGVkU1JhdGUEBWJSYXRlCQEOZ2V0QWN0dWFsQlJhdGUDBRVjdXJyZW50TGFzdFJhdGVIZWlnaHQFCGludGVyZXN0BQ1vdXRkYXRlZEJSYXRlBAZzdXBwbHkJAQ9nZXRBY3R1YWxBbW91bnQCBRNvdXRkYXRlZFRvdGFsU3VwcGx5BQVzUmF0ZQQGYm9ycm93CQEPZ2V0QWN0dWFsQW1vdW50AgUTb3V0ZGF0ZWRUb3RhbEJvcnJvdwUFYlJhdGUEAnVyCQELZ2V0QWN0dWFsVXICBQZzdXBwbHkFBmJvcnJvdwQJc3VwcGx5QXB5CQEMZ2V0U3VwcGx5QXB5AgUEcmF0ZQUCdXIECWJvcnJvd0FweQkBDGdldEJvcnJvd0FweQEFBHJhdGUEDHdhbGxldFN1cHBseQkBD2dldFdhbGxldFN1cHBseQQFFGN1cnJlbnRNYXJrZXRBZGRyZXNzBQphc3NldElkU3RyBQZ3YWxsZXQFBXNSYXRlBBF3YWxsZXRTdXBwbHlJblVzZAkBCGdldEluVXNkAwUMd2FsbGV0U3VwcGx5BQphc3NldFNjYWxlBQVwcmljZQQMd2FsbGV0Qm9ycm93CQEPZ2V0V2FsbGV0Qm9ycm93BAUUY3VycmVudE1hcmtldEFkZHJlc3MFCmFzc2V0SWRTdHIFBndhbGxldAUFYlJhdGUEEXdhbGxldEJvcnJvd0luVXNkCQEIZ2V0SW5Vc2QDBQx3YWxsZXRCb3Jyb3cFCmFzc2V0U2NhbGUFBXByaWNlBBZ3YWxsZXRCb3Jyb3dMaW1pdEluVXNkCQBrAwURd2FsbGV0U3VwcGx5SW5Vc2QFAmNmBQZTY2FsZTgEFndhbGxldEJvcnJvd1VzYWdlSW5Vc2QJAGsDBRF3YWxsZXRCb3Jyb3dJblVzZAUGU2NhbGU4BQJsdAQRd2FsbGV0RGFpbHlJbmNvbWUJARBnZXREYWlseVBlcmNlbnRzAgUJc3VwcGx5QXB5BQx3YWxsZXRTdXBwbHkEFndhbGxldERhaWx5SW5jb21lSW5Vc2QJAQhnZXRJblVzZAMFEXdhbGxldERhaWx5SW5jb21lBQphc3NldFNjYWxlBQVwcmljZQQXd2FsbGV0RGFpbHlMb2FuSW50ZXJlc3QJARBnZXREYWlseVBlcmNlbnRzAgUJYm9ycm93QXB5BQx3YWxsZXRCb3Jyb3cEHHdhbGxldERhaWx5TG9hbkludGVyZXN0SW5Vc2QJAQhnZXRJblVzZAMFF3dhbGxldERhaWx5TG9hbkludGVyZXN0BQphc3NldFNjYWxlBQVwcmljZQQRd2FsbGV0TWFyZ2luSW5Vc2QJAGUCCQBrAwURd2FsbGV0U3VwcGx5SW5Vc2QFCXN1cHBseUFweQUGU2NhbGU4CQBrAwURd2FsbGV0Qm9ycm93SW5Vc2QFCWJvcnJvd0FweQUGU2NhbGU4CQCZCgcJAGQCCAUFYWNjdW0CXzEFEXdhbGxldFN1cHBseUluVXNkCQBkAggFBWFjY3VtAl8yBRF3YWxsZXRCb3Jyb3dJblVzZAkAZAIIBQVhY2N1bQJfMwUWd2FsbGV0Qm9ycm93TGltaXRJblVzZAkAZAIIBQVhY2N1bQJfNAUWd2FsbGV0Qm9ycm93VXNhZ2VJblVzZAkAZAIIBQVhY2N1bQJfNQUWd2FsbGV0RGFpbHlJbmNvbWVJblVzZAkAZAIIBQVhY2N1bQJfNgUcd2FsbGV0RGFpbHlMb2FuSW50ZXJlc3RJblVzZAkAZAIIBQVhY2N1bQJfNwURd2FsbGV0TWFyZ2luSW5Vc2QEDSR0MDMyMTc4MzI1MzMKAAIkbAUFYXJyMTIKAAIkcwkAkAMBBQIkbAoABSRhY2MwCQCZCgcAAAAAAAAAAAAAAAAAAAoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEQbWFya2V0QXNzZXRzRm9sZAIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMTIJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgALAAwEFnRvdGFsV2FsbGV0U3VwcGx5SW5Vc2QIBQ0kdDAzMjE3ODMyNTMzAl8xBBZ0b3RhbFdhbGxldEJvcnJvd0luVXNkCAUNJHQwMzIxNzgzMjUzMwJfMgQbdG90YWxXYWxsZXRCb3Jyb3dMaW1pdEluVXNkCAUNJHQwMzIxNzgzMjUzMwJfMwQbdG90YWxXYWxsZXRCb3Jyb3dVc2FnZUluVXNkCAUNJHQwMzIxNzgzMjUzMwJfNAQbdG90YWxXYWxsZXREYWlseUluY29tZUluVXNkCAUNJHQwMzIxNzgzMjUzMwJfNQQhdG90YWxXYWxsZXREYWlseUxvYW5JbnRlcmVzdEluVXNkCAUNJHQwMzIxNzgzMjUzMwJfNgQWdG90YWxXYWxsZXRNYXJnaW5JblVzZAgFDSR0MDMyMTc4MzI1MzMCXzcEF3RvdGFsV2FsbGV0QmFkRGVidEluVXNkAwkAZgIFFnRvdGFsV2FsbGV0Qm9ycm93SW5Vc2QFFnRvdGFsV2FsbGV0U3VwcGx5SW5Vc2QJAGUCBRZ0b3RhbFdhbGxldEJvcnJvd0luVXNkBRZ0b3RhbFdhbGxldFN1cHBseUluVXNkAAAEDWFjY291bnRIZWFsdGgJARBnZXRBY2NvdW50SGVhbHRoAgUbdG90YWxXYWxsZXRCb3Jyb3dMaW1pdEluVXNkBRt0b3RhbFdhbGxldEJvcnJvd1VzYWdlSW5Vc2QEBm5ldEFweQkBCWdldE5ldEFweQMFFnRvdGFsV2FsbGV0U3VwcGx5SW5Vc2QFFnRvdGFsV2FsbGV0Qm9ycm93SW5Vc2QFFnRvdGFsV2FsbGV0TWFyZ2luSW5Vc2QEC21hcmtldHNKc29uCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAgF7AggiaW5kZXgiOgkApAMBBQRuZXh0AgksIm5hbWUiOiIFFmN1cnJlbnRNYXJrZXRTaG9ydE5hbWUCASICDywic3VwcGx5SW5Vc2QiOgkBC2Fzc2V0VG9Kc29uAgUJdXNkdElkU3RyBRZ0b3RhbFdhbGxldFN1cHBseUluVXNkAg8sImJvcnJvd0luVXNkIjoJAQthc3NldFRvSnNvbgIFCXVzZHRJZFN0cgUWdG90YWxXYWxsZXRCb3Jyb3dJblVzZAIRLCJhY2NvdW50SGVhbHRoIjoJAQ9hbW91bnRUb0RlY2ltYWwCBQ1hY2NvdW50SGVhbHRoAAgCAX0KARB3YWxsZXRBc3NldHNGb2xkAgVhY2N1bQRuZXh0AwkAZwIFBG5leHQFEmN1cnJlbnRBc3NldHNDb3VudAUFYWNjdW0ECmFzc2V0SWRTdHIJAJEDAgUSY3VycmVudFNldHVwVG9rZW5zBQRuZXh0BAVwcmljZQkBDWdldFRva2VuUHJpY2UCBQ1tYXJrZXRBZGRyZXNzBQphc3NldElkU3RyBAphc3NldFNjYWxlCQENZ2V0QXNzZXRTY2FsZQEFCmFzc2V0SWRTdHIEE291dGRhdGVkVG90YWxTdXBwbHkJARZnZXRPdXRkYXRlZFRvdGFsU3VwcGx5AgUUY3VycmVudE1hcmtldEFkZHJlc3MFCmFzc2V0SWRTdHIEE291dGRhdGVkVG90YWxCb3Jyb3cJARZnZXRPdXRkYXRlZFRvdGFsQm9ycm93AgUUY3VycmVudE1hcmtldEFkZHJlc3MFCmFzc2V0SWRTdHIEDW91dGRhdGVkU1JhdGUJARBnZXRPdXRkYXRlZFNSYXRlAgUUY3VycmVudE1hcmtldEFkZHJlc3MFCmFzc2V0SWRTdHIEDW91dGRhdGVkQlJhdGUJARBnZXRPdXRkYXRlZEJSYXRlAgUUY3VycmVudE1hcmtldEFkZHJlc3MFCmFzc2V0SWRTdHIECm91dGRhdGVkVXIJAQ1nZXRPdXRkYXRlZFVyBAUTb3V0ZGF0ZWRUb3RhbFN1cHBseQUTb3V0ZGF0ZWRUb3RhbEJvcnJvdwUNb3V0ZGF0ZWRTUmF0ZQUNb3V0ZGF0ZWRCUmF0ZQQEcmF0ZQkBB2dldFJhdGUDBQpvdXRkYXRlZFVyBQphc3NldElkU3RyBQltYXJrZXRTdHIECGludGVyZXN0CQELZ2V0SW50ZXJlc3QBBQRyYXRlBAVzUmF0ZQkBDmdldEFjdHVhbFNSYXRlBAUVY3VycmVudExhc3RSYXRlSGVpZ2h0BQhpbnRlcmVzdAUKb3V0ZGF0ZWRVcgUNb3V0ZGF0ZWRTUmF0ZQQFYlJhdGUJAQ5nZXRBY3R1YWxCUmF0ZQMFFWN1cnJlbnRMYXN0UmF0ZUhlaWdodAUIaW50ZXJlc3QFDW91dGRhdGVkQlJhdGUEBnN1cHBseQkBD2dldEFjdHVhbEFtb3VudAIFE291dGRhdGVkVG90YWxTdXBwbHkFBXNSYXRlBAZib3Jyb3cJAQ9nZXRBY3R1YWxBbW91bnQCBRNvdXRkYXRlZFRvdGFsQm9ycm93BQViUmF0ZQQCdXIJAQtnZXRBY3R1YWxVcgIFBnN1cHBseQUGYm9ycm93BAlzdXBwbHlBcHkJAQxnZXRTdXBwbHlBcHkCBQRyYXRlBQJ1cgQJYm9ycm93QXB5CQEMZ2V0Qm9ycm93QXB5AQUEcmF0ZQQMd2FsbGV0U3VwcGx5CQEPZ2V0V2FsbGV0U3VwcGx5BAUUY3VycmVudE1hcmtldEFkZHJlc3MFCmFzc2V0SWRTdHIFBndhbGxldAUFc1JhdGUEEXdhbGxldFN1cHBseUluVXNkCQEIZ2V0SW5Vc2QDBQx3YWxsZXRTdXBwbHkFCmFzc2V0U2NhbGUFBXByaWNlBAx3YWxsZXRCb3Jyb3cJAQ9nZXRXYWxsZXRCb3Jyb3cEBRRjdXJyZW50TWFya2V0QWRkcmVzcwUKYXNzZXRJZFN0cgUGd2FsbGV0BQViUmF0ZQQRd2FsbGV0Qm9ycm93SW5Vc2QJAQhnZXRJblVzZAMFDHdhbGxldEJvcnJvdwUKYXNzZXRTY2FsZQUFcHJpY2UEEXdhbGxldERhaWx5SW5jb21lCQEQZ2V0RGFpbHlQZXJjZW50cwIFCXN1cHBseUFweQUMd2FsbGV0U3VwcGx5BBZ3YWxsZXREYWlseUluY29tZUluVXNkCQEIZ2V0SW5Vc2QDBRF3YWxsZXREYWlseUluY29tZQUKYXNzZXRTY2FsZQUFcHJpY2UEF3dhbGxldERhaWx5TG9hbkludGVyZXN0CQEQZ2V0RGFpbHlQZXJjZW50cwIFCWJvcnJvd0FweQUMd2FsbGV0Qm9ycm93BBx3YWxsZXREYWlseUxvYW5JbnRlcmVzdEluVXNkCQEIZ2V0SW5Vc2QDBRd3YWxsZXREYWlseUxvYW5JbnRlcmVzdAUKYXNzZXRTY2FsZQUFcHJpY2UEEHN1cHBseUFzc2V0c0pzb24JAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgIBewIJImFtb3VudCI6CQELYXNzZXRUb0pzb24CBQphc3NldElkU3RyBQx3YWxsZXRTdXBwbHkCDywiYW1vdW50SW5Vc2QiOgkBC2Fzc2V0VG9Kc29uAgUJdXNkdElkU3RyBRF3YWxsZXRTdXBwbHlJblVzZAIJLCJwcmljZSI6CQELYXNzZXRUb0pzb24CBQl1c2R0SWRTdHIFBXByaWNlAgcsImFweSI6CQEPYW1vdW50VG9EZWNpbWFsAgUJc3VwcGx5QXB5AAgCESwiZGFpbHlQZXJjZW50cyI6CQELYXNzZXRUb0pzb24CBQphc3NldElkU3RyBRF3YWxsZXREYWlseUluY29tZQIWLCJkYWlseVBlcmNlbnRzSW5Vc2QiOgkBC2Fzc2V0VG9Kc29uAgUJdXNkdElkU3RyBRZ3YWxsZXREYWlseUluY29tZUluVXNkAgF9BBBib3Jyb3dBc3NldHNKc29uCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICAXsCCSJhbW91bnQiOgkBC2Fzc2V0VG9Kc29uAgUKYXNzZXRJZFN0cgUMd2FsbGV0Qm9ycm93Ag8sImFtb3VudEluVXNkIjoJAQthc3NldFRvSnNvbgIFCXVzZHRJZFN0cgURd2FsbGV0Qm9ycm93SW5Vc2QCCSwicHJpY2UiOgkBC2Fzc2V0VG9Kc29uAgUJdXNkdElkU3RyBQVwcmljZQIHLCJhcHkiOgkBD2Ftb3VudFRvRGVjaW1hbAIFCWJvcnJvd0FweQAIAhEsImRhaWx5UGVyY2VudHMiOgkBC2Fzc2V0VG9Kc29uAgUKYXNzZXRJZFN0cgUXd2FsbGV0RGFpbHlMb2FuSW50ZXJlc3QCFiwiZGFpbHlQZXJjZW50c0luVXNkIjoJAQthc3NldFRvSnNvbgIFCXVzZHRJZFN0cgUcd2FsbGV0RGFpbHlMb2FuSW50ZXJlc3RJblVzZAIBfQkAlAoCCQDNCAIIBQVhY2N1bQJfMQUQc3VwcGx5QXNzZXRzSnNvbgkAzQgCCAUFYWNjdW0CXzIFEGJvcnJvd0Fzc2V0c0pzb24EDSR0MDM2OTM1MzcwMjEKAAIkbAUFYXJyMTIKAAIkcwkAkAMBBQIkbAoABSRhY2MwCQCUCgIFA25pbAUDbmlsCgEFJGYxXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJARB3YWxsZXRBc3NldHNGb2xkAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYxXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMgkBBSRmMV8yAgkBBSRmMV8xAgkBBSRmMV8xAgkBBSRmMV8xAgkBBSRmMV8xAgkBBSRmMV8xAgkBBSRmMV8xAgkBBSRmMV8xAgkBBSRmMV8xAgkBBSRmMV8xAgkBBSRmMV8xAgkBBSRmMV8xAgkBBSRmMV8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKAAsADAQQc3VwcGx5QXNzZXRzSnNvbggFDSR0MDM2OTM1MzcwMjECXzEEEGJvcnJvd0Fzc2V0c0pzb24IBQ0kdDAzNjkzNTM3MDIxAl8yAwkAAAIFC21hcmtldEluZGV4BQRuZXh0CQChCg8JAGQCCAUFYWNjdW0CXzEFFnRvdGFsV2FsbGV0U3VwcGx5SW5Vc2QJAGQCCAUFYWNjdW0CXzIFFnRvdGFsV2FsbGV0Qm9ycm93SW5Vc2QJAGQCCAUFYWNjdW0CXzMFF3RvdGFsV2FsbGV0QmFkRGVidEluVXNkCQBkAggFBWFjY3VtAl80BRt0b3RhbFdhbGxldERhaWx5SW5jb21lSW5Vc2QJAGQCCAUFYWNjdW0CXzUFIXRvdGFsV2FsbGV0RGFpbHlMb2FuSW50ZXJlc3RJblVzZAUWdG90YWxXYWxsZXRTdXBwbHlJblVzZAUWdG90YWxXYWxsZXRCb3Jyb3dJblVzZAUXdG90YWxXYWxsZXRCYWREZWJ0SW5Vc2QFG3RvdGFsV2FsbGV0RGFpbHlJbmNvbWVJblVzZAUhdG90YWxXYWxsZXREYWlseUxvYW5JbnRlcmVzdEluVXNkBQ1hY2NvdW50SGVhbHRoBQZuZXRBcHkJAM0IAggFBWFjY3VtA18xMwULbWFya2V0c0pzb24FEHN1cHBseUFzc2V0c0pzb24FEGJvcnJvd0Fzc2V0c0pzb24JAKEKDwkAZAIIBQVhY2N1bQJfMQUWdG90YWxXYWxsZXRTdXBwbHlJblVzZAkAZAIIBQVhY2N1bQJfMgUWdG90YWxXYWxsZXRCb3Jyb3dJblVzZAkAZAIIBQVhY2N1bQJfMwUXdG90YWxXYWxsZXRCYWREZWJ0SW5Vc2QJAGQCCAUFYWNjdW0CXzQFG3RvdGFsV2FsbGV0RGFpbHlJbmNvbWVJblVzZAkAZAIIBQVhY2N1bQJfNQUhdG90YWxXYWxsZXREYWlseUxvYW5JbnRlcmVzdEluVXNkCAUFYWNjdW0CXzYIBQVhY2N1bQJfNwgFBWFjY3VtAl84CAUFYWNjdW0CXzkIBQVhY2N1bQNfMTAIBQVhY2N1bQNfMTEIBQVhY2N1bQNfMTIJAM0IAggFBWFjY3VtA18xMwULbWFya2V0c0pzb24IBQVhY2N1bQNfMTQIBQVhY2N1bQNfMTUEDSR0MDM4NDc4Mzg5NjIKAAIkbAUFYXJyMTIKAAIkcwkAkAMBBQIkbAoABSRhY2MwCQChCg8AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAFA25pbAUDbmlsBQNuaWwKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBC21hcmtldHNGb2xkAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxMgkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKAAsADAQWdG90YWxXYWxsZXRTdXBwbHlJblVzZAgFDSR0MDM4NDc4Mzg5NjICXzEEFnRvdGFsV2FsbGV0Qm9ycm93SW5Vc2QIBQ0kdDAzODQ3ODM4OTYyAl8yBBd0b3RhbFdhbGxldEJhZERlYnRJblVzZAgFDSR0MDM4NDc4Mzg5NjICXzMEG3RvdGFsV2FsbGV0RGFpbHlJbmNvbWVJblVzZAgFDSR0MDM4NDc4Mzg5NjICXzQEIXRvdGFsV2FsbGV0RGFpbHlMb2FuSW50ZXJlc3RJblVzZAgFDSR0MDM4NDc4Mzg5NjICXzUEEXdhbGxldFN1cHBseUluVXNkCAUNJHQwMzg0NzgzODk2MgJfNgQRd2FsbGV0Qm9ycm93SW5Vc2QIBQ0kdDAzODQ3ODM4OTYyAl83BBJ3YWxsZXRCYWREZWJ0SW5Vc2QIBQ0kdDAzODQ3ODM4OTYyAl84BBZ3YWxsZXREYWlseUluY29tZUluVXNkCAUNJHQwMzg0NzgzODk2MgJfOQQcd2FsbGV0RGFpbHlMb2FuSW50ZXJlc3RJblVzZAgFDSR0MDM4NDc4Mzg5NjIDXzEwBBN3YWxsZXRBY2NvdW50SGVhbHRoCAUNJHQwMzg0NzgzODk2MgNfMTEEDHdhbGxldE5ldEFweQgFDSR0MDM4NDc4Mzg5NjIDXzEyBAttYXJrZXRzSnNvbggFDSR0MDM4NDc4Mzg5NjIDXzEzBBBzdXBwbHlBc3NldHNKc29uCAUNJHQwMzg0NzgzODk2MgNfMTQEEGJvcnJvd0Fzc2V0c0pzb24IBQ0kdDAzODQ3ODM4OTYyA18xNQQEanNvbgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgIBewIOIm1hcmtldEluZGV4IjoJAKQDAQULbWFya2V0SW5kZXgCCSwibmFtZSI6IgUKbWFya2V0TmFtZQIBIgIULCJ0b3RhbFN1cHBseUluVXNkIjoJAQthc3NldFRvSnNvbgIFCXVzZHRJZFN0cgUWdG90YWxXYWxsZXRTdXBwbHlJblVzZAIULCJ0b3RhbEJvcnJvd0luVXNkIjoJAQthc3NldFRvSnNvbgIFCXVzZHRJZFN0cgUWdG90YWxXYWxsZXRCb3Jyb3dJblVzZAIVLCJ0b3RhbEJhZERlYnRJblVzZCI6CQELYXNzZXRUb0pzb24CBQl1c2R0SWRTdHIFF3RvdGFsV2FsbGV0QmFkRGVidEluVXNkAhksInRvdGFsRGFpbHlJbmNvbWVJblVzZCI6CQELYXNzZXRUb0pzb24CBQl1c2R0SWRTdHIFG3RvdGFsV2FsbGV0RGFpbHlJbmNvbWVJblVzZAIfLCJ0b3RhbERhaWx5TG9hbkludGVyZXN0SW5Vc2QiOgkBC2Fzc2V0VG9Kc29uAgUJdXNkdElkU3RyBSF0b3RhbFdhbGxldERhaWx5TG9hbkludGVyZXN0SW5Vc2QCDywic3VwcGx5SW5Vc2QiOgkBC2Fzc2V0VG9Kc29uAgUJdXNkdElkU3RyBRF3YWxsZXRTdXBwbHlJblVzZAIPLCJib3Jyb3dJblVzZCI6CQELYXNzZXRUb0pzb24CBQl1c2R0SWRTdHIFEXdhbGxldEJvcnJvd0luVXNkAhAsImJhZERlYnRJblVzZCI6CQELYXNzZXRUb0pzb24CBQl1c2R0SWRTdHIFEndhbGxldEJhZERlYnRJblVzZAIULCJkYWlseUluY29tZUluVXNkIjoJAQthc3NldFRvSnNvbgIFCXVzZHRJZFN0cgUWd2FsbGV0RGFpbHlJbmNvbWVJblVzZAIaLCJkYWlseUxvYW5JbnRlcmVzdEluVXNkIjoJAQthc3NldFRvSnNvbgIFCXVzZHRJZFN0cgUcd2FsbGV0RGFpbHlMb2FuSW50ZXJlc3RJblVzZAIRLCJhY2NvdW50SGVhbHRoIjoJAQ9hbW91bnRUb0RlY2ltYWwCBRN3YWxsZXRBY2NvdW50SGVhbHRoAAgCCiwibmV0QXB5IjoJAQ9hbW91bnRUb0RlY2ltYWwCBQx3YWxsZXROZXRBcHkACAIRLCJzdXBwbHlBc3NldHMiOlsJALsJAgUQc3VwcGx5QXNzZXRzSnNvbgIBLAIBXQIRLCJib3Jyb3dBc3NldHMiOlsJALsJAgUQYm9ycm93QXNzZXRzSnNvbgIBLAIBXQIMLCJtYXJrZXRzIjpbCQC7CQIFC21hcmtldHNKc29uAgEsAgFdAgF9AwUFZGVidWcJAAIBBQRqc29uBQRqc29uARdnZXRXYWxsZXRPcGVyYXRpb25zSnNvbgQLbWFya2V0SW5kZXgKYXNzZXRJZFN0cgZ3YWxsZXQFZGVidWcECW1hcmtldFN0cgkBEUBleHRyTmF0aXZlKDEwNTgpAQkArAICAgdtYXJrZXRfCQCkAwEFC21hcmtldEluZGV4BA1tYXJrZXRBZGRyZXNzCQERQGV4dHJOYXRpdmUoMTA2MikBBQltYXJrZXRTdHIECm1hcmtldE5hbWUJARFAZXh0ck5hdGl2ZSgxMDU4KQEJAKwCAgIMbWFya2V0X25hbWVfBQltYXJrZXRTdHIEBmFjdGl2ZQkBC3ZhbHVlT3JFbHNlAgkAmwgCBQ1tYXJrZXRBZGRyZXNzAgxzZXR1cF9hY3RpdmUGBAtzZXR1cFRva2VucwkBDmdldFNldHVwVG9rZW5zAQUNbWFya2V0QWRkcmVzcwQHc2V0dXBDZgkAvAkCCQERQGV4dHJOYXRpdmUoMTA1MykCBQ1tYXJrZXRBZGRyZXNzAgpzZXR1cF9sdHZzAgEsBAdzZXR1cEx0CQC8CQIJARFAZXh0ck5hdGl2ZSgxMDUzKQIFDW1hcmtldEFkZHJlc3MCCXNldHVwX2x0cwIBLAQMc2V0dXBQZW5hbHR5CQC8CQIJARFAZXh0ck5hdGl2ZSgxMDUzKQIFDW1hcmtldEFkZHJlc3MCD3NldHVwX3BlbmFsdGllcwIBLAQKYXNzZXRJbmRleAkBDWdldEFzc2V0SW5kZXgCBQtzZXR1cFRva2VucwUKYXNzZXRJZFN0cgQCY2YJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQdzZXR1cENmBQphc3NldEluZGV4BAJsdAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFB3NldHVwTHQFCmFzc2V0SW5kZXgEB3BlbmFsdHkJAQ1wYXJzZUludFZhbHVlAQkAkQMCBQxzZXR1cFBlbmFsdHkFCmFzc2V0SW5kZXgEC2Fzc2V0c0NvdW50CQCQAwEFC3NldHVwVG9rZW5zBA5sYXN0UmF0ZUhlaWdodAkBEWdldExhc3RSYXRlSGVpZ2h0AQUNbWFya2V0QWRkcmVzcwQFcHJpY2UJAQ1nZXRUb2tlblByaWNlAgUNbWFya2V0QWRkcmVzcwUKYXNzZXRJZFN0cgQKYXNzZXRTY2FsZQkBDWdldEFzc2V0U2NhbGUBBQphc3NldElkU3RyBBNvdXRkYXRlZFRvdGFsU3VwcGx5CQEWZ2V0T3V0ZGF0ZWRUb3RhbFN1cHBseQIFDW1hcmtldEFkZHJlc3MFCmFzc2V0SWRTdHIEE291dGRhdGVkVG90YWxCb3Jyb3cJARZnZXRPdXRkYXRlZFRvdGFsQm9ycm93AgUNbWFya2V0QWRkcmVzcwUKYXNzZXRJZFN0cgQNb3V0ZGF0ZWRTUmF0ZQkBEGdldE91dGRhdGVkU1JhdGUCBQ1tYXJrZXRBZGRyZXNzBQphc3NldElkU3RyBA1vdXRkYXRlZEJSYXRlCQEQZ2V0T3V0ZGF0ZWRCUmF0ZQIFDW1hcmtldEFkZHJlc3MFCmFzc2V0SWRTdHIECm91dGRhdGVkVXIJAQ1nZXRPdXRkYXRlZFVyBAUTb3V0ZGF0ZWRUb3RhbFN1cHBseQUTb3V0ZGF0ZWRUb3RhbEJvcnJvdwUNb3V0ZGF0ZWRTUmF0ZQUNb3V0ZGF0ZWRCUmF0ZQQEcmF0ZQkBB2dldFJhdGUDBQpvdXRkYXRlZFVyBQphc3NldElkU3RyBQltYXJrZXRTdHIECGludGVyZXN0CQELZ2V0SW50ZXJlc3QBBQRyYXRlBAVzUmF0ZQkBDmdldEFjdHVhbFNSYXRlBAUObGFzdFJhdGVIZWlnaHQFCGludGVyZXN0BQpvdXRkYXRlZFVyBQ1vdXRkYXRlZFNSYXRlBAViUmF0ZQkBDmdldEFjdHVhbEJSYXRlAwUObGFzdFJhdGVIZWlnaHQFCGludGVyZXN0BQ1vdXRkYXRlZEJSYXRlBAZzdXBwbHkJAQ9nZXRBY3R1YWxBbW91bnQCBRNvdXRkYXRlZFRvdGFsU3VwcGx5BQVzUmF0ZQQGYm9ycm93CQEPZ2V0QWN0dWFsQW1vdW50AgUTb3V0ZGF0ZWRUb3RhbEJvcnJvdwUFYlJhdGUEC3N1cHBseUluVXNkCQEIZ2V0SW5Vc2QDBQZzdXBwbHkFCmFzc2V0U2NhbGUFBXByaWNlBAtib3Jyb3dJblVzZAkBCGdldEluVXNkAwUGYm9ycm93BQphc3NldFNjYWxlBQVwcmljZQQIcmVzZXJ2ZXMJAGUCBQZzdXBwbHkFBmJvcnJvdwQNcmVzZXJ2ZXNJblVzZAkBCGdldEluVXNkAwUIcmVzZXJ2ZXMFCmFzc2V0U2NhbGUFBXByaWNlBAJ1cgkBC2dldEFjdHVhbFVyAgUGc3VwcGx5BQZib3Jyb3cECXN1cHBseUFweQkBDGdldFN1cHBseUFweQIFBHJhdGUFAnVyBAlib3Jyb3dBcHkJAQxnZXRCb3Jyb3dBcHkBBQRyYXRlBAltYXhTdXBwbHkJAQxnZXRNYXhTdXBwbHkCBQ1tYXJrZXRBZGRyZXNzBQphc3NldElkU3RyBAx3YWxsZXRTdXBwbHkJAQ9nZXRXYWxsZXRTdXBwbHkEBQ1tYXJrZXRBZGRyZXNzBQphc3NldElkU3RyBQZ3YWxsZXQFBXNSYXRlBBF3YWxsZXRTdXBwbHlJblVzZAkBCGdldEluVXNkAwUMd2FsbGV0U3VwcGx5BQphc3NldFNjYWxlBQVwcmljZQQRd2FsbGV0RGFpbHlJbmNvbWUJARBnZXREYWlseVBlcmNlbnRzAgUJc3VwcGx5QXB5BQx3YWxsZXRTdXBwbHkEFndhbGxldERhaWx5SW5jb21lSW5Vc2QJAQhnZXRJblVzZAMFEXdhbGxldERhaWx5SW5jb21lBQphc3NldFNjYWxlBQVwcmljZQQMd2FsbGV0Qm9ycm93CQEPZ2V0V2FsbGV0Qm9ycm93BAUNbWFya2V0QWRkcmVzcwUKYXNzZXRJZFN0cgUGd2FsbGV0BQViUmF0ZQQRd2FsbGV0Qm9ycm93SW5Vc2QJAQhnZXRJblVzZAMFDHdhbGxldEJvcnJvdwUKYXNzZXRTY2FsZQUFcHJpY2UEF3dhbGxldERhaWx5TG9hblBlcmNlbnRzCQEQZ2V0RGFpbHlQZXJjZW50cwIFCWJvcnJvd0FweQUMd2FsbGV0Qm9ycm93BBx3YWxsZXREYWlseUxvYW5QZXJjZW50c0luVXNkCQEIZ2V0SW5Vc2QDBRd3YWxsZXREYWlseUxvYW5QZXJjZW50cwUKYXNzZXRTY2FsZQUFcHJpY2UKAQphc3NldHNGb2xkAgVhY2N1bQRuZXh0AwkAZwIFBG5leHQFC2Fzc2V0c0NvdW50BQVhY2N1bQQRY3VycmVudEFzc2V0SWRTdHIJAJEDAgULc2V0dXBUb2tlbnMFBG5leHQECWN1cnJlbnRDZgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFB3NldHVwQ2YFBG5leHQECWN1cnJlbnRMdAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFB3NldHVwTHQFBG5leHQEDGN1cnJlbnRQcmljZQkBDWdldFRva2VuUHJpY2UCBQ1tYXJrZXRBZGRyZXNzBRFjdXJyZW50QXNzZXRJZFN0cgQRY3VycmVudEFzc2V0U2NhbGUJAQ1nZXRBc3NldFNjYWxlAQURY3VycmVudEFzc2V0SWRTdHIEGmN1cnJlbnRPdXRkYXRlZFRvdGFsU3VwcGx5CQEWZ2V0T3V0ZGF0ZWRUb3RhbFN1cHBseQIFDW1hcmtldEFkZHJlc3MFEWN1cnJlbnRBc3NldElkU3RyBBpjdXJyZW50T3V0ZGF0ZWRUb3RhbEJvcnJvdwkBFmdldE91dGRhdGVkVG90YWxCb3Jyb3cCBQ1tYXJrZXRBZGRyZXNzBRFjdXJyZW50QXNzZXRJZFN0cgQUY3VycmVudE91dGRhdGVkU1JhdGUJARBnZXRPdXRkYXRlZFNSYXRlAgUNbWFya2V0QWRkcmVzcwURY3VycmVudEFzc2V0SWRTdHIEFGN1cnJlbnRPdXRkYXRlZEJSYXRlCQEQZ2V0T3V0ZGF0ZWRCUmF0ZQIFDW1hcmtldEFkZHJlc3MFEWN1cnJlbnRBc3NldElkU3RyBBFjdXJyZW50T3V0ZGF0ZWRVcgkBDWdldE91dGRhdGVkVXIEBRpjdXJyZW50T3V0ZGF0ZWRUb3RhbFN1cHBseQUaY3VycmVudE91dGRhdGVkVG90YWxCb3Jyb3cFFGN1cnJlbnRPdXRkYXRlZFNSYXRlBRRjdXJyZW50T3V0ZGF0ZWRCUmF0ZQQLY3VycmVudFJhdGUJAQdnZXRSYXRlAwURY3VycmVudE91dGRhdGVkVXIFEWN1cnJlbnRBc3NldElkU3RyBQltYXJrZXRTdHIED2N1cnJlbnRJbnRlcmVzdAkBC2dldEludGVyZXN0AQULY3VycmVudFJhdGUEDGN1cnJlbnRTUmF0ZQkBDmdldEFjdHVhbFNSYXRlBAUObGFzdFJhdGVIZWlnaHQFD2N1cnJlbnRJbnRlcmVzdAURY3VycmVudE91dGRhdGVkVXIFFGN1cnJlbnRPdXRkYXRlZFNSYXRlBAxjdXJyZW50QlJhdGUJAQ5nZXRBY3R1YWxCUmF0ZQMFDmxhc3RSYXRlSGVpZ2h0BQ9jdXJyZW50SW50ZXJlc3QFFGN1cnJlbnRPdXRkYXRlZEJSYXRlBA1jdXJyZW50U3VwcGx5CQEPZ2V0QWN0dWFsQW1vdW50AgUaY3VycmVudE91dGRhdGVkVG90YWxTdXBwbHkFBXNSYXRlBA1jdXJyZW50Qm9ycm93CQEPZ2V0QWN0dWFsQW1vdW50AgUaY3VycmVudE91dGRhdGVkVG90YWxCb3Jyb3cFBWJSYXRlBAljdXJyZW50VXIJAQtnZXRBY3R1YWxVcgIFDWN1cnJlbnRTdXBwbHkFDWN1cnJlbnRCb3Jyb3cEEGN1cnJlbnRTdXBwbHlBcHkJAQxnZXRTdXBwbHlBcHkCBQtjdXJyZW50UmF0ZQUJY3VycmVudFVyBBBjdXJyZW50Qm9ycm93QXB5CQEMZ2V0Qm9ycm93QXB5AQULY3VycmVudFJhdGUEE2N1cnJlbnRXYWxsZXRTdXBwbHkJAQ9nZXRXYWxsZXRTdXBwbHkEBQ1tYXJrZXRBZGRyZXNzBRFjdXJyZW50QXNzZXRJZFN0cgUGd2FsbGV0BQxjdXJyZW50U1JhdGUEGGN1cnJlbnRXYWxsZXRTdXBwbHlJblVzZAkBCGdldEluVXNkAwUTY3VycmVudFdhbGxldFN1cHBseQURY3VycmVudEFzc2V0U2NhbGUFDGN1cnJlbnRQcmljZQQTY3VycmVudFdhbGxldEJvcnJvdwkBD2dldFdhbGxldEJvcnJvdwQFDW1hcmtldEFkZHJlc3MFEWN1cnJlbnRBc3NldElkU3RyBQZ3YWxsZXQFDGN1cnJlbnRCUmF0ZQQYY3VycmVudFdhbGxldEJvcnJvd0luVXNkCQEIZ2V0SW5Vc2QDBRNjdXJyZW50V2FsbGV0Qm9ycm93BRFjdXJyZW50QXNzZXRTY2FsZQUMY3VycmVudFByaWNlBB1jdXJyZW50V2FsbGV0Qm9ycm93TGltaXRJblVzZAkAawMFGGN1cnJlbnRXYWxsZXRTdXBwbHlJblVzZAUJY3VycmVudENmBQZTY2FsZTgEHWN1cnJlbnRXYWxsZXRCb3Jyb3dVc2FnZUluVXNkCQBrAwUYY3VycmVudFdhbGxldEJvcnJvd0luVXNkBQZTY2FsZTgFCWN1cnJlbnRMdAQRd2FsbGV0TWFyZ2luSW5Vc2QJAGUCCQBrAwUYY3VycmVudFdhbGxldFN1cHBseUluVXNkBRBjdXJyZW50U3VwcGx5QXB5BQZTY2FsZTgJAGsDBRhjdXJyZW50V2FsbGV0Qm9ycm93SW5Vc2QFEGN1cnJlbnRCb3Jyb3dBcHkFBlNjYWxlOAkAlwoFCQBkAggFBWFjY3VtAl8xBRhjdXJyZW50V2FsbGV0U3VwcGx5SW5Vc2QJAGQCCAUFYWNjdW0CXzIFGGN1cnJlbnRXYWxsZXRCb3Jyb3dJblVzZAkAZAIIBQVhY2N1bQJfMwUdY3VycmVudFdhbGxldEJvcnJvd0xpbWl0SW5Vc2QJAGQCCAUFYWNjdW0CXzQFHWN1cnJlbnRXYWxsZXRCb3Jyb3dVc2FnZUluVXNkCQBkAggFBWFjY3VtAl81BRF3YWxsZXRNYXJnaW5JblVzZAQNJHQwNDU5NzM0NjE1NAoAAiRsBQVhcnIxMgoAAiRzCQCQAwEFAiRsCgAFJGFjYzAJAJcKBQAAAAAAAAAAAAAKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBCmFzc2V0c0ZvbGQCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDEyCQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoACwAMBBZ0b3RhbFdhbGxldFN1cHBseUluVXNkCAUNJHQwNDU5NzM0NjE1NAJfMQQWdG90YWxXYWxsZXRCb3Jyb3dJblVzZAgFDSR0MDQ1OTczNDYxNTQCXzIEG3RvdGFsV2FsbGV0Qm9ycm93TGltaXRJblVzZAgFDSR0MDQ1OTczNDYxNTQCXzMEG3RvdGFsV2FsbGV0Qm9ycm93VXNhZ2VJblVzZAgFDSR0MDQ1OTczNDYxNTQCXzQEFnRvdGFsV2FsbGV0TWFyZ2luSW5Vc2QIBQ0kdDA0NTk3MzQ2MTU0Al81BA1hY2NvdW50SGVhbHRoCQEQZ2V0QWNjb3VudEhlYWx0aAIFG3RvdGFsV2FsbGV0Qm9ycm93TGltaXRJblVzZAUbdG90YWxXYWxsZXRCb3Jyb3dVc2FnZUluVXNkBAZuZXRBcHkJAQlnZXROZXRBcHkDBRZ0b3RhbFdhbGxldFN1cHBseUluVXNkBRZ0b3RhbFdhbGxldEJvcnJvd0luVXNkBRZ0b3RhbFdhbGxldE1hcmdpbkluVXNkBARqc29uCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICAgF7Ag4ibWFya2V0SW5kZXgiOgkApAMBBQttYXJrZXRJbmRleAIPLCJtYXJrZXROYW1lIjoiBQptYXJrZXROYW1lAgEiAgwsImFkZHJlc3MiOiIFCW1hcmtldFN0cgIBIgIOLCJhc3NldFByaWNlIjoJAQthc3NldFRvSnNvbgIFCXVzZHRJZFN0cgUFcHJpY2UCCiwic3VwcGx5IjoJAQthc3NldFRvSnNvbgIFCmFzc2V0SWRTdHIFBnN1cHBseQIPLCJzdXBwbHlJblVzZCI6CQELYXNzZXRUb0pzb24CBQl1c2R0SWRTdHIFC3N1cHBseUluVXNkAg0sInN1cHBseUFweSI6CQEPYW1vdW50VG9EZWNpbWFsAgUJc3VwcGx5QXB5AAgCCiwiYm9ycm93IjoJAQthc3NldFRvSnNvbgIFCmFzc2V0SWRTdHIFBmJvcnJvdwIPLCJib3Jyb3dJblVzZCI6CQELYXNzZXRUb0pzb24CBQl1c2R0SWRTdHIFC2JvcnJvd0luVXNkAg0sImJvcnJvd0FweSI6CQEPYW1vdW50VG9EZWNpbWFsAgUJYm9ycm93QXB5AAgCDCwicmVzZXJ2ZXMiOgkBC2Fzc2V0VG9Kc29uAgUKYXNzZXRJZFN0cgUIcmVzZXJ2ZXMCESwicmVzZXJ2ZXNJblVzZCI6CQELYXNzZXRUb0pzb24CBQl1c2R0SWRTdHIFDXJlc2VydmVzSW5Vc2QCFCwidXRpbGl6YXRpb25SYXRpbyI6CQEPYW1vdW50VG9EZWNpbWFsAgUCdXIACAIULCJjb2xsYXRlcmFsRmFjdG9yIjoJAQ9hbW91bnRUb0RlY2ltYWwCBQJjZgAIAhgsImxpcXVpZGF0aW9uVGhyZXNob2xkIjoJAQ9hbW91bnRUb0RlY2ltYWwCBQJsdAAIAhYsImxpcXVpZGF0aW9uUGVuYWx0eSI6CQEPYW1vdW50VG9EZWNpbWFsAgUHcGVuYWx0eQAIAg0sIm1heFN1cHBseSI6CQELYXNzZXRUb0pzb24CBQl1c2R0SWRTdHIFCW1heFN1cHBseQIQLCJ3YWxsZXRTdXBwbHkiOgkBC2Fzc2V0VG9Kc29uAgUKYXNzZXRJZFN0cgUMd2FsbGV0U3VwcGx5AhUsIndhbGxldFN1cHBseUluVXNkIjoJAQthc3NldFRvSnNvbgIFCXVzZHRJZFN0cgURd2FsbGV0U3VwcGx5SW5Vc2QCFSwid2FsbGV0RGFpbHlJbmNvbWUiOgkBC2Fzc2V0VG9Kc29uAgUKYXNzZXRJZFN0cgURd2FsbGV0RGFpbHlJbmNvbWUCGiwid2FsbGV0RGFpbHlJbmNvbWVJblVzZCI6CQELYXNzZXRUb0pzb24CBQl1c2R0SWRTdHIFFndhbGxldERhaWx5SW5jb21lSW5Vc2QCECwid2FsbGV0Qm9ycm93IjoJAQthc3NldFRvSnNvbgIFCmFzc2V0SWRTdHIFDHdhbGxldEJvcnJvdwIVLCJ3YWxsZXRCb3Jyb3dJblVzZCI6CQELYXNzZXRUb0pzb24CBQl1c2R0SWRTdHIFEXdhbGxldEJvcnJvd0luVXNkAhssIndhbGxldERhaWx5TG9hbkludGVyZXN0IjoJAQthc3NldFRvSnNvbgIFCmFzc2V0SWRTdHIFF3dhbGxldERhaWx5TG9hblBlcmNlbnRzAiAsIndhbGxldERhaWx5TG9hbkludGVyZXN0SW5Vc2QiOgkBC2Fzc2V0VG9Kc29uAgUJdXNkdElkU3RyBRx3YWxsZXREYWlseUxvYW5QZXJjZW50c0luVXNkAhEsImFjY291bnRIZWFsdGgiOgkBD2Ftb3VudFRvRGVjaW1hbAIFDWFjY291bnRIZWFsdGgACAIKLCJuZXRBcHkiOgkBD2Ftb3VudFRvRGVjaW1hbAIFBm5ldEFweQAIAgF9AwUFZGVidWcJAAIBBQRqc29uBQRqc29uARdnZXRNYXJrZXRQYXJhbWV0ZXJzSnNvbgILbWFya2V0SW5kZXgFZGVidWcECW1hcmtldFN0cgkBEUBleHRyTmF0aXZlKDEwNTgpAQkArAICAgdtYXJrZXRfCQCkAwEFC21hcmtldEluZGV4BA1tYXJrZXRBZGRyZXNzCQERQGV4dHJOYXRpdmUoMTA2MikBBQltYXJrZXRTdHIECm1hcmtldE5hbWUJARFAZXh0ck5hdGl2ZSgxMDU4KQEJAKwCAgIMbWFya2V0X25hbWVfBQltYXJrZXRTdHIEC3NldHVwVG9rZW5zCQEOZ2V0U2V0dXBUb2tlbnMBBQ1tYXJrZXRBZGRyZXNzBAdzZXR1cENmCQC8CQIJARFAZXh0ck5hdGl2ZSgxMDUzKQIFDW1hcmtldEFkZHJlc3MCCnNldHVwX2x0dnMCASwEB3NldHVwTHQJALwJAgkBEUBleHRyTmF0aXZlKDEwNTMpAgUNbWFya2V0QWRkcmVzcwIJc2V0dXBfbHRzAgEsBAxzZXR1cFBlbmFsdHkJALwJAgkBEUBleHRyTmF0aXZlKDEwNTMpAgUNbWFya2V0QWRkcmVzcwIPc2V0dXBfcGVuYWx0aWVzAgEsBAthc3NldHNDb3VudAkAkAMBBQtzZXR1cFRva2VucwoBCmFzc2V0c0ZvbGQCBWFjY3VtBG5leHQDCQBnAgUEbmV4dAULYXNzZXRzQ291bnQFBWFjY3VtBAphc3NldElkU3RyCQCRAwIFC3NldHVwVG9rZW5zBQRuZXh0BAltYXhTdXBwbHkJAQxnZXRNYXhTdXBwbHkCBQ1tYXJrZXRBZGRyZXNzBQphc3NldElkU3RyBAJjZgkBDXBhcnNlSW50VmFsdWUBCQCRAwIFB3NldHVwQ2YFBG5leHQEAmx0CQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUHc2V0dXBMdAUEbmV4dAQHcGVuYWx0eQkBDXBhcnNlSW50VmFsdWUBCQCRAwIFDHNldHVwUGVuYWx0eQUEbmV4dAQEanNvbgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICAXsCCCJhc3NldCI6CQELYXNzZXRUb0pzb24CBQphc3NldElkU3RyAAACDSwibWF4U3VwcGx5IjoJAQthc3NldFRvSnNvbgIFCXVzZHRJZFN0cgUJbWF4U3VwcGx5AhQsImNvbGxhdGVyYWxGYWN0b3IiOgkBD2Ftb3VudFRvRGVjaW1hbAIFAmNmAAgCGCwibGlxdWlkYXRpb25UaHJlc2hvbGQiOgkBD2Ftb3VudFRvRGVjaW1hbAIFAmx0AAgCFiwibGlxdWlkYXRpb25QZW5hbHR5IjoJAQ9hbW91bnRUb0RlY2ltYWwCBQdwZW5hbHR5AAgCAX0JAM0IAgUFYWNjdW0FBGpzb24ECmFzc2V0c0pzb24KAAIkbAUFYXJyMTIKAAIkcwkAkAMBBQIkbAoABSRhY2MwBQNuaWwKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBCmFzc2V0c0ZvbGQCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDEyCQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoACwAMBARqc29uCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICAXsCCCJuYW1lIjoiBQptYXJrZXROYW1lAgEiAgssImFzc2V0cyI6WwkAuwkCBQphc3NldHNKc29uAgEsAgFdAgF9AwUFZGVidWcJAAIBBQRqc29uBQRqc29uAABBiZFj", "height": 4065215, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: 46WCUsxY7VmzqMVhosH867sMxK7cj8PfsFcyrK9vVE3E Next: none Diff:
Old | New | Differences | |
---|---|---|---|
42 | 42 | let setupRateCurve = getString(marketAddress, ("setup_rateCurve_" + assetIdStr)) | |
43 | 43 | if (isDefined(setupRateCurve)) | |
44 | 44 | then { | |
45 | - | let curveArr = split(value(setupRateCurve), ",") | |
45 | + | let curveArr = split_4C(value(setupRateCurve), ",") | |
46 | 46 | $Tuple4(parseIntValue(curveArr[0]), parseIntValue(curveArr[1]), parseIntValue(curveArr[2]), parseIntValue(curveArr[3])) | |
47 | 47 | } | |
48 | 48 | else match marketStr { | |
201 | 201 | } | |
202 | 202 | ||
203 | 203 | ||
204 | - | func getSetupTokens (marketAddress) = split(getStringValue(marketAddress, "setup_tokens"), ",") | |
204 | + | func getSetupTokens (marketAddress) = split_4C(getStringValue(marketAddress, "setup_tokens"), ",") | |
205 | 205 | ||
206 | 206 | ||
207 | 207 | func getTokenPrice (marketAddress,assetIdStr) = { | |
208 | 208 | let oracleStr = valueOrElse(getString(marketAddress, "oracle"), oracleAddressStr) | |
209 | 209 | let oracleAddress = addressFromStringValue(oracleStr) | |
210 | - | let stables = split(valueOrElse(getString(marketAddress, "setup_stablesIds"), "9wc3LXNA4TEBsXyKtoLE9mrbDD7WMHXvXrCjZvabLAsi,HGgabTqUS8WtVFUJzfmrTDMgEccJuZLBPhFgQFxvnsoW"), ",") | |
210 | + | let stables = split_4C(valueOrElse(getString(marketAddress, "setup_stablesIds"), "9wc3LXNA4TEBsXyKtoLE9mrbDD7WMHXvXrCjZvabLAsi,HGgabTqUS8WtVFUJzfmrTDMgEccJuZLBPhFgQFxvnsoW"), ",") | |
211 | 211 | if ((indexOf(stables, assetIdStr) != unit)) | |
212 | 212 | then 1000000 | |
213 | 213 | else if (if (if ((assetIdStr == usdtIdStr)) | |
279 | 279 | ||
280 | 280 | ||
281 | 281 | func getMarketParameters (marketAddress,setupTokens) = { | |
282 | - | let setupCf = split(getStringValue(marketAddress, "setup_ltvs"), ",") | |
283 | - | let setupLt = split(getStringValue(marketAddress, "setup_lts"), ",") | |
284 | - | let setupPenalty = split(getStringValue(marketAddress, "setup_penalties"), ",") | |
282 | + | let setupCf = split_4C(getStringValue(marketAddress, "setup_ltvs"), ",") | |
283 | + | let setupLt = split_4C(getStringValue(marketAddress, "setup_lts"), ",") | |
284 | + | let setupPenalty = split_4C(getStringValue(marketAddress, "setup_penalties"), ",") | |
285 | 285 | let tokensSize = size(setupTokens) | |
286 | 286 | func fold (accum,next) = if ((next >= tokensSize)) | |
287 | 287 | then accum | |
367 | 367 | ||
368 | 368 | ||
369 | 369 | func assetToJson (assetIdStr,quantity) = { | |
370 | - | let $ | |
370 | + | let $t01534315538 = if ((assetIdStr == Waves)) | |
371 | 371 | then $Tuple2(8, "WAVES") | |
372 | 372 | else { | |
373 | 373 | let asset = value(assetInfo(fromBase58String(assetIdStr))) | |
374 | 374 | $Tuple2(asset.decimals, asset.name) | |
375 | 375 | } | |
376 | - | let decimals = $ | |
377 | - | let name = $ | |
376 | + | let decimals = $t01534315538._1 | |
377 | + | let name = $t01534315538._2 | |
378 | 378 | (((((((("{\"quantity\":" + toString(quantity)) + ",\"decimals\":") + toString(decimals)) + ",\"name\":\"") + name) + "\",\"id\":\"") + assetIdStr) + "\"}") | |
379 | 379 | } | |
380 | 380 | ||
418 | 418 | $Tuple4((accum._1 + supplyInUsd), (accum._2 + borrowInUsd), (accum._3 + reservesInUsd), (accum._4 :+ marketAssetJson)) | |
419 | 419 | } | |
420 | 420 | ||
421 | - | let $ | |
421 | + | let $t01895119059 = { | |
422 | 422 | let $l = arr12 | |
423 | 423 | let $s = size($l) | |
424 | 424 | let $acc0 = $Tuple4(0, 0, 0, nil) | |
432 | 432 | ||
433 | 433 | $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($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12) | |
434 | 434 | } | |
435 | - | let supplyInUsd = $ | |
436 | - | let borrowInUsd = $ | |
437 | - | let reservesInUsd = $ | |
438 | - | let marketAssetsJson = $ | |
435 | + | let supplyInUsd = $t01895119059._1 | |
436 | + | let borrowInUsd = $t01895119059._2 | |
437 | + | let reservesInUsd = $t01895119059._3 | |
438 | + | let marketAssetsJson = $t01895119059._4 | |
439 | 439 | let marketsCount = getIntegerValue("markets") | |
440 | 440 | func marketsFold (accum,next) = if ((next >= marketsCount)) | |
441 | 441 | then accum | |
450 | 450 | let currentSetupTokens = getSetupTokens(currentMarketAddress) | |
451 | 451 | let currentAssetsCount = size(currentSetupTokens) | |
452 | 452 | let currentMarketShortName = getStringValue(("market_shortname_" + currentMarketAddressStr)) | |
453 | - | let setupCf = split(getStringValue(currentMarketAddress, "setup_ltvs"), ",") | |
454 | - | let setupLt = split(getStringValue(currentMarketAddress, "setup_lts"), ",") | |
453 | + | let setupCf = split_4C(getStringValue(currentMarketAddress, "setup_ltvs"), ",") | |
454 | + | let setupLt = split_4C(getStringValue(currentMarketAddress, "setup_lts"), ",") | |
455 | 455 | let currentLastRateHeight = getLastRateHeight(currentMarketAddress) | |
456 | 456 | func marketAssetsFold (accum,next) = if ((next >= currentAssetsCount)) | |
457 | 457 | then accum | |
479 | 479 | $Tuple4((accum._1 + walletSupplyInUsd), (accum._2 + walletBorrowInUsd), (accum._3 + walletBorrowLimitInUsd), (accum._4 + walletBorrowUsageInUsd)) | |
480 | 480 | } | |
481 | 481 | ||
482 | - | let $ | |
482 | + | let $t02263622796 = { | |
483 | 483 | let $l = arr12 | |
484 | 484 | let $s = size($l) | |
485 | 485 | let $acc0 = $Tuple4(0, 0, 0, 0) | |
493 | 493 | ||
494 | 494 | $f1_2($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12) | |
495 | 495 | } | |
496 | - | let totalWalletSupplyInUsd = $ | |
497 | - | let totalWalletBorrowInUsd = $ | |
498 | - | let totalWalletBorrowLimitInUsd = $ | |
499 | - | let totalWalletBorrowUsageInUsd = $ | |
496 | + | let totalWalletSupplyInUsd = $t02263622796._1 | |
497 | + | let totalWalletBorrowInUsd = $t02263622796._2 | |
498 | + | let totalWalletBorrowLimitInUsd = $t02263622796._3 | |
499 | + | let totalWalletBorrowUsageInUsd = $t02263622796._4 | |
500 | 500 | let accountHealth = getAccountHealth(totalWalletBorrowLimitInUsd, totalWalletBorrowUsageInUsd) | |
501 | 501 | let fullJson = (((((((((((("{" + "\"index\":") + toString(next)) + ",\"name\":\"") + currentMarketShortName) + "\"") + ",\"supplyInUsd\":") + assetToJson(usdtIdStr, totalWalletSupplyInUsd)) + ",\"borrowInUsd\":") + assetToJson(usdtIdStr, totalWalletBorrowInUsd)) + ",\"accountHealth\":") + amountToDecimal(accountHealth, 8)) + "}") | |
502 | 502 | (accum :+ fullJson) | |
559 | 559 | $Tuple4((accum._1 + supplyInUsd), (accum._2 + borrowInUsd), (accum._3 + reservesInUsd), (accum._4 :+ marketAssetJson)) | |
560 | 560 | } | |
561 | 561 | ||
562 | - | let $ | |
562 | + | let $t02673026838 = { | |
563 | 563 | let $l = arr12 | |
564 | 564 | let $s = size($l) | |
565 | 565 | let $acc0 = $Tuple4(0, 0, 0, nil) | |
573 | 573 | ||
574 | 574 | $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($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12) | |
575 | 575 | } | |
576 | - | let supplyInUsd = $ | |
577 | - | let borrowInUsd = $ | |
578 | - | let reservesInUsd = $ | |
579 | - | let marketAssetsJson = $ | |
576 | + | let supplyInUsd = $t02673026838._1 | |
577 | + | let borrowInUsd = $t02673026838._2 | |
578 | + | let reservesInUsd = $t02673026838._3 | |
579 | + | let marketAssetsJson = $t02673026838._4 | |
580 | 580 | let marketJson = ((((((("{" + "\"address\":\"") + marketStr) + "\"") + ",\"assets\":[") + makeString_11C(marketAssetsJson, ",")) + "]") + "}") | |
581 | 581 | $Tuple4((accum._1 + supplyInUsd), (accum._2 + borrowInUsd), (accum._3 + reservesInUsd), (accum._4 :+ marketJson)) | |
582 | 582 | } | |
583 | 583 | ||
584 | - | let $ | |
584 | + | let $t02722927348 = { | |
585 | 585 | let $l = arr12 | |
586 | 586 | let $s = size($l) | |
587 | 587 | let $acc0 = $Tuple4(0, 0, 0, nil) | |
595 | 595 | ||
596 | 596 | $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($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12) | |
597 | 597 | } | |
598 | - | let totalSupplyInUsd = $ | |
599 | - | let totalBorrowInUsd = $ | |
600 | - | let totalReservesInUsd = $ | |
601 | - | let marketsJson = $ | |
598 | + | let totalSupplyInUsd = $t02722927348._1 | |
599 | + | let totalBorrowInUsd = $t02722927348._2 | |
600 | + | let totalReservesInUsd = $t02722927348._3 | |
601 | + | let marketsJson = $t02722927348._4 | |
602 | 602 | let json = (((((((((("{" + "\"supplyInUsd\":") + assetToJson(usdtIdStr, totalSupplyInUsd)) + ",\"borrowInUsd\":") + assetToJson(usdtIdStr, totalBorrowInUsd)) + ",\"reservesInUsd\":") + assetToJson(usdtIdStr, totalReservesInUsd)) + ",\"markets\":[") + makeString_11C(marketsJson, ",")) + "]") + "}") | |
603 | 603 | if (debug) | |
604 | 604 | then throw(json) | |
620 | 620 | let currentSetupTokens = getSetupTokens(currentMarketAddress) | |
621 | 621 | let currentAssetsCount = size(currentSetupTokens) | |
622 | 622 | let currentMarketShortName = getStringValue(("market_shortname_" + currentMarketAddressStr)) | |
623 | - | let setupCf = split(getStringValue(currentMarketAddress, "setup_ltvs"), ",") | |
624 | - | let setupLt = split(getStringValue(currentMarketAddress, "setup_lts"), ",") | |
623 | + | let setupCf = split_4C(getStringValue(currentMarketAddress, "setup_ltvs"), ",") | |
624 | + | let setupLt = split_4C(getStringValue(currentMarketAddress, "setup_lts"), ",") | |
625 | 625 | let currentLastRateHeight = getLastRateHeight(currentMarketAddress) | |
626 | 626 | func marketAssetsFold (accum,next) = if ((next >= currentAssetsCount)) | |
627 | 627 | then accum | |
659 | 659 | $Tuple7((accum._1 + walletSupplyInUsd), (accum._2 + walletBorrowInUsd), (accum._3 + walletBorrowLimitInUsd), (accum._4 + walletBorrowUsageInUsd), (accum._5 + walletDailyIncomeInUsd), (accum._6 + walletDailyLoanInterestInUsd), (accum._7 + walletMarginInUsd)) | |
660 | 660 | } | |
661 | 661 | ||
662 | - | let $ | |
662 | + | let $t03217832533 = { | |
663 | 663 | let $l = arr12 | |
664 | 664 | let $s = size($l) | |
665 | 665 | let $acc0 = $Tuple7(0, 0, 0, 0, 0, 0, 0) | |
673 | 673 | ||
674 | 674 | $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($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12) | |
675 | 675 | } | |
676 | - | let totalWalletSupplyInUsd = $ | |
677 | - | let totalWalletBorrowInUsd = $ | |
678 | - | let totalWalletBorrowLimitInUsd = $ | |
679 | - | let totalWalletBorrowUsageInUsd = $ | |
680 | - | let totalWalletDailyIncomeInUsd = $ | |
681 | - | let totalWalletDailyLoanInterestInUsd = $ | |
682 | - | let totalWalletMarginInUsd = $ | |
676 | + | let totalWalletSupplyInUsd = $t03217832533._1 | |
677 | + | let totalWalletBorrowInUsd = $t03217832533._2 | |
678 | + | let totalWalletBorrowLimitInUsd = $t03217832533._3 | |
679 | + | let totalWalletBorrowUsageInUsd = $t03217832533._4 | |
680 | + | let totalWalletDailyIncomeInUsd = $t03217832533._5 | |
681 | + | let totalWalletDailyLoanInterestInUsd = $t03217832533._6 | |
682 | + | let totalWalletMarginInUsd = $t03217832533._7 | |
683 | 683 | let totalWalletBadDebtInUsd = if ((totalWalletBorrowInUsd > totalWalletSupplyInUsd)) | |
684 | 684 | then (totalWalletBorrowInUsd - totalWalletSupplyInUsd) | |
685 | 685 | else 0 | |
719 | 719 | $Tuple2((accum._1 :+ supplyAssetsJson), (accum._2 :+ borrowAssetsJson)) | |
720 | 720 | } | |
721 | 721 | ||
722 | - | let $ | |
722 | + | let $t03693537021 = { | |
723 | 723 | let $l = arr12 | |
724 | 724 | let $s = size($l) | |
725 | 725 | let $acc0 = $Tuple2(nil, nil) | |
733 | 733 | ||
734 | 734 | $f1_2($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12) | |
735 | 735 | } | |
736 | - | let supplyAssetsJson = $ | |
737 | - | let borrowAssetsJson = $ | |
736 | + | let supplyAssetsJson = $t03693537021._1 | |
737 | + | let borrowAssetsJson = $t03693537021._2 | |
738 | 738 | if ((marketIndex == next)) | |
739 | 739 | then $Tuple15((accum._1 + totalWalletSupplyInUsd), (accum._2 + totalWalletBorrowInUsd), (accum._3 + totalWalletBadDebtInUsd), (accum._4 + totalWalletDailyIncomeInUsd), (accum._5 + totalWalletDailyLoanInterestInUsd), totalWalletSupplyInUsd, totalWalletBorrowInUsd, totalWalletBadDebtInUsd, totalWalletDailyIncomeInUsd, totalWalletDailyLoanInterestInUsd, accountHealth, netApy, (accum._13 :+ marketsJson), supplyAssetsJson, borrowAssetsJson) | |
740 | 740 | else $Tuple15((accum._1 + totalWalletSupplyInUsd), (accum._2 + totalWalletBorrowInUsd), (accum._3 + totalWalletBadDebtInUsd), (accum._4 + totalWalletDailyIncomeInUsd), (accum._5 + totalWalletDailyLoanInterestInUsd), accum._6, accum._7, accum._8, accum._9, accum._10, accum._11, accum._12, (accum._13 :+ marketsJson), accum._14, accum._15) | |
741 | 741 | } | |
742 | 742 | ||
743 | - | let $ | |
743 | + | let $t03847838962 = { | |
744 | 744 | let $l = arr12 | |
745 | 745 | let $s = size($l) | |
746 | 746 | let $acc0 = $Tuple15(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, nil, nil, nil) | |
754 | 754 | ||
755 | 755 | $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($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12) | |
756 | 756 | } | |
757 | - | let totalWalletSupplyInUsd = $ | |
758 | - | let totalWalletBorrowInUsd = $ | |
759 | - | let totalWalletBadDebtInUsd = $ | |
760 | - | let totalWalletDailyIncomeInUsd = $ | |
761 | - | let totalWalletDailyLoanInterestInUsd = $ | |
762 | - | let walletSupplyInUsd = $ | |
763 | - | let walletBorrowInUsd = $ | |
764 | - | let walletBadDebtInUsd = $ | |
765 | - | let walletDailyIncomeInUsd = $ | |
766 | - | let walletDailyLoanInterestInUsd = $ | |
767 | - | let walletAccountHealth = $ | |
768 | - | let walletNetApy = $ | |
769 | - | let marketsJson = $ | |
770 | - | let supplyAssetsJson = $ | |
771 | - | let borrowAssetsJson = $ | |
757 | + | let totalWalletSupplyInUsd = $t03847838962._1 | |
758 | + | let totalWalletBorrowInUsd = $t03847838962._2 | |
759 | + | let totalWalletBadDebtInUsd = $t03847838962._3 | |
760 | + | let totalWalletDailyIncomeInUsd = $t03847838962._4 | |
761 | + | let totalWalletDailyLoanInterestInUsd = $t03847838962._5 | |
762 | + | let walletSupplyInUsd = $t03847838962._6 | |
763 | + | let walletBorrowInUsd = $t03847838962._7 | |
764 | + | let walletBadDebtInUsd = $t03847838962._8 | |
765 | + | let walletDailyIncomeInUsd = $t03847838962._9 | |
766 | + | let walletDailyLoanInterestInUsd = $t03847838962._10 | |
767 | + | let walletAccountHealth = $t03847838962._11 | |
768 | + | let walletNetApy = $t03847838962._12 | |
769 | + | let marketsJson = $t03847838962._13 | |
770 | + | let supplyAssetsJson = $t03847838962._14 | |
771 | + | let borrowAssetsJson = $t03847838962._15 | |
772 | 772 | let json = ((((((((((((((((((((((((((((((((((((((("{" + "\"marketIndex\":") + toString(marketIndex)) + ",\"name\":\"") + marketName) + "\"") + ",\"totalSupplyInUsd\":") + assetToJson(usdtIdStr, totalWalletSupplyInUsd)) + ",\"totalBorrowInUsd\":") + assetToJson(usdtIdStr, totalWalletBorrowInUsd)) + ",\"totalBadDebtInUsd\":") + assetToJson(usdtIdStr, totalWalletBadDebtInUsd)) + ",\"totalDailyIncomeInUsd\":") + assetToJson(usdtIdStr, totalWalletDailyIncomeInUsd)) + ",\"totalDailyLoanInterestInUsd\":") + assetToJson(usdtIdStr, totalWalletDailyLoanInterestInUsd)) + ",\"supplyInUsd\":") + assetToJson(usdtIdStr, walletSupplyInUsd)) + ",\"borrowInUsd\":") + assetToJson(usdtIdStr, walletBorrowInUsd)) + ",\"badDebtInUsd\":") + assetToJson(usdtIdStr, walletBadDebtInUsd)) + ",\"dailyIncomeInUsd\":") + assetToJson(usdtIdStr, walletDailyIncomeInUsd)) + ",\"dailyLoanInterestInUsd\":") + assetToJson(usdtIdStr, walletDailyLoanInterestInUsd)) + ",\"accountHealth\":") + amountToDecimal(walletAccountHealth, 8)) + ",\"netApy\":") + amountToDecimal(walletNetApy, 8)) + ",\"supplyAssets\":[") + makeString_11C(supplyAssetsJson, ",")) + "]") + ",\"borrowAssets\":[") + makeString_11C(borrowAssetsJson, ",")) + "]") + ",\"markets\":[") + makeString_11C(marketsJson, ",")) + "]") + "}") | |
773 | 773 | if (debug) | |
774 | 774 | then throw(json) | |
782 | 782 | let marketName = getStringValue(("market_name_" + marketStr)) | |
783 | 783 | let active = valueOrElse(getBoolean(marketAddress, "setup_active"), true) | |
784 | 784 | let setupTokens = getSetupTokens(marketAddress) | |
785 | - | let setupCf = split(getStringValue(marketAddress, "setup_ltvs"), ",") | |
786 | - | let setupLt = split(getStringValue(marketAddress, "setup_lts"), ",") | |
787 | - | let setupPenalty = split(getStringValue(marketAddress, "setup_penalties"), ",") | |
785 | + | let setupCf = split_4C(getStringValue(marketAddress, "setup_ltvs"), ",") | |
786 | + | let setupLt = split_4C(getStringValue(marketAddress, "setup_lts"), ",") | |
787 | + | let setupPenalty = split_4C(getStringValue(marketAddress, "setup_penalties"), ",") | |
788 | 788 | let assetIndex = getAssetIndex(setupTokens, assetIdStr) | |
789 | 789 | let cf = parseIntValue(setupCf[assetIndex]) | |
790 | 790 | let lt = parseIntValue(setupLt[assetIndex]) | |
852 | 852 | $Tuple5((accum._1 + currentWalletSupplyInUsd), (accum._2 + currentWalletBorrowInUsd), (accum._3 + currentWalletBorrowLimitInUsd), (accum._4 + currentWalletBorrowUsageInUsd), (accum._5 + walletMarginInUsd)) | |
853 | 853 | } | |
854 | 854 | ||
855 | - | let $ | |
855 | + | let $t04597346154 = { | |
856 | 856 | let $l = arr12 | |
857 | 857 | let $s = size($l) | |
858 | 858 | let $acc0 = $Tuple5(0, 0, 0, 0, 0) | |
866 | 866 | ||
867 | 867 | $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($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12) | |
868 | 868 | } | |
869 | - | let totalWalletSupplyInUsd = $ | |
870 | - | let totalWalletBorrowInUsd = $ | |
871 | - | let totalWalletBorrowLimitInUsd = $ | |
872 | - | let totalWalletBorrowUsageInUsd = $ | |
873 | - | let totalWalletMarginInUsd = $ | |
869 | + | let totalWalletSupplyInUsd = $t04597346154._1 | |
870 | + | let totalWalletBorrowInUsd = $t04597346154._2 | |
871 | + | let totalWalletBorrowLimitInUsd = $t04597346154._3 | |
872 | + | let totalWalletBorrowUsageInUsd = $t04597346154._4 | |
873 | + | let totalWalletMarginInUsd = $t04597346154._5 | |
874 | 874 | let accountHealth = getAccountHealth(totalWalletBorrowLimitInUsd, totalWalletBorrowUsageInUsd) | |
875 | 875 | let netApy = getNetApy(totalWalletSupplyInUsd, totalWalletBorrowInUsd, totalWalletMarginInUsd) | |
876 | 876 | let json = ((((((((((((((((((((((((((((((((((((((((((((((((((((((((("{" + "\"marketIndex\":") + toString(marketIndex)) + ",\"marketName\":\"") + marketName) + "\"") + ",\"address\":\"") + marketStr) + "\"") + ",\"assetPrice\":") + assetToJson(usdtIdStr, price)) + ",\"supply\":") + assetToJson(assetIdStr, supply)) + ",\"supplyInUsd\":") + assetToJson(usdtIdStr, supplyInUsd)) + ",\"supplyApy\":") + amountToDecimal(supplyApy, 8)) + ",\"borrow\":") + assetToJson(assetIdStr, borrow)) + ",\"borrowInUsd\":") + assetToJson(usdtIdStr, borrowInUsd)) + ",\"borrowApy\":") + amountToDecimal(borrowApy, 8)) + ",\"reserves\":") + assetToJson(assetIdStr, reserves)) + ",\"reservesInUsd\":") + assetToJson(usdtIdStr, reservesInUsd)) + ",\"utilizationRatio\":") + amountToDecimal(ur, 8)) + ",\"collateralFactor\":") + amountToDecimal(cf, 8)) + ",\"liquidationThreshold\":") + amountToDecimal(lt, 8)) + ",\"liquidationPenalty\":") + amountToDecimal(penalty, 8)) + ",\"maxSupply\":") + assetToJson(usdtIdStr, maxSupply)) + ",\"walletSupply\":") + assetToJson(assetIdStr, walletSupply)) + ",\"walletSupplyInUsd\":") + assetToJson(usdtIdStr, walletSupplyInUsd)) + ",\"walletDailyIncome\":") + assetToJson(assetIdStr, walletDailyIncome)) + ",\"walletDailyIncomeInUsd\":") + assetToJson(usdtIdStr, walletDailyIncomeInUsd)) + ",\"walletBorrow\":") + assetToJson(assetIdStr, walletBorrow)) + ",\"walletBorrowInUsd\":") + assetToJson(usdtIdStr, walletBorrowInUsd)) + ",\"walletDailyLoanInterest\":") + assetToJson(assetIdStr, walletDailyLoanPercents)) + ",\"walletDailyLoanInterestInUsd\":") + assetToJson(usdtIdStr, walletDailyLoanPercentsInUsd)) + ",\"accountHealth\":") + amountToDecimal(accountHealth, 8)) + ",\"netApy\":") + amountToDecimal(netApy, 8)) + "}") | |
885 | 885 | let marketAddress = addressFromStringValue(marketStr) | |
886 | 886 | let marketName = getStringValue(("market_name_" + marketStr)) | |
887 | 887 | let setupTokens = getSetupTokens(marketAddress) | |
888 | - | let setupCf = split(getStringValue(marketAddress, "setup_ltvs"), ",") | |
889 | - | let setupLt = split(getStringValue(marketAddress, "setup_lts"), ",") | |
890 | - | let setupPenalty = split(getStringValue(marketAddress, "setup_penalties"), ",") | |
888 | + | let setupCf = split_4C(getStringValue(marketAddress, "setup_ltvs"), ",") | |
889 | + | let setupLt = split_4C(getStringValue(marketAddress, "setup_lts"), ",") | |
890 | + | let setupPenalty = split_4C(getStringValue(marketAddress, "setup_penalties"), ",") | |
891 | 891 | let assetsCount = size(setupTokens) | |
892 | 892 | func assetsFold (accum,next) = if ((next >= assetsCount)) | |
893 | 893 | then accum |
Old | New | Differences | |
---|---|---|---|
1 | 1 | {-# STDLIB_VERSION 6 #-} | |
2 | 2 | {-# SCRIPT_TYPE ACCOUNT #-} | |
3 | 3 | {-# CONTENT_TYPE DAPP #-} | |
4 | 4 | let Waves = "WAVES" | |
5 | 5 | ||
6 | 6 | let Scale6 = 1000000 | |
7 | 7 | ||
8 | 8 | let Scale8 = 100000000 | |
9 | 9 | ||
10 | 10 | let Scale8Big = toBigInt(100000000) | |
11 | 11 | ||
12 | 12 | let Scale10 = 10000000000 | |
13 | 13 | ||
14 | 14 | let Scale16 = 10000000000000000 | |
15 | 15 | ||
16 | 16 | let Scale16Big = toBigInt(10000000000000000) | |
17 | 17 | ||
18 | 18 | let dayBlocks = 1440 | |
19 | 19 | ||
20 | 20 | let yearBlocks = 525600 | |
21 | 21 | ||
22 | 22 | let yearBlocksBig = toBigInt(525600) | |
23 | 23 | ||
24 | 24 | let reserveFund = 20 | |
25 | 25 | ||
26 | 26 | let arr12 = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11] | |
27 | 27 | ||
28 | 28 | let usdtIdStr = "9wc3LXNA4TEBsXyKtoLE9mrbDD7WMHXvXrCjZvabLAsi" | |
29 | 29 | ||
30 | 30 | let usdcIdStr = "HGgabTqUS8WtVFUJzfmrTDMgEccJuZLBPhFgQFxvnsoW" | |
31 | 31 | ||
32 | 32 | let romeIdStr = "AP4Cb5xLYGH6ZigHreCZHoXpQTWDkPsG2BHqfDUx6taJ" | |
33 | 33 | ||
34 | 34 | let oracleAddressStr = "3P8d1E1BLKoD52y3bQJ1bDTd2TD1gpaLn9t" | |
35 | 35 | ||
36 | 36 | let axlyAddress = Address(base58'3PLsYkBw7taejV1J3qWPCN2yeyVRu31d5HW') | |
37 | 37 | ||
38 | 38 | let axlyLPs = ["7KZbJrVopwJhkdwbe1eFDBbex4dkY63MxjTNjqXtrzj1", "Btw3G1j4wQgdp49PTxaFkNvn75dQtqGDM7ejQppHnWC1", "BiSzFe8nSL78oZaebfoin5vBZ5Pze6d7kaeijLqr5xZe", "F2AKkA513k5yHEJkLsU6vWxCYYk811GpjLhwEv2WGwZ9", "4CQ5CPGLXLbWBUs2JBjKUaRqF49CmKHkwzvPgSvQpAQV", "6iMB6LKSrgv9waEvEnN6Ydyx7dfxPnGcTw8318WVm5bR"] | |
39 | 39 | ||
40 | 40 | func getRateCurve (assetIdStr,marketStr) = { | |
41 | 41 | let marketAddress = addressFromStringValue(marketStr) | |
42 | 42 | let setupRateCurve = getString(marketAddress, ("setup_rateCurve_" + assetIdStr)) | |
43 | 43 | if (isDefined(setupRateCurve)) | |
44 | 44 | then { | |
45 | - | let curveArr = split(value(setupRateCurve), ",") | |
45 | + | let curveArr = split_4C(value(setupRateCurve), ",") | |
46 | 46 | $Tuple4(parseIntValue(curveArr[0]), parseIntValue(curveArr[1]), parseIntValue(curveArr[2]), parseIntValue(curveArr[3])) | |
47 | 47 | } | |
48 | 48 | else match marketStr { | |
49 | 49 | case _ => | |
50 | 50 | if (("3P4uA5etnZi4AmBabKinq2bMiWU8KcnHZdH" == $match0)) | |
51 | 51 | then match assetIdStr { | |
52 | 52 | case _ => | |
53 | 53 | if (("9wc3LXNA4TEBsXyKtoLE9mrbDD7WMHXvXrCjZvabLAsi" == $match1)) | |
54 | 54 | then $Tuple4(2000000, 25000000, 80000000, 100000000) | |
55 | 55 | else if (("HGgabTqUS8WtVFUJzfmrTDMgEccJuZLBPhFgQFxvnsoW" == $match1)) | |
56 | 56 | then $Tuple4(2000000, 25000000, 80000000, 100000000) | |
57 | 57 | else if (("34N9YcEETLWn93qYQ64EsP1x89tSruJU44RrEMSXXEPJ" == $match1)) | |
58 | 58 | then $Tuple4(2000000, 25000000, 80000000, 100000000) | |
59 | 59 | else if (("6XtHjpXbs9RRJP2Sr9GUyVqzACcby9TkThHXnjVC5CDJ" == $match1)) | |
60 | 60 | then $Tuple4(2000000, 25000000, 80000000, 100000000) | |
61 | 61 | else if (("DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p" == $match1)) | |
62 | 62 | then $Tuple4(2000000, 25000000, 80000000, 100000000) | |
63 | 63 | else if (("Ajso6nTTjptu2UHLx6hfSXVtHFtRBJCkKYd5SAyj7zf5" == $match1)) | |
64 | 64 | then $Tuple4(2000000, 40000000, 80000000, 150000000) | |
65 | 65 | else if (("HEB8Qaw9xrWpWs8tHsiATYGBWDBtP2S7kcPALrMu43AS" == $match1)) | |
66 | 66 | then $Tuple4(0, 100000000, 80000000, 400000000) | |
67 | 67 | else if (("WAVES" == $match1)) | |
68 | 68 | then $Tuple4(2000000, 30000000, 80000000, 90000000) | |
69 | 69 | else if (("Atqv59EYzjFGuitKVnMRk6H8FukjoV3ktPorbEys25on" == $match1)) | |
70 | 70 | then $Tuple4(0, 20000000, 80000000, 40000000) | |
71 | 71 | else if (("DSbbhLsSTeDg5Lsiufk2Aneh3DjVqJuPr2M9uU1gwy5p" == $match1)) | |
72 | 72 | then $Tuple4(0, 20000000, 80000000, 100000000) | |
73 | 73 | else if (("8t4DPWTwPzpatHA9AkTxWAB47THnYzBsDnoY7fQqbG91" == $match1)) | |
74 | 74 | then $Tuple4(0, 30000000, 80000000, 40000000) | |
75 | 75 | else if (("At8D6NFFpheCbvKVnjVoeLL84Eo8NZn6ovManxfLaFWL" == $match1)) | |
76 | 76 | then $Tuple4(0, 25000000, 80000000, 40000000) | |
77 | 77 | else if (("8LQW8f7P5d5PZM7GtZEBgaqRPGSzS3DfPuiXrURJ4AJS" == $match1)) | |
78 | 78 | then $Tuple4(2000000, 30000000, 80000000, 50000000) | |
79 | 79 | else if (("474jTeYx2r2Va35794tCScAXWJG9hU2HcgxzMowaZUnu" == $match1)) | |
80 | 80 | then $Tuple4(2000000, 30000000, 80000000, 50000000) | |
81 | 81 | else if (("5UYBPpq4WoU5n4MwpFkgJnW3Fq4B1u3ukpK33ik4QerR" == $match1)) | |
82 | 82 | then $Tuple4(2000000, 30000000, 80000000, 50000000) | |
83 | 83 | else if (("2thsACuHmzDMuNezPM32wg9a3BwUzBWDeSKakgz3cw21" == $match1)) | |
84 | 84 | then $Tuple4(2000000, 40000000, 80000000, 100000000) | |
85 | 85 | else if (("YiNbofFzC17jEHHCMwrRcpy9MrrjabMMLZxg8g5xmf7" == $match1)) | |
86 | 86 | then $Tuple4(2000000, 30000000, 80000000, 80000000) | |
87 | 87 | else if (("9wc3LXNA4TEBsXyKtoLE9mrbDD7WMHXvXrCjZvabLAsi" == $match1)) | |
88 | 88 | then $Tuple4(0, 50000000, 80000000, 200000000) | |
89 | 89 | else if (("3VuV5WTmDz47Dmdn3QpcYjzbSdipjQE4JMdNe1xZpX13" == $match1)) | |
90 | 90 | then $Tuple4(0, 100000000, 80000000, 400000000) | |
91 | 91 | else $Tuple4(0, 20000000, 80000000, 80000000) | |
92 | 92 | } | |
93 | 93 | else if (("3P8Df2b7ywHtLBHBe8PBVQYd3A5MdEEJAou" == $match0)) | |
94 | 94 | then $Tuple4(20000000, 100000000, 60000000, 400000000) | |
95 | 95 | else if (("3P4DK5VzDwL3vfc5ahUEhtoe5ByZNyacJ3X" == $match0)) | |
96 | 96 | then match assetIdStr { | |
97 | 97 | case _ => | |
98 | 98 | if (("9wc3LXNA4TEBsXyKtoLE9mrbDD7WMHXvXrCjZvabLAsi" == $match1)) | |
99 | 99 | then $Tuple4(2000000, 25000000, 80000000, 100000000) | |
100 | 100 | else if (("HGgabTqUS8WtVFUJzfmrTDMgEccJuZLBPhFgQFxvnsoW" == $match1)) | |
101 | 101 | then $Tuple4(2000000, 25000000, 80000000, 100000000) | |
102 | 102 | else if (("34N9YcEETLWn93qYQ64EsP1x89tSruJU44RrEMSXXEPJ" == $match1)) | |
103 | 103 | then $Tuple4(2000000, 25000000, 80000000, 100000000) | |
104 | 104 | else if (("6XtHjpXbs9RRJP2Sr9GUyVqzACcby9TkThHXnjVC5CDJ" == $match1)) | |
105 | 105 | then $Tuple4(2000000, 25000000, 80000000, 100000000) | |
106 | 106 | else if (("DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p" == $match1)) | |
107 | 107 | then $Tuple4(2000000, 25000000, 80000000, 100000000) | |
108 | 108 | else if (("Ajso6nTTjptu2UHLx6hfSXVtHFtRBJCkKYd5SAyj7zf5" == $match1)) | |
109 | 109 | then $Tuple4(2000000, 40000000, 80000000, 150000000) | |
110 | 110 | else if (("HEB8Qaw9xrWpWs8tHsiATYGBWDBtP2S7kcPALrMu43AS" == $match1)) | |
111 | 111 | then $Tuple4(0, 50000000, 80000000, 400000000) | |
112 | 112 | else if (("WAVES" == $match1)) | |
113 | 113 | then $Tuple4(2000000, 30000000, 80000000, 80000000) | |
114 | 114 | else if (("Atqv59EYzjFGuitKVnMRk6H8FukjoV3ktPorbEys25on" == $match1)) | |
115 | 115 | then $Tuple4(0, 20000000, 80000000, 40000000) | |
116 | 116 | else if (("DSbbhLsSTeDg5Lsiufk2Aneh3DjVqJuPr2M9uU1gwy5p" == $match1)) | |
117 | 117 | then $Tuple4(0, 20000000, 80000000, 100000000) | |
118 | 118 | else if (("8t4DPWTwPzpatHA9AkTxWAB47THnYzBsDnoY7fQqbG91" == $match1)) | |
119 | 119 | then $Tuple4(0, 30000000, 80000000, 40000000) | |
120 | 120 | else if (("At8D6NFFpheCbvKVnjVoeLL84Eo8NZn6ovManxfLaFWL" == $match1)) | |
121 | 121 | then $Tuple4(0, 25000000, 80000000, 40000000) | |
122 | 122 | else if (("8LQW8f7P5d5PZM7GtZEBgaqRPGSzS3DfPuiXrURJ4AJS" == $match1)) | |
123 | 123 | then $Tuple4(2000000, 30000000, 80000000, 50000000) | |
124 | 124 | else if (("474jTeYx2r2Va35794tCScAXWJG9hU2HcgxzMowaZUnu" == $match1)) | |
125 | 125 | then $Tuple4(2000000, 30000000, 80000000, 50000000) | |
126 | 126 | else if (("5UYBPpq4WoU5n4MwpFkgJnW3Fq4B1u3ukpK33ik4QerR" == $match1)) | |
127 | 127 | then $Tuple4(2000000, 30000000, 80000000, 50000000) | |
128 | 128 | else if (("2thsACuHmzDMuNezPM32wg9a3BwUzBWDeSKakgz3cw21" == $match1)) | |
129 | 129 | then $Tuple4(2000000, 40000000, 80000000, 100000000) | |
130 | 130 | else if (("YiNbofFzC17jEHHCMwrRcpy9MrrjabMMLZxg8g5xmf7" == $match1)) | |
131 | 131 | then $Tuple4(2000000, 30000000, 80000000, 80000000) | |
132 | 132 | else if (("9wc3LXNA4TEBsXyKtoLE9mrbDD7WMHXvXrCjZvabLAsi" == $match1)) | |
133 | 133 | then $Tuple4(0, 50000000, 80000000, 200000000) | |
134 | 134 | else if (("3VuV5WTmDz47Dmdn3QpcYjzbSdipjQE4JMdNe1xZpX13" == $match1)) | |
135 | 135 | then $Tuple4(0, 100000000, 80000000, 400000000) | |
136 | 136 | else $Tuple4(0, 20000000, 80000000, 80000000) | |
137 | 137 | } | |
138 | 138 | else if (("3PHpuQUPVUoR3AYzFeJzeWJfYLsLTmWssVH" == $match0)) | |
139 | 139 | then $Tuple4(20000000, 100000000, 60000000, 400000000) | |
140 | 140 | else if (("3PAd9Aqg3cQSzu26MFYWQYcjSXPVCJtuf5V" == $match0)) | |
141 | 141 | then match assetIdStr { | |
142 | 142 | case _ => | |
143 | 143 | if (("9wc3LXNA4TEBsXyKtoLE9mrbDD7WMHXvXrCjZvabLAsi" == $match1)) | |
144 | 144 | then $Tuple4(2000000, 25000000, 80000000, 100000000) | |
145 | 145 | else if (("HGgabTqUS8WtVFUJzfmrTDMgEccJuZLBPhFgQFxvnsoW" == $match1)) | |
146 | 146 | then $Tuple4(2000000, 25000000, 80000000, 100000000) | |
147 | 147 | else if (("34N9YcEETLWn93qYQ64EsP1x89tSruJU44RrEMSXXEPJ" == $match1)) | |
148 | 148 | then $Tuple4(2000000, 25000000, 80000000, 100000000) | |
149 | 149 | else if (("6XtHjpXbs9RRJP2Sr9GUyVqzACcby9TkThHXnjVC5CDJ" == $match1)) | |
150 | 150 | then $Tuple4(2000000, 25000000, 80000000, 100000000) | |
151 | 151 | else if (("DG2xFkPdDwKUoBkzGAhQtLpSGzfXLiCYPEzeKH2Ad24p" == $match1)) | |
152 | 152 | then $Tuple4(2000000, 25000000, 80000000, 100000000) | |
153 | 153 | else if (("Ajso6nTTjptu2UHLx6hfSXVtHFtRBJCkKYd5SAyj7zf5" == $match1)) | |
154 | 154 | then $Tuple4(2000000, 40000000, 80000000, 150000000) | |
155 | 155 | else if (("HEB8Qaw9xrWpWs8tHsiATYGBWDBtP2S7kcPALrMu43AS" == $match1)) | |
156 | 156 | then $Tuple4(0, 20000000, 80000000, 40000000) | |
157 | 157 | else if (("WAVES" == $match1)) | |
158 | 158 | then $Tuple4(2000000, 30000000, 80000000, 50000000) | |
159 | 159 | else if (("Atqv59EYzjFGuitKVnMRk6H8FukjoV3ktPorbEys25on" == $match1)) | |
160 | 160 | then $Tuple4(0, 20000000, 80000000, 40000000) | |
161 | 161 | else if (("DSbbhLsSTeDg5Lsiufk2Aneh3DjVqJuPr2M9uU1gwy5p" == $match1)) | |
162 | 162 | then $Tuple4(0, 20000000, 80000000, 100000000) | |
163 | 163 | else if (("8t4DPWTwPzpatHA9AkTxWAB47THnYzBsDnoY7fQqbG91" == $match1)) | |
164 | 164 | then $Tuple4(0, 30000000, 80000000, 40000000) | |
165 | 165 | else if (("At8D6NFFpheCbvKVnjVoeLL84Eo8NZn6ovManxfLaFWL" == $match1)) | |
166 | 166 | then $Tuple4(0, 25000000, 80000000, 40000000) | |
167 | 167 | else if (("8LQW8f7P5d5PZM7GtZEBgaqRPGSzS3DfPuiXrURJ4AJS" == $match1)) | |
168 | 168 | then $Tuple4(2000000, 30000000, 80000000, 50000000) | |
169 | 169 | else if (("474jTeYx2r2Va35794tCScAXWJG9hU2HcgxzMowaZUnu" == $match1)) | |
170 | 170 | then $Tuple4(2000000, 30000000, 80000000, 50000000) | |
171 | 171 | else if (("5UYBPpq4WoU5n4MwpFkgJnW3Fq4B1u3ukpK33ik4QerR" == $match1)) | |
172 | 172 | then $Tuple4(2000000, 30000000, 80000000, 50000000) | |
173 | 173 | else if (("2thsACuHmzDMuNezPM32wg9a3BwUzBWDeSKakgz3cw21" == $match1)) | |
174 | 174 | then $Tuple4(2000000, 40000000, 80000000, 100000000) | |
175 | 175 | else if (("YiNbofFzC17jEHHCMwrRcpy9MrrjabMMLZxg8g5xmf7" == $match1)) | |
176 | 176 | then $Tuple4(2000000, 30000000, 80000000, 80000000) | |
177 | 177 | else $Tuple4(0, 20000000, 80000000, 80000000) | |
178 | 178 | } | |
179 | 179 | else throw("Unknown market") | |
180 | 180 | } | |
181 | 181 | } | |
182 | 182 | ||
183 | 183 | ||
184 | 184 | func sum (size,data) = { | |
185 | 185 | func fold (accum,next) = if ((next >= size)) | |
186 | 186 | then accum | |
187 | 187 | else (accum + data[next]) | |
188 | 188 | ||
189 | 189 | let $l = arr12 | |
190 | 190 | let $s = size($l) | |
191 | 191 | let $acc0 = 0 | |
192 | 192 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
193 | 193 | then $a | |
194 | 194 | else fold($a, $l[$i]) | |
195 | 195 | ||
196 | 196 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
197 | 197 | then $a | |
198 | 198 | else throw("List size exceeds 12") | |
199 | 199 | ||
200 | 200 | $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($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12) | |
201 | 201 | } | |
202 | 202 | ||
203 | 203 | ||
204 | - | func getSetupTokens (marketAddress) = split(getStringValue(marketAddress, "setup_tokens"), ",") | |
204 | + | func getSetupTokens (marketAddress) = split_4C(getStringValue(marketAddress, "setup_tokens"), ",") | |
205 | 205 | ||
206 | 206 | ||
207 | 207 | func getTokenPrice (marketAddress,assetIdStr) = { | |
208 | 208 | let oracleStr = valueOrElse(getString(marketAddress, "oracle"), oracleAddressStr) | |
209 | 209 | let oracleAddress = addressFromStringValue(oracleStr) | |
210 | - | let stables = split(valueOrElse(getString(marketAddress, "setup_stablesIds"), "9wc3LXNA4TEBsXyKtoLE9mrbDD7WMHXvXrCjZvabLAsi,HGgabTqUS8WtVFUJzfmrTDMgEccJuZLBPhFgQFxvnsoW"), ",") | |
210 | + | let stables = split_4C(valueOrElse(getString(marketAddress, "setup_stablesIds"), "9wc3LXNA4TEBsXyKtoLE9mrbDD7WMHXvXrCjZvabLAsi,HGgabTqUS8WtVFUJzfmrTDMgEccJuZLBPhFgQFxvnsoW"), ",") | |
211 | 211 | if ((indexOf(stables, assetIdStr) != unit)) | |
212 | 212 | then 1000000 | |
213 | 213 | else if (if (if ((assetIdStr == usdtIdStr)) | |
214 | 214 | then true | |
215 | 215 | else (assetIdStr == usdcIdStr)) | |
216 | 216 | then true | |
217 | 217 | else (assetIdStr == romeIdStr)) | |
218 | 218 | then 1000000 | |
219 | 219 | else if (containsElement(axlyLPs, assetIdStr)) | |
220 | 220 | then { | |
221 | 221 | let @ = invoke(axlyAddress, "getShareAssetPriceREADONLY", [assetIdStr], nil) | |
222 | 222 | if ($isInstanceOf(@, "Int")) | |
223 | 223 | then @ | |
224 | 224 | else throw(($getType(@) + " couldn't be cast to Int")) | |
225 | 225 | } | |
226 | 226 | else { | |
227 | 227 | let price = getIntegerValue(oracleAddress, (assetIdStr + "_twap5B")) | |
228 | 228 | price | |
229 | 229 | } | |
230 | 230 | } | |
231 | 231 | ||
232 | 232 | ||
233 | 233 | func getAssetScale (assetIdStr) = { | |
234 | 234 | let decimals = if ((assetIdStr == "WAVES")) | |
235 | 235 | then 8 | |
236 | 236 | else value(assetInfo(fromBase58String(assetIdStr))).decimals | |
237 | 237 | pow(10, 0, decimals, 0, 0, DOWN) | |
238 | 238 | } | |
239 | 239 | ||
240 | 240 | ||
241 | 241 | func getLastRateHeight (marketAddress) = valueOrElse(getInteger(marketAddress, "lastRateHeight"), 0) | |
242 | 242 | ||
243 | 243 | ||
244 | 244 | func getOutdatedTotalSupply (marketAddress,assetIdStr) = valueOrElse(getInteger(marketAddress, ("total_supplied_" + assetIdStr)), 0) | |
245 | 245 | ||
246 | 246 | ||
247 | 247 | func getOutdatedTotalBorrow (marketAddress,assetIdStr) = valueOrElse(getInteger(marketAddress, ("total_borrowed_" + assetIdStr)), 0) | |
248 | 248 | ||
249 | 249 | ||
250 | 250 | func getOutdatedSRate (marketAddress,assetIdStr) = valueOrElse(getInteger(marketAddress, (assetIdStr + "_sRate")), 0) | |
251 | 251 | ||
252 | 252 | ||
253 | 253 | func getOutdatedBRate (marketAddress,assetIdStr) = valueOrElse(getInteger(marketAddress, (assetIdStr + "_bRate")), 0) | |
254 | 254 | ||
255 | 255 | ||
256 | 256 | func getOutdatedUr (outdatedTotalSupply,outdatedTotalBorrow,outdatedSRate,outdatedBRate) = { | |
257 | 257 | let down = fraction(outdatedTotalSupply, outdatedSRate, Scale16) | |
258 | 258 | if ((down == 0)) | |
259 | 259 | then 0 | |
260 | 260 | else fraction(Scale8, fraction(outdatedTotalBorrow, outdatedBRate, Scale16), down) | |
261 | 261 | } | |
262 | 262 | ||
263 | 263 | ||
264 | 264 | func getRate (outdatedUr,assetIdStr,marketStr) = { | |
265 | 265 | let curve = getRateCurve(assetIdStr, marketStr) | |
266 | 266 | (curve._1 + (if ((curve._3 >= outdatedUr)) | |
267 | 267 | then fraction(outdatedUr, curve._2, curve._3) | |
268 | 268 | else (curve._2 + fraction((outdatedUr - curve._3), curve._4, (100000000 - curve._3))))) | |
269 | 269 | } | |
270 | 270 | ||
271 | 271 | ||
272 | 272 | func getInterest (rate) = max([fraction(rate, Scale8, yearBlocks), 1]) | |
273 | 273 | ||
274 | 274 | ||
275 | 275 | func getAssetIndex (setupTokens,assetIdStr) = value(indexOf(setupTokens, assetIdStr)) | |
276 | 276 | ||
277 | 277 | ||
278 | 278 | func getAssetParamters (marketParameters,assetIndex) = $Tuple3(marketParameters._1[assetIndex], marketParameters._2[assetIndex], marketParameters._3[assetIndex]) | |
279 | 279 | ||
280 | 280 | ||
281 | 281 | func getMarketParameters (marketAddress,setupTokens) = { | |
282 | - | let setupCf = split(getStringValue(marketAddress, "setup_ltvs"), ",") | |
283 | - | let setupLt = split(getStringValue(marketAddress, "setup_lts"), ",") | |
284 | - | let setupPenalty = split(getStringValue(marketAddress, "setup_penalties"), ",") | |
282 | + | let setupCf = split_4C(getStringValue(marketAddress, "setup_ltvs"), ",") | |
283 | + | let setupLt = split_4C(getStringValue(marketAddress, "setup_lts"), ",") | |
284 | + | let setupPenalty = split_4C(getStringValue(marketAddress, "setup_penalties"), ",") | |
285 | 285 | let tokensSize = size(setupTokens) | |
286 | 286 | func fold (accum,next) = if ((next >= tokensSize)) | |
287 | 287 | then accum | |
288 | 288 | else $Tuple3((accum._1 :+ parseIntValue(setupCf[next])), (accum._2 :+ parseIntValue(setupLt[next])), (accum._3 :+ parseIntValue(setupPenalty[next]))) | |
289 | 289 | ||
290 | 290 | let $l = arr12 | |
291 | 291 | let $s = size($l) | |
292 | 292 | let $acc0 = $Tuple3(nil, nil, nil) | |
293 | 293 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
294 | 294 | then $a | |
295 | 295 | else fold($a, $l[$i]) | |
296 | 296 | ||
297 | 297 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
298 | 298 | then $a | |
299 | 299 | else throw("List size exceeds 12") | |
300 | 300 | ||
301 | 301 | $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($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12) | |
302 | 302 | } | |
303 | 303 | ||
304 | 304 | ||
305 | 305 | func getMaxSupply (marketAddress,assetIdStr) = parseIntValue(valueOrElse(getString(marketAddress, ("setup_maxSupply_" + assetIdStr)), "0")) | |
306 | 306 | ||
307 | 307 | ||
308 | 308 | func getActualSRate (lastRateHeight,interest,outdatedUr,outdatedSRate) = { | |
309 | 309 | let lastSRate = max([outdatedSRate, Scale16]) | |
310 | 310 | let newSRate = (lastSRate + ((((height - lastRateHeight) * fraction(interest, outdatedUr, Scale8)) * (100 - reserveFund)) / 100)) | |
311 | 311 | newSRate | |
312 | 312 | } | |
313 | 313 | ||
314 | 314 | ||
315 | 315 | func getActualBRate (lastRateHeight,interest,outdatedBRate) = { | |
316 | 316 | let lastBRate = max([outdatedBRate, Scale16]) | |
317 | 317 | let newBRate = (lastBRate + ((height - lastRateHeight) * interest)) | |
318 | 318 | newBRate | |
319 | 319 | } | |
320 | 320 | ||
321 | 321 | ||
322 | 322 | func getActualUr (actualSupply,actualBorrow) = if ((actualSupply == 0)) | |
323 | 323 | then 0 | |
324 | 324 | else fraction(actualBorrow, Scale8, actualSupply) | |
325 | 325 | ||
326 | 326 | ||
327 | 327 | func getActualAmount (outdatedAmount,actualRate) = fraction(outdatedAmount, actualRate, Scale16) | |
328 | 328 | ||
329 | 329 | ||
330 | 330 | func getInUsd (actualAmount,assetScale,price) = fraction(actualAmount, price, assetScale) | |
331 | 331 | ||
332 | 332 | ||
333 | 333 | func getSupplyApy (rate,actualUr) = { | |
334 | 334 | let supplyRate = fraction(fraction(rate, 80, 100), actualUr, Scale8) | |
335 | 335 | (toInt(pow((Scale16Big + fraction(toBigInt(supplyRate), Scale8Big, yearBlocksBig)), 16, yearBlocksBig, 0, 8, DOWN)) - Scale8) | |
336 | 336 | } | |
337 | 337 | ||
338 | 338 | ||
339 | 339 | func getBorrowApy (rate) = (toInt(pow((Scale16Big + fraction(toBigInt(rate), Scale8Big, yearBlocksBig)), 16, yearBlocksBig, 0, 8, DOWN)) - Scale8) | |
340 | 340 | ||
341 | 341 | ||
342 | 342 | func getWalletSupply (marketAddress,assetIdStr,wallet,actualSRate) = { | |
343 | 343 | let outdatedWalletSupply = valueOrElse(getInteger(marketAddress, ((wallet + "_supplied_") + assetIdStr)), 0) | |
344 | 344 | getActualAmount(outdatedWalletSupply, actualSRate) | |
345 | 345 | } | |
346 | 346 | ||
347 | 347 | ||
348 | 348 | func getWalletBorrow (marketAddress,assetIdStr,wallet,actualBRate) = { | |
349 | 349 | let outdatedWalletBorrow = valueOrElse(getInteger(marketAddress, ((wallet + "_borrowed_") + assetIdStr)), 0) | |
350 | 350 | getActualAmount(outdatedWalletBorrow, actualBRate) | |
351 | 351 | } | |
352 | 352 | ||
353 | 353 | ||
354 | 354 | func getDailyPercents (apy,quantity) = fraction(fraction((toInt(pow((Scale8Big + toBigInt(apy)), 8, (Scale16Big / yearBlocksBig), 16, 16, DOWN)) - Scale16), dayBlocks, Scale8), quantity, Scale8) | |
355 | 355 | ||
356 | 356 | ||
357 | 357 | func getAccountHealth (totalWalletBorrowLimitInUsd,totalWalletBorrowUsageInUsd) = if ((totalWalletBorrowLimitInUsd == 0)) | |
358 | 358 | then Scale8 | |
359 | 359 | else (Scale8 - fraction(totalWalletBorrowUsageInUsd, Scale8, totalWalletBorrowLimitInUsd)) | |
360 | 360 | ||
361 | 361 | ||
362 | 362 | func getNetApy (totalWalletSupplyInUsd,totalWalletBorrowInUsd,totalWalletMarginInUsd) = if ((totalWalletMarginInUsd == 0)) | |
363 | 363 | then 0 | |
364 | 364 | else if ((totalWalletMarginInUsd > 0)) | |
365 | 365 | then fraction(totalWalletMarginInUsd, Scale8, totalWalletSupplyInUsd) | |
366 | 366 | else fraction(totalWalletMarginInUsd, Scale8, totalWalletBorrowInUsd) | |
367 | 367 | ||
368 | 368 | ||
369 | 369 | func assetToJson (assetIdStr,quantity) = { | |
370 | - | let $ | |
370 | + | let $t01534315538 = if ((assetIdStr == Waves)) | |
371 | 371 | then $Tuple2(8, "WAVES") | |
372 | 372 | else { | |
373 | 373 | let asset = value(assetInfo(fromBase58String(assetIdStr))) | |
374 | 374 | $Tuple2(asset.decimals, asset.name) | |
375 | 375 | } | |
376 | - | let decimals = $ | |
377 | - | let name = $ | |
376 | + | let decimals = $t01534315538._1 | |
377 | + | let name = $t01534315538._2 | |
378 | 378 | (((((((("{\"quantity\":" + toString(quantity)) + ",\"decimals\":") + toString(decimals)) + ",\"name\":\"") + name) + "\",\"id\":\"") + assetIdStr) + "\"}") | |
379 | 379 | } | |
380 | 380 | ||
381 | 381 | ||
382 | 382 | func amountToDecimal (amount,decimals) = (((("{\"quantity\":" + toString(amount)) + ",\"decimals\":") + toString(decimals)) + ",\"name\":\"\",\"id\":\"\"}") | |
383 | 383 | ||
384 | 384 | ||
385 | 385 | func getMarketJson (marketIndex,wallet,debug) = { | |
386 | 386 | let marketStr = getStringValue(("market_" + toString(marketIndex))) | |
387 | 387 | let marketAddress = addressFromStringValue(marketStr) | |
388 | 388 | let marketName = getStringValue(("market_name_" + marketStr)) | |
389 | 389 | let active = valueOrElse(getBoolean(marketAddress, "setup_active"), true) | |
390 | 390 | let setupTokens = getSetupTokens(marketAddress) | |
391 | 391 | let assetsCount = size(setupTokens) | |
392 | 392 | let lastRateHeight = getLastRateHeight(marketAddress) | |
393 | 393 | func assetsFold (accum,next) = if ((next >= assetsCount)) | |
394 | 394 | then accum | |
395 | 395 | else { | |
396 | 396 | let assetIdStr = setupTokens[next] | |
397 | 397 | let price = getTokenPrice(marketAddress, assetIdStr) | |
398 | 398 | let assetScale = getAssetScale(assetIdStr) | |
399 | 399 | let outdatedTotalSupply = getOutdatedTotalSupply(marketAddress, assetIdStr) | |
400 | 400 | let outdatedTotalBorrow = getOutdatedTotalBorrow(marketAddress, assetIdStr) | |
401 | 401 | let outdatedSRate = getOutdatedSRate(marketAddress, assetIdStr) | |
402 | 402 | let outdatedBRate = getOutdatedBRate(marketAddress, assetIdStr) | |
403 | 403 | let outdatedUr = getOutdatedUr(outdatedTotalSupply, outdatedTotalBorrow, outdatedSRate, outdatedBRate) | |
404 | 404 | let rate = getRate(outdatedUr, assetIdStr, marketStr) | |
405 | 405 | let interest = getInterest(rate) | |
406 | 406 | let sRate = getActualSRate(lastRateHeight, interest, outdatedUr, outdatedSRate) | |
407 | 407 | let bRate = getActualBRate(lastRateHeight, interest, outdatedBRate) | |
408 | 408 | let supply = getActualAmount(outdatedTotalSupply, sRate) | |
409 | 409 | let borrow = getActualAmount(outdatedTotalBorrow, bRate) | |
410 | 410 | let supplyInUsd = getInUsd(supply, assetScale, price) | |
411 | 411 | let borrowInUsd = getInUsd(borrow, assetScale, price) | |
412 | 412 | let reserves = (supply - borrow) | |
413 | 413 | let reservesInUsd = getInUsd(reserves, assetScale, price) | |
414 | 414 | let ur = getActualUr(supply, borrow) | |
415 | 415 | let supplyApy = getSupplyApy(rate, ur) | |
416 | 416 | let borrowApy = getBorrowApy(rate) | |
417 | 417 | let marketAssetJson = ((((((((((((((((((((((((("{" + "\"supply\":") + assetToJson(assetIdStr, supply)) + ",\"supplyInUsd\":") + assetToJson(usdtIdStr, supplyInUsd)) + ",\"borrow\":") + assetToJson(assetIdStr, borrow)) + ",\"borrowInUsd\":") + assetToJson(usdtIdStr, borrowInUsd)) + ",\"reserves\":") + assetToJson(assetIdStr, reserves)) + ",\"reservesInUsd\":") + assetToJson(usdtIdStr, reservesInUsd)) + ",\"price\":") + assetToJson(usdtIdStr, price)) + ",\"supplyApy\":") + amountToDecimal(supplyApy, 8)) + ",\"borrowApy\":") + amountToDecimal(borrowApy, 8)) + ",\"utilizationRatio\":") + amountToDecimal(ur, 8)) + ",\"sRate\":") + amountToDecimal(sRate, 16)) + ",\"bRate\":") + amountToDecimal(bRate, 16)) + "}") | |
418 | 418 | $Tuple4((accum._1 + supplyInUsd), (accum._2 + borrowInUsd), (accum._3 + reservesInUsd), (accum._4 :+ marketAssetJson)) | |
419 | 419 | } | |
420 | 420 | ||
421 | - | let $ | |
421 | + | let $t01895119059 = { | |
422 | 422 | let $l = arr12 | |
423 | 423 | let $s = size($l) | |
424 | 424 | let $acc0 = $Tuple4(0, 0, 0, nil) | |
425 | 425 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
426 | 426 | then $a | |
427 | 427 | else assetsFold($a, $l[$i]) | |
428 | 428 | ||
429 | 429 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
430 | 430 | then $a | |
431 | 431 | else throw("List size exceeds 12") | |
432 | 432 | ||
433 | 433 | $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($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12) | |
434 | 434 | } | |
435 | - | let supplyInUsd = $ | |
436 | - | let borrowInUsd = $ | |
437 | - | let reservesInUsd = $ | |
438 | - | let marketAssetsJson = $ | |
435 | + | let supplyInUsd = $t01895119059._1 | |
436 | + | let borrowInUsd = $t01895119059._2 | |
437 | + | let reservesInUsd = $t01895119059._3 | |
438 | + | let marketAssetsJson = $t01895119059._4 | |
439 | 439 | let marketsCount = getIntegerValue("markets") | |
440 | 440 | func marketsFold (accum,next) = if ((next >= marketsCount)) | |
441 | 441 | then accum | |
442 | 442 | else { | |
443 | 443 | let currentMarketAddressStr = getStringValue(("market_" + toString(next))) | |
444 | 444 | let currentMarketName = getStringValue(("market_name_" + currentMarketAddressStr)) | |
445 | 445 | let simpleJson = (((((((((("{" + "\"index\":") + toString(next)) + ",\"name\":\"") + currentMarketName) + "\"") + ",\"supplyInUsd\":") + assetToJson(usdtIdStr, 0)) + ",\"accountHealth\":") + amountToDecimal(0, 8)) + "}") | |
446 | 446 | if ((wallet == "")) | |
447 | 447 | then (accum :+ simpleJson) | |
448 | 448 | else { | |
449 | 449 | let currentMarketAddress = addressFromStringValue(currentMarketAddressStr) | |
450 | 450 | let currentSetupTokens = getSetupTokens(currentMarketAddress) | |
451 | 451 | let currentAssetsCount = size(currentSetupTokens) | |
452 | 452 | let currentMarketShortName = getStringValue(("market_shortname_" + currentMarketAddressStr)) | |
453 | - | let setupCf = split(getStringValue(currentMarketAddress, "setup_ltvs"), ",") | |
454 | - | let setupLt = split(getStringValue(currentMarketAddress, "setup_lts"), ",") | |
453 | + | let setupCf = split_4C(getStringValue(currentMarketAddress, "setup_ltvs"), ",") | |
454 | + | let setupLt = split_4C(getStringValue(currentMarketAddress, "setup_lts"), ",") | |
455 | 455 | let currentLastRateHeight = getLastRateHeight(currentMarketAddress) | |
456 | 456 | func marketAssetsFold (accum,next) = if ((next >= currentAssetsCount)) | |
457 | 457 | then accum | |
458 | 458 | else { | |
459 | 459 | let assetIdStr = currentSetupTokens[next] | |
460 | 460 | let cf = parseIntValue(setupCf[next]) | |
461 | 461 | let lt = parseIntValue(setupLt[next]) | |
462 | 462 | let price = getTokenPrice(marketAddress, assetIdStr) | |
463 | 463 | let assetScale = getAssetScale(assetIdStr) | |
464 | 464 | let outdatedTotalSupply = getOutdatedTotalSupply(currentMarketAddress, assetIdStr) | |
465 | 465 | let outdatedTotalBorrow = getOutdatedTotalBorrow(currentMarketAddress, assetIdStr) | |
466 | 466 | let outdatedSRate = getOutdatedSRate(currentMarketAddress, assetIdStr) | |
467 | 467 | let outdatedBRate = getOutdatedBRate(currentMarketAddress, assetIdStr) | |
468 | 468 | let outdatedUr = getOutdatedUr(outdatedTotalSupply, outdatedTotalBorrow, outdatedSRate, outdatedBRate) | |
469 | 469 | let rate = getRate(outdatedUr, assetIdStr, marketStr) | |
470 | 470 | let interest = getInterest(rate) | |
471 | 471 | let sRate = getActualSRate(currentLastRateHeight, interest, outdatedUr, outdatedSRate) | |
472 | 472 | let bRate = getActualBRate(currentLastRateHeight, interest, outdatedBRate) | |
473 | 473 | let walletSupply = getWalletSupply(currentMarketAddress, assetIdStr, wallet, sRate) | |
474 | 474 | let walletSupplyInUsd = getInUsd(walletSupply, assetScale, price) | |
475 | 475 | let walletBorrow = getWalletBorrow(currentMarketAddress, assetIdStr, wallet, bRate) | |
476 | 476 | let walletBorrowInUsd = getInUsd(walletBorrow, assetScale, price) | |
477 | 477 | let walletBorrowLimitInUsd = fraction(walletSupplyInUsd, cf, Scale8) | |
478 | 478 | let walletBorrowUsageInUsd = fraction(walletBorrowInUsd, Scale8, lt) | |
479 | 479 | $Tuple4((accum._1 + walletSupplyInUsd), (accum._2 + walletBorrowInUsd), (accum._3 + walletBorrowLimitInUsd), (accum._4 + walletBorrowUsageInUsd)) | |
480 | 480 | } | |
481 | 481 | ||
482 | - | let $ | |
482 | + | let $t02263622796 = { | |
483 | 483 | let $l = arr12 | |
484 | 484 | let $s = size($l) | |
485 | 485 | let $acc0 = $Tuple4(0, 0, 0, 0) | |
486 | 486 | func $f1_1 ($a,$i) = if (($i >= $s)) | |
487 | 487 | then $a | |
488 | 488 | else marketAssetsFold($a, $l[$i]) | |
489 | 489 | ||
490 | 490 | func $f1_2 ($a,$i) = if (($i >= $s)) | |
491 | 491 | then $a | |
492 | 492 | else throw("List size exceeds 12") | |
493 | 493 | ||
494 | 494 | $f1_2($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12) | |
495 | 495 | } | |
496 | - | let totalWalletSupplyInUsd = $ | |
497 | - | let totalWalletBorrowInUsd = $ | |
498 | - | let totalWalletBorrowLimitInUsd = $ | |
499 | - | let totalWalletBorrowUsageInUsd = $ | |
496 | + | let totalWalletSupplyInUsd = $t02263622796._1 | |
497 | + | let totalWalletBorrowInUsd = $t02263622796._2 | |
498 | + | let totalWalletBorrowLimitInUsd = $t02263622796._3 | |
499 | + | let totalWalletBorrowUsageInUsd = $t02263622796._4 | |
500 | 500 | let accountHealth = getAccountHealth(totalWalletBorrowLimitInUsd, totalWalletBorrowUsageInUsd) | |
501 | 501 | let fullJson = (((((((((((("{" + "\"index\":") + toString(next)) + ",\"name\":\"") + currentMarketShortName) + "\"") + ",\"supplyInUsd\":") + assetToJson(usdtIdStr, totalWalletSupplyInUsd)) + ",\"borrowInUsd\":") + assetToJson(usdtIdStr, totalWalletBorrowInUsd)) + ",\"accountHealth\":") + amountToDecimal(accountHealth, 8)) + "}") | |
502 | 502 | (accum :+ fullJson) | |
503 | 503 | } | |
504 | 504 | } | |
505 | 505 | ||
506 | 506 | let marketsJson = { | |
507 | 507 | let $l = arr12 | |
508 | 508 | let $s = size($l) | |
509 | 509 | let $acc0 = nil | |
510 | 510 | func $f1_1 ($a,$i) = if (($i >= $s)) | |
511 | 511 | then $a | |
512 | 512 | else marketsFold($a, $l[$i]) | |
513 | 513 | ||
514 | 514 | func $f1_2 ($a,$i) = if (($i >= $s)) | |
515 | 515 | then $a | |
516 | 516 | else throw("List size exceeds 12") | |
517 | 517 | ||
518 | 518 | $f1_2($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12) | |
519 | 519 | } | |
520 | 520 | let json = ((((((((((((((((((((((("{" + "\"index\":") + toString(marketIndex)) + ",\"name\":\"") + marketName) + "\"") + ",\"address\":\"") + marketStr) + "\"") + ",\"active\":") + toString(active)) + ",\"supplyInUsd\":") + assetToJson(usdtIdStr, supplyInUsd)) + ",\"borrowInUsd\":") + assetToJson(usdtIdStr, borrowInUsd)) + ",\"reservesInUsd\":") + assetToJson(usdtIdStr, reservesInUsd)) + ",\"assets\":[") + makeString_11C(marketAssetsJson, ",")) + "]") + ",\"markets\":[") + makeString_11C(marketsJson, ",")) + "]") + "}") | |
521 | 521 | if (debug) | |
522 | 522 | then throw(json) | |
523 | 523 | else json | |
524 | 524 | } | |
525 | 525 | ||
526 | 526 | ||
527 | 527 | func getMenuJson (debug) = { | |
528 | 528 | let marketsCount = getIntegerValue("markets") | |
529 | 529 | func marketsFold (accum,next) = if ((next >= marketsCount)) | |
530 | 530 | then accum | |
531 | 531 | else { | |
532 | 532 | let marketStr = getStringValue(("market_" + toString(next))) | |
533 | 533 | let marketAddress = addressFromStringValue(marketStr) | |
534 | 534 | let setupTokens = getSetupTokens(marketAddress) | |
535 | 535 | let assetsCount = size(setupTokens) | |
536 | 536 | let lastRateHeight = getLastRateHeight(marketAddress) | |
537 | 537 | func assetsFold (accum,next) = if ((next >= assetsCount)) | |
538 | 538 | then accum | |
539 | 539 | else { | |
540 | 540 | let assetIdStr = setupTokens[next] | |
541 | 541 | let price = getTokenPrice(marketAddress, assetIdStr) | |
542 | 542 | let assetScale = getAssetScale(assetIdStr) | |
543 | 543 | let outdatedTotalSupply = getOutdatedTotalSupply(marketAddress, assetIdStr) | |
544 | 544 | let outdatedTotalBorrow = getOutdatedTotalBorrow(marketAddress, assetIdStr) | |
545 | 545 | let outdatedSRate = getOutdatedSRate(marketAddress, assetIdStr) | |
546 | 546 | let outdatedBRate = getOutdatedBRate(marketAddress, assetIdStr) | |
547 | 547 | let outdatedUr = getOutdatedUr(outdatedTotalSupply, outdatedTotalBorrow, outdatedSRate, outdatedBRate) | |
548 | 548 | let rate = getRate(outdatedUr, assetIdStr, marketStr) | |
549 | 549 | let interest = getInterest(rate) | |
550 | 550 | let sRate = getActualSRate(lastRateHeight, interest, outdatedUr, outdatedSRate) | |
551 | 551 | let bRate = getActualBRate(lastRateHeight, interest, outdatedBRate) | |
552 | 552 | let supply = getActualAmount(outdatedTotalSupply, sRate) | |
553 | 553 | let borrow = getActualAmount(outdatedTotalBorrow, bRate) | |
554 | 554 | let supplyInUsd = getInUsd(supply, assetScale, price) | |
555 | 555 | let borrowInUsd = getInUsd(borrow, assetScale, price) | |
556 | 556 | let reserves = (supply - borrow) | |
557 | 557 | let reservesInUsd = getInUsd(reserves, assetScale, price) | |
558 | 558 | let marketAssetJson = ((((((((("{" + "\"asset\":") + assetToJson(assetIdStr, 0)) + ",\"price\":") + assetToJson(usdtIdStr, price)) + ",\"sRate\":") + amountToDecimal(sRate, 16)) + ",\"bRate\":") + amountToDecimal(bRate, 16)) + "}") | |
559 | 559 | $Tuple4((accum._1 + supplyInUsd), (accum._2 + borrowInUsd), (accum._3 + reservesInUsd), (accum._4 :+ marketAssetJson)) | |
560 | 560 | } | |
561 | 561 | ||
562 | - | let $ | |
562 | + | let $t02673026838 = { | |
563 | 563 | let $l = arr12 | |
564 | 564 | let $s = size($l) | |
565 | 565 | let $acc0 = $Tuple4(0, 0, 0, nil) | |
566 | 566 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
567 | 567 | then $a | |
568 | 568 | else assetsFold($a, $l[$i]) | |
569 | 569 | ||
570 | 570 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
571 | 571 | then $a | |
572 | 572 | else throw("List size exceeds 12") | |
573 | 573 | ||
574 | 574 | $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($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12) | |
575 | 575 | } | |
576 | - | let supplyInUsd = $ | |
577 | - | let borrowInUsd = $ | |
578 | - | let reservesInUsd = $ | |
579 | - | let marketAssetsJson = $ | |
576 | + | let supplyInUsd = $t02673026838._1 | |
577 | + | let borrowInUsd = $t02673026838._2 | |
578 | + | let reservesInUsd = $t02673026838._3 | |
579 | + | let marketAssetsJson = $t02673026838._4 | |
580 | 580 | let marketJson = ((((((("{" + "\"address\":\"") + marketStr) + "\"") + ",\"assets\":[") + makeString_11C(marketAssetsJson, ",")) + "]") + "}") | |
581 | 581 | $Tuple4((accum._1 + supplyInUsd), (accum._2 + borrowInUsd), (accum._3 + reservesInUsd), (accum._4 :+ marketJson)) | |
582 | 582 | } | |
583 | 583 | ||
584 | - | let $ | |
584 | + | let $t02722927348 = { | |
585 | 585 | let $l = arr12 | |
586 | 586 | let $s = size($l) | |
587 | 587 | let $acc0 = $Tuple4(0, 0, 0, nil) | |
588 | 588 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
589 | 589 | then $a | |
590 | 590 | else marketsFold($a, $l[$i]) | |
591 | 591 | ||
592 | 592 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
593 | 593 | then $a | |
594 | 594 | else throw("List size exceeds 12") | |
595 | 595 | ||
596 | 596 | $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($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12) | |
597 | 597 | } | |
598 | - | let totalSupplyInUsd = $ | |
599 | - | let totalBorrowInUsd = $ | |
600 | - | let totalReservesInUsd = $ | |
601 | - | let marketsJson = $ | |
598 | + | let totalSupplyInUsd = $t02722927348._1 | |
599 | + | let totalBorrowInUsd = $t02722927348._2 | |
600 | + | let totalReservesInUsd = $t02722927348._3 | |
601 | + | let marketsJson = $t02722927348._4 | |
602 | 602 | let json = (((((((((("{" + "\"supplyInUsd\":") + assetToJson(usdtIdStr, totalSupplyInUsd)) + ",\"borrowInUsd\":") + assetToJson(usdtIdStr, totalBorrowInUsd)) + ",\"reservesInUsd\":") + assetToJson(usdtIdStr, totalReservesInUsd)) + ",\"markets\":[") + makeString_11C(marketsJson, ",")) + "]") + "}") | |
603 | 603 | if (debug) | |
604 | 604 | then throw(json) | |
605 | 605 | else json | |
606 | 606 | } | |
607 | 607 | ||
608 | 608 | ||
609 | 609 | func getWalletJson (marketIndex,wallet,debug) = { | |
610 | 610 | let marketStr = getStringValue(("market_" + toString(marketIndex))) | |
611 | 611 | let marketAddress = addressFromStringValue(marketStr) | |
612 | 612 | let marketName = getStringValue(("market_name_" + marketStr)) | |
613 | 613 | let marketsCount = getIntegerValue("markets") | |
614 | 614 | func marketsFold (accum,next) = if ((next >= marketsCount)) | |
615 | 615 | then accum | |
616 | 616 | else { | |
617 | 617 | let currentMarketAddressStr = getStringValue(("market_" + toString(next))) | |
618 | 618 | let currentMarketName = getStringValue(("market_name_" + currentMarketAddressStr)) | |
619 | 619 | let currentMarketAddress = addressFromStringValue(currentMarketAddressStr) | |
620 | 620 | let currentSetupTokens = getSetupTokens(currentMarketAddress) | |
621 | 621 | let currentAssetsCount = size(currentSetupTokens) | |
622 | 622 | let currentMarketShortName = getStringValue(("market_shortname_" + currentMarketAddressStr)) | |
623 | - | let setupCf = split(getStringValue(currentMarketAddress, "setup_ltvs"), ",") | |
624 | - | let setupLt = split(getStringValue(currentMarketAddress, "setup_lts"), ",") | |
623 | + | let setupCf = split_4C(getStringValue(currentMarketAddress, "setup_ltvs"), ",") | |
624 | + | let setupLt = split_4C(getStringValue(currentMarketAddress, "setup_lts"), ",") | |
625 | 625 | let currentLastRateHeight = getLastRateHeight(currentMarketAddress) | |
626 | 626 | func marketAssetsFold (accum,next) = if ((next >= currentAssetsCount)) | |
627 | 627 | then accum | |
628 | 628 | else { | |
629 | 629 | let assetIdStr = currentSetupTokens[next] | |
630 | 630 | let cf = parseIntValue(setupCf[next]) | |
631 | 631 | let lt = parseIntValue(setupLt[next]) | |
632 | 632 | let price = getTokenPrice(marketAddress, assetIdStr) | |
633 | 633 | let assetScale = getAssetScale(assetIdStr) | |
634 | 634 | let outdatedTotalSupply = getOutdatedTotalSupply(currentMarketAddress, assetIdStr) | |
635 | 635 | let outdatedTotalBorrow = getOutdatedTotalBorrow(currentMarketAddress, assetIdStr) | |
636 | 636 | let outdatedSRate = getOutdatedSRate(currentMarketAddress, assetIdStr) | |
637 | 637 | let outdatedBRate = getOutdatedBRate(currentMarketAddress, assetIdStr) | |
638 | 638 | let outdatedUr = getOutdatedUr(outdatedTotalSupply, outdatedTotalBorrow, outdatedSRate, outdatedBRate) | |
639 | 639 | let rate = getRate(outdatedUr, assetIdStr, marketStr) | |
640 | 640 | let interest = getInterest(rate) | |
641 | 641 | let sRate = getActualSRate(currentLastRateHeight, interest, outdatedUr, outdatedSRate) | |
642 | 642 | let bRate = getActualBRate(currentLastRateHeight, interest, outdatedBRate) | |
643 | 643 | let supply = getActualAmount(outdatedTotalSupply, sRate) | |
644 | 644 | let borrow = getActualAmount(outdatedTotalBorrow, bRate) | |
645 | 645 | let ur = getActualUr(supply, borrow) | |
646 | 646 | let supplyApy = getSupplyApy(rate, ur) | |
647 | 647 | let borrowApy = getBorrowApy(rate) | |
648 | 648 | let walletSupply = getWalletSupply(currentMarketAddress, assetIdStr, wallet, sRate) | |
649 | 649 | let walletSupplyInUsd = getInUsd(walletSupply, assetScale, price) | |
650 | 650 | let walletBorrow = getWalletBorrow(currentMarketAddress, assetIdStr, wallet, bRate) | |
651 | 651 | let walletBorrowInUsd = getInUsd(walletBorrow, assetScale, price) | |
652 | 652 | let walletBorrowLimitInUsd = fraction(walletSupplyInUsd, cf, Scale8) | |
653 | 653 | let walletBorrowUsageInUsd = fraction(walletBorrowInUsd, Scale8, lt) | |
654 | 654 | let walletDailyIncome = getDailyPercents(supplyApy, walletSupply) | |
655 | 655 | let walletDailyIncomeInUsd = getInUsd(walletDailyIncome, assetScale, price) | |
656 | 656 | let walletDailyLoanInterest = getDailyPercents(borrowApy, walletBorrow) | |
657 | 657 | let walletDailyLoanInterestInUsd = getInUsd(walletDailyLoanInterest, assetScale, price) | |
658 | 658 | let walletMarginInUsd = (fraction(walletSupplyInUsd, supplyApy, Scale8) - fraction(walletBorrowInUsd, borrowApy, Scale8)) | |
659 | 659 | $Tuple7((accum._1 + walletSupplyInUsd), (accum._2 + walletBorrowInUsd), (accum._3 + walletBorrowLimitInUsd), (accum._4 + walletBorrowUsageInUsd), (accum._5 + walletDailyIncomeInUsd), (accum._6 + walletDailyLoanInterestInUsd), (accum._7 + walletMarginInUsd)) | |
660 | 660 | } | |
661 | 661 | ||
662 | - | let $ | |
662 | + | let $t03217832533 = { | |
663 | 663 | let $l = arr12 | |
664 | 664 | let $s = size($l) | |
665 | 665 | let $acc0 = $Tuple7(0, 0, 0, 0, 0, 0, 0) | |
666 | 666 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
667 | 667 | then $a | |
668 | 668 | else marketAssetsFold($a, $l[$i]) | |
669 | 669 | ||
670 | 670 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
671 | 671 | then $a | |
672 | 672 | else throw("List size exceeds 12") | |
673 | 673 | ||
674 | 674 | $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($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12) | |
675 | 675 | } | |
676 | - | let totalWalletSupplyInUsd = $ | |
677 | - | let totalWalletBorrowInUsd = $ | |
678 | - | let totalWalletBorrowLimitInUsd = $ | |
679 | - | let totalWalletBorrowUsageInUsd = $ | |
680 | - | let totalWalletDailyIncomeInUsd = $ | |
681 | - | let totalWalletDailyLoanInterestInUsd = $ | |
682 | - | let totalWalletMarginInUsd = $ | |
676 | + | let totalWalletSupplyInUsd = $t03217832533._1 | |
677 | + | let totalWalletBorrowInUsd = $t03217832533._2 | |
678 | + | let totalWalletBorrowLimitInUsd = $t03217832533._3 | |
679 | + | let totalWalletBorrowUsageInUsd = $t03217832533._4 | |
680 | + | let totalWalletDailyIncomeInUsd = $t03217832533._5 | |
681 | + | let totalWalletDailyLoanInterestInUsd = $t03217832533._6 | |
682 | + | let totalWalletMarginInUsd = $t03217832533._7 | |
683 | 683 | let totalWalletBadDebtInUsd = if ((totalWalletBorrowInUsd > totalWalletSupplyInUsd)) | |
684 | 684 | then (totalWalletBorrowInUsd - totalWalletSupplyInUsd) | |
685 | 685 | else 0 | |
686 | 686 | let accountHealth = getAccountHealth(totalWalletBorrowLimitInUsd, totalWalletBorrowUsageInUsd) | |
687 | 687 | let netApy = getNetApy(totalWalletSupplyInUsd, totalWalletBorrowInUsd, totalWalletMarginInUsd) | |
688 | 688 | let marketsJson = (((((((((((("{" + "\"index\":") + toString(next)) + ",\"name\":\"") + currentMarketShortName) + "\"") + ",\"supplyInUsd\":") + assetToJson(usdtIdStr, totalWalletSupplyInUsd)) + ",\"borrowInUsd\":") + assetToJson(usdtIdStr, totalWalletBorrowInUsd)) + ",\"accountHealth\":") + amountToDecimal(accountHealth, 8)) + "}") | |
689 | 689 | func walletAssetsFold (accum,next) = if ((next >= currentAssetsCount)) | |
690 | 690 | then accum | |
691 | 691 | else { | |
692 | 692 | let assetIdStr = currentSetupTokens[next] | |
693 | 693 | let price = getTokenPrice(marketAddress, assetIdStr) | |
694 | 694 | let assetScale = getAssetScale(assetIdStr) | |
695 | 695 | let outdatedTotalSupply = getOutdatedTotalSupply(currentMarketAddress, assetIdStr) | |
696 | 696 | let outdatedTotalBorrow = getOutdatedTotalBorrow(currentMarketAddress, assetIdStr) | |
697 | 697 | let outdatedSRate = getOutdatedSRate(currentMarketAddress, assetIdStr) | |
698 | 698 | let outdatedBRate = getOutdatedBRate(currentMarketAddress, assetIdStr) | |
699 | 699 | let outdatedUr = getOutdatedUr(outdatedTotalSupply, outdatedTotalBorrow, outdatedSRate, outdatedBRate) | |
700 | 700 | let rate = getRate(outdatedUr, assetIdStr, marketStr) | |
701 | 701 | let interest = getInterest(rate) | |
702 | 702 | let sRate = getActualSRate(currentLastRateHeight, interest, outdatedUr, outdatedSRate) | |
703 | 703 | let bRate = getActualBRate(currentLastRateHeight, interest, outdatedBRate) | |
704 | 704 | let supply = getActualAmount(outdatedTotalSupply, sRate) | |
705 | 705 | let borrow = getActualAmount(outdatedTotalBorrow, bRate) | |
706 | 706 | let ur = getActualUr(supply, borrow) | |
707 | 707 | let supplyApy = getSupplyApy(rate, ur) | |
708 | 708 | let borrowApy = getBorrowApy(rate) | |
709 | 709 | let walletSupply = getWalletSupply(currentMarketAddress, assetIdStr, wallet, sRate) | |
710 | 710 | let walletSupplyInUsd = getInUsd(walletSupply, assetScale, price) | |
711 | 711 | let walletBorrow = getWalletBorrow(currentMarketAddress, assetIdStr, wallet, bRate) | |
712 | 712 | let walletBorrowInUsd = getInUsd(walletBorrow, assetScale, price) | |
713 | 713 | let walletDailyIncome = getDailyPercents(supplyApy, walletSupply) | |
714 | 714 | let walletDailyIncomeInUsd = getInUsd(walletDailyIncome, assetScale, price) | |
715 | 715 | let walletDailyLoanInterest = getDailyPercents(borrowApy, walletBorrow) | |
716 | 716 | let walletDailyLoanInterestInUsd = getInUsd(walletDailyLoanInterest, assetScale, price) | |
717 | 717 | let supplyAssetsJson = ((((((((((((("{" + "\"amount\":") + assetToJson(assetIdStr, walletSupply)) + ",\"amountInUsd\":") + assetToJson(usdtIdStr, walletSupplyInUsd)) + ",\"price\":") + assetToJson(usdtIdStr, price)) + ",\"apy\":") + amountToDecimal(supplyApy, 8)) + ",\"dailyPercents\":") + assetToJson(assetIdStr, walletDailyIncome)) + ",\"dailyPercentsInUsd\":") + assetToJson(usdtIdStr, walletDailyIncomeInUsd)) + "}") | |
718 | 718 | let borrowAssetsJson = ((((((((((((("{" + "\"amount\":") + assetToJson(assetIdStr, walletBorrow)) + ",\"amountInUsd\":") + assetToJson(usdtIdStr, walletBorrowInUsd)) + ",\"price\":") + assetToJson(usdtIdStr, price)) + ",\"apy\":") + amountToDecimal(borrowApy, 8)) + ",\"dailyPercents\":") + assetToJson(assetIdStr, walletDailyLoanInterest)) + ",\"dailyPercentsInUsd\":") + assetToJson(usdtIdStr, walletDailyLoanInterestInUsd)) + "}") | |
719 | 719 | $Tuple2((accum._1 :+ supplyAssetsJson), (accum._2 :+ borrowAssetsJson)) | |
720 | 720 | } | |
721 | 721 | ||
722 | - | let $ | |
722 | + | let $t03693537021 = { | |
723 | 723 | let $l = arr12 | |
724 | 724 | let $s = size($l) | |
725 | 725 | let $acc0 = $Tuple2(nil, nil) | |
726 | 726 | func $f1_1 ($a,$i) = if (($i >= $s)) | |
727 | 727 | then $a | |
728 | 728 | else walletAssetsFold($a, $l[$i]) | |
729 | 729 | ||
730 | 730 | func $f1_2 ($a,$i) = if (($i >= $s)) | |
731 | 731 | then $a | |
732 | 732 | else throw("List size exceeds 12") | |
733 | 733 | ||
734 | 734 | $f1_2($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($f1_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12) | |
735 | 735 | } | |
736 | - | let supplyAssetsJson = $ | |
737 | - | let borrowAssetsJson = $ | |
736 | + | let supplyAssetsJson = $t03693537021._1 | |
737 | + | let borrowAssetsJson = $t03693537021._2 | |
738 | 738 | if ((marketIndex == next)) | |
739 | 739 | then $Tuple15((accum._1 + totalWalletSupplyInUsd), (accum._2 + totalWalletBorrowInUsd), (accum._3 + totalWalletBadDebtInUsd), (accum._4 + totalWalletDailyIncomeInUsd), (accum._5 + totalWalletDailyLoanInterestInUsd), totalWalletSupplyInUsd, totalWalletBorrowInUsd, totalWalletBadDebtInUsd, totalWalletDailyIncomeInUsd, totalWalletDailyLoanInterestInUsd, accountHealth, netApy, (accum._13 :+ marketsJson), supplyAssetsJson, borrowAssetsJson) | |
740 | 740 | else $Tuple15((accum._1 + totalWalletSupplyInUsd), (accum._2 + totalWalletBorrowInUsd), (accum._3 + totalWalletBadDebtInUsd), (accum._4 + totalWalletDailyIncomeInUsd), (accum._5 + totalWalletDailyLoanInterestInUsd), accum._6, accum._7, accum._8, accum._9, accum._10, accum._11, accum._12, (accum._13 :+ marketsJson), accum._14, accum._15) | |
741 | 741 | } | |
742 | 742 | ||
743 | - | let $ | |
743 | + | let $t03847838962 = { | |
744 | 744 | let $l = arr12 | |
745 | 745 | let $s = size($l) | |
746 | 746 | let $acc0 = $Tuple15(0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, nil, nil, nil) | |
747 | 747 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
748 | 748 | then $a | |
749 | 749 | else marketsFold($a, $l[$i]) | |
750 | 750 | ||
751 | 751 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
752 | 752 | then $a | |
753 | 753 | else throw("List size exceeds 12") | |
754 | 754 | ||
755 | 755 | $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($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12) | |
756 | 756 | } | |
757 | - | let totalWalletSupplyInUsd = $ | |
758 | - | let totalWalletBorrowInUsd = $ | |
759 | - | let totalWalletBadDebtInUsd = $ | |
760 | - | let totalWalletDailyIncomeInUsd = $ | |
761 | - | let totalWalletDailyLoanInterestInUsd = $ | |
762 | - | let walletSupplyInUsd = $ | |
763 | - | let walletBorrowInUsd = $ | |
764 | - | let walletBadDebtInUsd = $ | |
765 | - | let walletDailyIncomeInUsd = $ | |
766 | - | let walletDailyLoanInterestInUsd = $ | |
767 | - | let walletAccountHealth = $ | |
768 | - | let walletNetApy = $ | |
769 | - | let marketsJson = $ | |
770 | - | let supplyAssetsJson = $ | |
771 | - | let borrowAssetsJson = $ | |
757 | + | let totalWalletSupplyInUsd = $t03847838962._1 | |
758 | + | let totalWalletBorrowInUsd = $t03847838962._2 | |
759 | + | let totalWalletBadDebtInUsd = $t03847838962._3 | |
760 | + | let totalWalletDailyIncomeInUsd = $t03847838962._4 | |
761 | + | let totalWalletDailyLoanInterestInUsd = $t03847838962._5 | |
762 | + | let walletSupplyInUsd = $t03847838962._6 | |
763 | + | let walletBorrowInUsd = $t03847838962._7 | |
764 | + | let walletBadDebtInUsd = $t03847838962._8 | |
765 | + | let walletDailyIncomeInUsd = $t03847838962._9 | |
766 | + | let walletDailyLoanInterestInUsd = $t03847838962._10 | |
767 | + | let walletAccountHealth = $t03847838962._11 | |
768 | + | let walletNetApy = $t03847838962._12 | |
769 | + | let marketsJson = $t03847838962._13 | |
770 | + | let supplyAssetsJson = $t03847838962._14 | |
771 | + | let borrowAssetsJson = $t03847838962._15 | |
772 | 772 | let json = ((((((((((((((((((((((((((((((((((((((("{" + "\"marketIndex\":") + toString(marketIndex)) + ",\"name\":\"") + marketName) + "\"") + ",\"totalSupplyInUsd\":") + assetToJson(usdtIdStr, totalWalletSupplyInUsd)) + ",\"totalBorrowInUsd\":") + assetToJson(usdtIdStr, totalWalletBorrowInUsd)) + ",\"totalBadDebtInUsd\":") + assetToJson(usdtIdStr, totalWalletBadDebtInUsd)) + ",\"totalDailyIncomeInUsd\":") + assetToJson(usdtIdStr, totalWalletDailyIncomeInUsd)) + ",\"totalDailyLoanInterestInUsd\":") + assetToJson(usdtIdStr, totalWalletDailyLoanInterestInUsd)) + ",\"supplyInUsd\":") + assetToJson(usdtIdStr, walletSupplyInUsd)) + ",\"borrowInUsd\":") + assetToJson(usdtIdStr, walletBorrowInUsd)) + ",\"badDebtInUsd\":") + assetToJson(usdtIdStr, walletBadDebtInUsd)) + ",\"dailyIncomeInUsd\":") + assetToJson(usdtIdStr, walletDailyIncomeInUsd)) + ",\"dailyLoanInterestInUsd\":") + assetToJson(usdtIdStr, walletDailyLoanInterestInUsd)) + ",\"accountHealth\":") + amountToDecimal(walletAccountHealth, 8)) + ",\"netApy\":") + amountToDecimal(walletNetApy, 8)) + ",\"supplyAssets\":[") + makeString_11C(supplyAssetsJson, ",")) + "]") + ",\"borrowAssets\":[") + makeString_11C(borrowAssetsJson, ",")) + "]") + ",\"markets\":[") + makeString_11C(marketsJson, ",")) + "]") + "}") | |
773 | 773 | if (debug) | |
774 | 774 | then throw(json) | |
775 | 775 | else json | |
776 | 776 | } | |
777 | 777 | ||
778 | 778 | ||
779 | 779 | func getWalletOperationsJson (marketIndex,assetIdStr,wallet,debug) = { | |
780 | 780 | let marketStr = getStringValue(("market_" + toString(marketIndex))) | |
781 | 781 | let marketAddress = addressFromStringValue(marketStr) | |
782 | 782 | let marketName = getStringValue(("market_name_" + marketStr)) | |
783 | 783 | let active = valueOrElse(getBoolean(marketAddress, "setup_active"), true) | |
784 | 784 | let setupTokens = getSetupTokens(marketAddress) | |
785 | - | let setupCf = split(getStringValue(marketAddress, "setup_ltvs"), ",") | |
786 | - | let setupLt = split(getStringValue(marketAddress, "setup_lts"), ",") | |
787 | - | let setupPenalty = split(getStringValue(marketAddress, "setup_penalties"), ",") | |
785 | + | let setupCf = split_4C(getStringValue(marketAddress, "setup_ltvs"), ",") | |
786 | + | let setupLt = split_4C(getStringValue(marketAddress, "setup_lts"), ",") | |
787 | + | let setupPenalty = split_4C(getStringValue(marketAddress, "setup_penalties"), ",") | |
788 | 788 | let assetIndex = getAssetIndex(setupTokens, assetIdStr) | |
789 | 789 | let cf = parseIntValue(setupCf[assetIndex]) | |
790 | 790 | let lt = parseIntValue(setupLt[assetIndex]) | |
791 | 791 | let penalty = parseIntValue(setupPenalty[assetIndex]) | |
792 | 792 | let assetsCount = size(setupTokens) | |
793 | 793 | let lastRateHeight = getLastRateHeight(marketAddress) | |
794 | 794 | let price = getTokenPrice(marketAddress, assetIdStr) | |
795 | 795 | let assetScale = getAssetScale(assetIdStr) | |
796 | 796 | let outdatedTotalSupply = getOutdatedTotalSupply(marketAddress, assetIdStr) | |
797 | 797 | let outdatedTotalBorrow = getOutdatedTotalBorrow(marketAddress, assetIdStr) | |
798 | 798 | let outdatedSRate = getOutdatedSRate(marketAddress, assetIdStr) | |
799 | 799 | let outdatedBRate = getOutdatedBRate(marketAddress, assetIdStr) | |
800 | 800 | let outdatedUr = getOutdatedUr(outdatedTotalSupply, outdatedTotalBorrow, outdatedSRate, outdatedBRate) | |
801 | 801 | let rate = getRate(outdatedUr, assetIdStr, marketStr) | |
802 | 802 | let interest = getInterest(rate) | |
803 | 803 | let sRate = getActualSRate(lastRateHeight, interest, outdatedUr, outdatedSRate) | |
804 | 804 | let bRate = getActualBRate(lastRateHeight, interest, outdatedBRate) | |
805 | 805 | let supply = getActualAmount(outdatedTotalSupply, sRate) | |
806 | 806 | let borrow = getActualAmount(outdatedTotalBorrow, bRate) | |
807 | 807 | let supplyInUsd = getInUsd(supply, assetScale, price) | |
808 | 808 | let borrowInUsd = getInUsd(borrow, assetScale, price) | |
809 | 809 | let reserves = (supply - borrow) | |
810 | 810 | let reservesInUsd = getInUsd(reserves, assetScale, price) | |
811 | 811 | let ur = getActualUr(supply, borrow) | |
812 | 812 | let supplyApy = getSupplyApy(rate, ur) | |
813 | 813 | let borrowApy = getBorrowApy(rate) | |
814 | 814 | let maxSupply = getMaxSupply(marketAddress, assetIdStr) | |
815 | 815 | let walletSupply = getWalletSupply(marketAddress, assetIdStr, wallet, sRate) | |
816 | 816 | let walletSupplyInUsd = getInUsd(walletSupply, assetScale, price) | |
817 | 817 | let walletDailyIncome = getDailyPercents(supplyApy, walletSupply) | |
818 | 818 | let walletDailyIncomeInUsd = getInUsd(walletDailyIncome, assetScale, price) | |
819 | 819 | let walletBorrow = getWalletBorrow(marketAddress, assetIdStr, wallet, bRate) | |
820 | 820 | let walletBorrowInUsd = getInUsd(walletBorrow, assetScale, price) | |
821 | 821 | let walletDailyLoanPercents = getDailyPercents(borrowApy, walletBorrow) | |
822 | 822 | let walletDailyLoanPercentsInUsd = getInUsd(walletDailyLoanPercents, assetScale, price) | |
823 | 823 | func assetsFold (accum,next) = if ((next >= assetsCount)) | |
824 | 824 | then accum | |
825 | 825 | else { | |
826 | 826 | let currentAssetIdStr = setupTokens[next] | |
827 | 827 | let currentCf = parseIntValue(setupCf[next]) | |
828 | 828 | let currentLt = parseIntValue(setupLt[next]) | |
829 | 829 | let currentPrice = getTokenPrice(marketAddress, currentAssetIdStr) | |
830 | 830 | let currentAssetScale = getAssetScale(currentAssetIdStr) | |
831 | 831 | let currentOutdatedTotalSupply = getOutdatedTotalSupply(marketAddress, currentAssetIdStr) | |
832 | 832 | let currentOutdatedTotalBorrow = getOutdatedTotalBorrow(marketAddress, currentAssetIdStr) | |
833 | 833 | let currentOutdatedSRate = getOutdatedSRate(marketAddress, currentAssetIdStr) | |
834 | 834 | let currentOutdatedBRate = getOutdatedBRate(marketAddress, currentAssetIdStr) | |
835 | 835 | let currentOutdatedUr = getOutdatedUr(currentOutdatedTotalSupply, currentOutdatedTotalBorrow, currentOutdatedSRate, currentOutdatedBRate) | |
836 | 836 | let currentRate = getRate(currentOutdatedUr, currentAssetIdStr, marketStr) | |
837 | 837 | let currentInterest = getInterest(currentRate) | |
838 | 838 | let currentSRate = getActualSRate(lastRateHeight, currentInterest, currentOutdatedUr, currentOutdatedSRate) | |
839 | 839 | let currentBRate = getActualBRate(lastRateHeight, currentInterest, currentOutdatedBRate) | |
840 | 840 | let currentSupply = getActualAmount(currentOutdatedTotalSupply, sRate) | |
841 | 841 | let currentBorrow = getActualAmount(currentOutdatedTotalBorrow, bRate) | |
842 | 842 | let currentUr = getActualUr(currentSupply, currentBorrow) | |
843 | 843 | let currentSupplyApy = getSupplyApy(currentRate, currentUr) | |
844 | 844 | let currentBorrowApy = getBorrowApy(currentRate) | |
845 | 845 | let currentWalletSupply = getWalletSupply(marketAddress, currentAssetIdStr, wallet, currentSRate) | |
846 | 846 | let currentWalletSupplyInUsd = getInUsd(currentWalletSupply, currentAssetScale, currentPrice) | |
847 | 847 | let currentWalletBorrow = getWalletBorrow(marketAddress, currentAssetIdStr, wallet, currentBRate) | |
848 | 848 | let currentWalletBorrowInUsd = getInUsd(currentWalletBorrow, currentAssetScale, currentPrice) | |
849 | 849 | let currentWalletBorrowLimitInUsd = fraction(currentWalletSupplyInUsd, currentCf, Scale8) | |
850 | 850 | let currentWalletBorrowUsageInUsd = fraction(currentWalletBorrowInUsd, Scale8, currentLt) | |
851 | 851 | let walletMarginInUsd = (fraction(currentWalletSupplyInUsd, currentSupplyApy, Scale8) - fraction(currentWalletBorrowInUsd, currentBorrowApy, Scale8)) | |
852 | 852 | $Tuple5((accum._1 + currentWalletSupplyInUsd), (accum._2 + currentWalletBorrowInUsd), (accum._3 + currentWalletBorrowLimitInUsd), (accum._4 + currentWalletBorrowUsageInUsd), (accum._5 + walletMarginInUsd)) | |
853 | 853 | } | |
854 | 854 | ||
855 | - | let $ | |
855 | + | let $t04597346154 = { | |
856 | 856 | let $l = arr12 | |
857 | 857 | let $s = size($l) | |
858 | 858 | let $acc0 = $Tuple5(0, 0, 0, 0, 0) | |
859 | 859 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
860 | 860 | then $a | |
861 | 861 | else assetsFold($a, $l[$i]) | |
862 | 862 | ||
863 | 863 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
864 | 864 | then $a | |
865 | 865 | else throw("List size exceeds 12") | |
866 | 866 | ||
867 | 867 | $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($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12) | |
868 | 868 | } | |
869 | - | let totalWalletSupplyInUsd = $ | |
870 | - | let totalWalletBorrowInUsd = $ | |
871 | - | let totalWalletBorrowLimitInUsd = $ | |
872 | - | let totalWalletBorrowUsageInUsd = $ | |
873 | - | let totalWalletMarginInUsd = $ | |
869 | + | let totalWalletSupplyInUsd = $t04597346154._1 | |
870 | + | let totalWalletBorrowInUsd = $t04597346154._2 | |
871 | + | let totalWalletBorrowLimitInUsd = $t04597346154._3 | |
872 | + | let totalWalletBorrowUsageInUsd = $t04597346154._4 | |
873 | + | let totalWalletMarginInUsd = $t04597346154._5 | |
874 | 874 | let accountHealth = getAccountHealth(totalWalletBorrowLimitInUsd, totalWalletBorrowUsageInUsd) | |
875 | 875 | let netApy = getNetApy(totalWalletSupplyInUsd, totalWalletBorrowInUsd, totalWalletMarginInUsd) | |
876 | 876 | let json = ((((((((((((((((((((((((((((((((((((((((((((((((((((((((("{" + "\"marketIndex\":") + toString(marketIndex)) + ",\"marketName\":\"") + marketName) + "\"") + ",\"address\":\"") + marketStr) + "\"") + ",\"assetPrice\":") + assetToJson(usdtIdStr, price)) + ",\"supply\":") + assetToJson(assetIdStr, supply)) + ",\"supplyInUsd\":") + assetToJson(usdtIdStr, supplyInUsd)) + ",\"supplyApy\":") + amountToDecimal(supplyApy, 8)) + ",\"borrow\":") + assetToJson(assetIdStr, borrow)) + ",\"borrowInUsd\":") + assetToJson(usdtIdStr, borrowInUsd)) + ",\"borrowApy\":") + amountToDecimal(borrowApy, 8)) + ",\"reserves\":") + assetToJson(assetIdStr, reserves)) + ",\"reservesInUsd\":") + assetToJson(usdtIdStr, reservesInUsd)) + ",\"utilizationRatio\":") + amountToDecimal(ur, 8)) + ",\"collateralFactor\":") + amountToDecimal(cf, 8)) + ",\"liquidationThreshold\":") + amountToDecimal(lt, 8)) + ",\"liquidationPenalty\":") + amountToDecimal(penalty, 8)) + ",\"maxSupply\":") + assetToJson(usdtIdStr, maxSupply)) + ",\"walletSupply\":") + assetToJson(assetIdStr, walletSupply)) + ",\"walletSupplyInUsd\":") + assetToJson(usdtIdStr, walletSupplyInUsd)) + ",\"walletDailyIncome\":") + assetToJson(assetIdStr, walletDailyIncome)) + ",\"walletDailyIncomeInUsd\":") + assetToJson(usdtIdStr, walletDailyIncomeInUsd)) + ",\"walletBorrow\":") + assetToJson(assetIdStr, walletBorrow)) + ",\"walletBorrowInUsd\":") + assetToJson(usdtIdStr, walletBorrowInUsd)) + ",\"walletDailyLoanInterest\":") + assetToJson(assetIdStr, walletDailyLoanPercents)) + ",\"walletDailyLoanInterestInUsd\":") + assetToJson(usdtIdStr, walletDailyLoanPercentsInUsd)) + ",\"accountHealth\":") + amountToDecimal(accountHealth, 8)) + ",\"netApy\":") + amountToDecimal(netApy, 8)) + "}") | |
877 | 877 | if (debug) | |
878 | 878 | then throw(json) | |
879 | 879 | else json | |
880 | 880 | } | |
881 | 881 | ||
882 | 882 | ||
883 | 883 | func getMarketParametersJson (marketIndex,debug) = { | |
884 | 884 | let marketStr = getStringValue(("market_" + toString(marketIndex))) | |
885 | 885 | let marketAddress = addressFromStringValue(marketStr) | |
886 | 886 | let marketName = getStringValue(("market_name_" + marketStr)) | |
887 | 887 | let setupTokens = getSetupTokens(marketAddress) | |
888 | - | let setupCf = split(getStringValue(marketAddress, "setup_ltvs"), ",") | |
889 | - | let setupLt = split(getStringValue(marketAddress, "setup_lts"), ",") | |
890 | - | let setupPenalty = split(getStringValue(marketAddress, "setup_penalties"), ",") | |
888 | + | let setupCf = split_4C(getStringValue(marketAddress, "setup_ltvs"), ",") | |
889 | + | let setupLt = split_4C(getStringValue(marketAddress, "setup_lts"), ",") | |
890 | + | let setupPenalty = split_4C(getStringValue(marketAddress, "setup_penalties"), ",") | |
891 | 891 | let assetsCount = size(setupTokens) | |
892 | 892 | func assetsFold (accum,next) = if ((next >= assetsCount)) | |
893 | 893 | then accum | |
894 | 894 | else { | |
895 | 895 | let assetIdStr = setupTokens[next] | |
896 | 896 | let maxSupply = getMaxSupply(marketAddress, assetIdStr) | |
897 | 897 | let cf = parseIntValue(setupCf[next]) | |
898 | 898 | let lt = parseIntValue(setupLt[next]) | |
899 | 899 | let penalty = parseIntValue(setupPenalty[next]) | |
900 | 900 | let json = ((((((((((("{" + "\"asset\":") + assetToJson(assetIdStr, 0)) + ",\"maxSupply\":") + assetToJson(usdtIdStr, maxSupply)) + ",\"collateralFactor\":") + amountToDecimal(cf, 8)) + ",\"liquidationThreshold\":") + amountToDecimal(lt, 8)) + ",\"liquidationPenalty\":") + amountToDecimal(penalty, 8)) + "}") | |
901 | 901 | (accum :+ json) | |
902 | 902 | } | |
903 | 903 | ||
904 | 904 | let assetsJson = { | |
905 | 905 | let $l = arr12 | |
906 | 906 | let $s = size($l) | |
907 | 907 | let $acc0 = nil | |
908 | 908 | func $f0_1 ($a,$i) = if (($i >= $s)) | |
909 | 909 | then $a | |
910 | 910 | else assetsFold($a, $l[$i]) | |
911 | 911 | ||
912 | 912 | func $f0_2 ($a,$i) = if (($i >= $s)) | |
913 | 913 | then $a | |
914 | 914 | else throw("List size exceeds 12") | |
915 | 915 | ||
916 | 916 | $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($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12) | |
917 | 917 | } | |
918 | 918 | let json = ((((((("{" + "\"name\":\"") + marketName) + "\"") + ",\"assets\":[") + makeString_11C(assetsJson, ",")) + "]") + "}") | |
919 | 919 | if (debug) | |
920 | 920 | then throw(json) | |
921 | 921 | else json | |
922 | 922 | } | |
923 | 923 | ||
924 | 924 | ||
925 | 925 |
github/deemru/w8io/3ef1775 142.28 ms ◑