tx · 2TJUj2YAiu1o4meX1SUia5HeEvyVfFJko1LCXzW6Neun

3MsAsECgvs3yQbezGUFsRxBH6NGuEZSLV2f:  -0.09800000 Waves

2023.03.01 11:04 [2470738] smart account 3MsAsECgvs3yQbezGUFsRxBH6NGuEZSLV2f > SELF 0.00000000 Waves

{ "type": 13, "id": "2TJUj2YAiu1o4meX1SUia5HeEvyVfFJko1LCXzW6Neun", "fee": 9800000, "feeAssetId": null, "timestamp": 1677657837024, "version": 2, "chainId": 84, "sender": "3MsAsECgvs3yQbezGUFsRxBH6NGuEZSLV2f", "senderPublicKey": "CfhnsiVkRfv8ce2p2fPcdKK41WoVn8g8WRq1UJJKuUY8", "proofs": [ "3DEYYeoqqurJDMwjxbrM8hJXESxCaA8DE1mPVrKw14P5fhrx786DRyNQb2HrEFCrgfJQ9gMmfnBgoYr3tE6oN2we" ], "script": "base64:BgKxAQgCEgUKAwEEARIHCgUBBAEIARIDCgEIEgMKAQgSABIECgIBBBIECgIBBBIDCgEBEgASBAoCCAESABIECgIIARIECgIIARIECgIBARIDCgEBEgUKAwEBARIFCgMBCAESBAoCAQgSBAoCAQgSBAoCCAgSBAoCCAgSBAoCCAESABIDCgEIEgUKAwEBARIECgIIARIECgIBARIECgIICBILCgkIAQECAQIIBAQSBgoECAgBCIIBAAZzY2FsZTgAgMLXLwAMc2NhbGU4QmlnSW50CQC2AgEAgMLXLwAHc2NhbGUxOAkAtgIBAICAkLu61q3wDQAKemVyb0JpZ0ludAkAtgIBAAAABGJpZzAJALYCAQAAAARiaWcxCQC2AgEAAQAEYmlnMgkAtgIBAAIABGJpZzMJALYCAQADAARiaWc0CQC2AgEABAAKc2xpcHBhZ2U0RAkAtgIBCQBlAgUGc2NhbGU4CQBpAgkAaAIFBnNjYWxlOAABBQZzY2FsZTgAC3dhdmVzU3RyaW5nAgVXQVZFUwAFQW11bHQCAzEwMAAFRGNvbnYCATEAA1NFUAICX18ABUVNUFRZAgAAClBvb2xBY3RpdmUAAQAKUG9vbFB1dERpcwACAA5Qb29sTWF0Y2hlckRpcwADAAxQb29sU2h1dGRvd24ABAAOaWR4UG9vbEFkZHJlc3MAAQAJaWR4UG9vbFN0AAIACWlkeExQQXNJZAADAAlpZHhBbUFzSWQABAAJaWR4UHJBc0lkAAUAC2lkeEFtdEFzRGNtAAYADWlkeFByaWNlQXNEY20ABwALaWR4SUFtdEFzSWQACAANaWR4SVByaWNlQXNJZAAJAA9pZHhGYWN0U3Rha0NudHIAAQASaWR4RmFjdG9yeVJlc3RDbnRyAAYAEGlkeEZhY3RTbGlwcENudHIABwARaWR4RmFjdEd3eFJld0NudHIACgAKZmVlRGVmYXVsdAkAawMACgUGc2NhbGU4AJBOAQJ0MQIHb3JpZ1ZhbA1vcmlnU2NhbGVNdWx0CQC8AgMJALYCAQUHb3JpZ1ZhbAUHc2NhbGUxOAkAtgIBBQ1vcmlnU2NhbGVNdWx0AQh0MUJpZ0ludAIHb3JpZ1ZhbA1vcmlnU2NhbGVNdWx0CQC8AgMFB29yaWdWYWwFB3NjYWxlMTgFDW9yaWdTY2FsZU11bHQBAmYxAgN2YWwPcmVzdWx0U2NhbGVNdWx0CQCgAwEJALwCAwUDdmFsCQC2AgEFD3Jlc3VsdFNjYWxlTXVsdAUHc2NhbGUxOAEMZnJvbVgxOFJvdW5kAwN2YWwPcmVzdWx0U2NhbGVNdWx0BXJvdW5kCQCgAwEJAL0CBAUDdmFsCQC2AgEFD3Jlc3VsdFNjYWxlTXVsdAUHc2NhbGUxOAUFcm91bmQBAnQyAgdvcmlnVmFsDW9yaWdTY2FsZU11bHQJALwCAwUHb3JpZ1ZhbAUHc2NhbGUxOAkAtgIBBQ1vcmlnU2NhbGVNdWx0AQJmMgIDdmFsD3Jlc3VsdFNjYWxlTXVsdAkAvAIDBQN2YWwJALYCAQUPcmVzdWx0U2NhbGVNdWx0BQdzY2FsZTE4AQJ0cwMDYW10CHJlc1NjYWxlCGN1clNjYWxlCQBrAwUDYW10BQhyZXNTY2FsZQUIY3VyU2NhbGUBA2FicwEDdmFsAwkAvwICBQp6ZXJvQmlnSW50BQN2YWwJAL4CAQUDdmFsBQN2YWwBCWFic0JpZ0ludAEDdmFsAwkAvwICBQp6ZXJvQmlnSW50BQN2YWwJAL4CAQUDdmFsBQN2YWwBAmZjAAITJXNfX2ZhY3RvcnlDb250cmFjdAEDbXBrAAIUJXNfX21hbmFnZXJQdWJsaWNLZXkBBHBtcGsAAhslc19fcGVuZGluZ01hbmFnZXJQdWJsaWNLZXkBAnBsAAIRJXMlc19fcHJpY2VfX2xhc3QBAnBoAgFoAXQJALkJAgkAzAgCAhglcyVzJWQlZF9fcHJpY2VfX2hpc3RvcnkJAMwIAgkApAMBBQFoCQDMCAIJAKQDAQUBdAUDbmlsBQNTRVABA3BhdQICdWEEdHhJZAkArAICCQCsAgIJAKwCAgILJXMlcyVzX19QX18FAnVhAgJfXwUEdHhJZAEDZ2F1AgJ1YQR0eElkCQCsAgIJAKwCAgkArAICAgslcyVzJXNfX0dfXwUCdWECAl9fBQR0eElkAQJhYQACDyVzX19hbW91bnRBc3NldAECcGEAAg4lc19fcHJpY2VBc3NldAEDYW1wAAIHJXNfX2FtcAEDYWRhAAINJXNfX2FkZG9uQWRkcgAGa2V5RmVlAgclc19fZmVlAANmZWUJAQt2YWx1ZU9yRWxzZQIJAJoIAgUEdGhpcwUGa2V5RmVlBQpmZWVEZWZhdWx0AAZrZXlETHAJALkJAgkAzAgCAgIlcwkAzAgCAgNkTHAFA25pbAUDU0VQABVrZXlETHBSZWZyZXNoZWRIZWlnaHQJALkJAgkAzAgCAgIlcwkAzAgCAhJkTHBSZWZyZXNoZWRIZWlnaHQFA25pbAUDU0VQABJrZXlETHBSZWZyZXNoRGVsYXkJALkJAgkAzAgCAgIlcwkAzAgCAg9yZWZyZXNoRExwRGVsYXkFA25pbAUDU0VQABZkTHBSZWZyZXNoRGVsYXlEZWZhdWx0AB4AD2RMcFJlZnJlc2hEZWxheQkBC3ZhbHVlT3JFbHNlAgkAmggCBQR0aGlzBRJrZXlETHBSZWZyZXNoRGVsYXkFFmRMcFJlZnJlc2hEZWxheURlZmF1bHQBBGZjZmcAAhElc19fZmFjdG9yeUNvbmZpZwEEbXRwawACGCVzJXNfX21hdGNoZXJfX3B1YmxpY0tleQECcGMCBmlBbXRBcwVpUHJBcwkArAICCQCsAgIJAKwCAgkArAICAgglZCVkJXNfXwUGaUFtdEFzAgJfXwUFaVByQXMCCF9fY29uZmlnAQNtYmEBBWJBU3RyCQCsAgICKCVzJXMlc19fbWFwcGluZ3NfX2Jhc2VBc3NldDJpbnRlcm5hbElkX18FBWJBU3RyAQNhcHMAAgwlc19fc2h1dGRvd24BHGtleUFsbG93ZWRMcFN0YWJsZVNjcmlwdEhhc2gAAh0lc19fYWxsb3dlZExwU3RhYmxlU2NyaXB0SGFzaAEWa2V5RmVlQ29sbGVjdG9yQWRkcmVzcwACFyVzX19mZWVDb2xsZWN0b3JBZGRyZXNzAQ90aHJvd09yZGVyRXJyb3IECm9yZGVyVmFsaWQOb3JkZXJWYWxpZEluZm8Lc2VuZGVyVmFsaWQMbWF0Y2hlclZhbGlkCQACAQkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkArAICCQCsAgICJG9yZGVyIHZhbGlkYXRpb24gZmFpbGVkOiBvcmRlclZhbGlkPQkApQMBBQpvcmRlclZhbGlkAgIgKAUOb3JkZXJWYWxpZEluZm8CASkCDSBzZW5kZXJWYWxpZD0JAKUDAQULc2VuZGVyVmFsaWQCDiBtYXRjaGVyVmFsaWQ9CQClAwEFDG1hdGNoZXJWYWxpZAEEc3RyZgIEYWRkcgNrZXkJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAnQgCBQRhZGRyBQNrZXkJALkJAgkAzAgCAgptYW5kYXRvcnkgCQDMCAIJAKUIAQUEYWRkcgkAzAgCAgEuCQDMCAIFA2tleQkAzAgCAgwgbm90IGRlZmluZWQFA25pbAIAAQRpbnRmAgRhZGRyA2tleQkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCaCAIFBGFkZHIFA2tleQkAuQkCCQDMCAICCm1hbmRhdG9yeSAJAMwIAgkApQgBBQRhZGRyCQDMCAICAS4JAMwIAgUDa2V5CQDMCAICDCBub3QgZGVmaW5lZAUDbmlsAgABCHRocm93RXJyAQNtc2cJAAIBCQC5CQIJAMwIAgIPbHBfc3RhYmxlLnJpZGU6CQDMCAIFA21zZwUDbmlsAgEgAQZmbXRFcnIBA21zZwkAuQkCCQDMCAICD2xwX3N0YWJsZS5yaWRlOgkAzAgCBQNtc2cFA25pbAIBIAADZmNhCQERQGV4dHJOYXRpdmUoMTA2MikBCQEEc3RyZgIFBHRoaXMJAQJmYwAABWluRmVlCgABQAkA/AcEBQNmY2ECEGdldEluRmVlUkVBRE9OTFkJAMwIAgkApQgBBQR0aGlzBQNuaWwFA25pbAMJAAECBQFAAgNJbnQFAUAJAAIBCQCsAgIJAAMBBQFAAhggY291bGRuJ3QgYmUgY2FzdCB0byBJbnQABm91dEZlZQoAAUAJAPwHBAUDZmNhAhFnZXRPdXRGZWVSRUFET05MWQkAzAgCCQClCAEFBHRoaXMFA25pbAUDbmlsAwkAAQIFAUACA0ludAUBQAkAAgEJAKwCAgkAAwEFAUACGCBjb3VsZG4ndCBiZSBjYXN0IHRvIEludAABQQkBBHN0cmYCBQR0aGlzCQEDYW1wAAEDaWdzAAkBC3ZhbHVlT3JFbHNlAgkAmwgCBQNmY2EJAQNhcHMABwECbXAACQDZBAEJAQRzdHJmAgUDZmNhCQEEbXRwawAAE2ZlZUNvbGxlY3RvckFkZHJlc3MJARFAZXh0ck5hdGl2ZSgxMDYyKQEJAQRzdHJmAgUDZmNhCQEWa2V5RmVlQ29sbGVjdG9yQWRkcmVzcwABA2dwYwAEBWFtdEFzCQEEc3RyZgIFBHRoaXMJAQJhYQAEB3ByaWNlQXMJAQRzdHJmAgUEdGhpcwkBAnBhAAQIaVByaWNlQXMJAQRpbnRmAgUDZmNhCQEDbWJhAQUHcHJpY2VBcwQGaUFtdEFzCQEEaW50ZgIFA2ZjYQkBA21iYQEFBWFtdEFzCQC1CQIJAQRzdHJmAgUDZmNhCQECcGMCCQCkAwEFBmlBbXRBcwkApAMBBQhpUHJpY2VBcwUDU0VQAQxwYXJzZUFzc2V0SWQBBWlucHV0AwkAAAIFBWlucHV0BQt3YXZlc1N0cmluZwUEdW5pdAkA2QQBBQVpbnB1dAEPYXNzZXRJZFRvU3RyaW5nAQVpbnB1dAMJAAACBQVpbnB1dAUEdW5pdAULd2F2ZXNTdHJpbmcJANgEAQkBBXZhbHVlAQUFaW5wdXQBD3BhcnNlUG9vbENvbmZpZwEKcG9vbENvbmZpZwkAmwoJCQERQGV4dHJOYXRpdmUoMTA2MikBCQCRAwIFCnBvb2xDb25maWcFDmlkeFBvb2xBZGRyZXNzCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUKcG9vbENvbmZpZwUJaWR4UG9vbFN0CQDZBAEJAJEDAgUKcG9vbENvbmZpZwUJaWR4TFBBc0lkCQEMcGFyc2VBc3NldElkAQkAkQMCBQpwb29sQ29uZmlnBQlpZHhBbUFzSWQJAQxwYXJzZUFzc2V0SWQBCQCRAwIFCnBvb2xDb25maWcFCWlkeFByQXNJZAkBDXBhcnNlSW50VmFsdWUBCQCRAwIFCnBvb2xDb25maWcFC2lkeEFtdEFzRGNtCQENcGFyc2VJbnRWYWx1ZQEJAJEDAgUKcG9vbENvbmZpZwUNaWR4UHJpY2VBc0RjbQkA2QQBCQCRAwIFCnBvb2xDb25maWcFC2lkeElBbXRBc0lkCQDZBAEJAJEDAgUKcG9vbENvbmZpZwUNaWR4SVByaWNlQXNJZAAQcG9vbENvbmZpZ1BhcnNlZAkBD3BhcnNlUG9vbENvbmZpZwEJAQNncGMAAAskdDA3OTY1ODE5NAUQcG9vbENvbmZpZ1BhcnNlZAAOY2ZnUG9vbEFkZHJlc3MIBQskdDA3OTY1ODE5NAJfMQANY2ZnUG9vbFN0YXR1cwgFCyR0MDc5NjU4MTk0Al8yAAxjZmdMcEFzc2V0SWQIBQskdDA3OTY1ODE5NAJfMwAQY2ZnQW1vdW50QXNzZXRJZAgFCyR0MDc5NjU4MTk0Al80AA9jZmdQcmljZUFzc2V0SWQIBQskdDA3OTY1ODE5NAJfNQAWY2ZnQW1vdW50QXNzZXREZWNpbWFscwgFCyR0MDc5NjU4MTk0Al82ABVjZmdQcmljZUFzc2V0RGVjaW1hbHMIBQskdDA3OTY1ODE5NAJfNwASY2ZnSW5BbW91bnRBc3NlZElkCAULJHQwNzk2NTgxOTQCXzgAEWNmZ0luUHJpY2VBc3NldElkCAULJHQwNzk2NTgxOTQCXzkBA2dmYwAJALUJAgkBBHN0cmYCBQNmY2EJAQRmY2ZnAAUDU0VQAA1mYWN0b3J5Q29uZmlnCQEDZ2ZjAAAPc3Rha2luZ0NvbnRyYWN0CQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkAkQMCBQ1mYWN0b3J5Q29uZmlnBQ9pZHhGYWN0U3Rha0NudHICIEludmFsaWQgc3Rha2luZyBjb250cmFjdCBhZGRyZXNzAA9zbGlwYWdlQ29udHJhY3QJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQCRAwIFDWZhY3RvcnlDb25maWcFEGlkeEZhY3RTbGlwcENudHICIEludmFsaWQgc2xpcGFnZSBjb250cmFjdCBhZGRyZXNzAAtnd3hDb250cmFjdAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEJAJEDAgUNZmFjdG9yeUNvbmZpZwURaWR4RmFjdEd3eFJld0NudHICHEludmFsaWQgZ3d4IGNvbnRyYWN0IGFkZHJlc3MADHJlc3RDb250cmFjdAkBE3ZhbHVlT3JFcnJvck1lc3NhZ2UCCQCmCAEJAJEDAgUNZmFjdG9yeUNvbmZpZwUSaWR4RmFjdG9yeVJlc3RDbnRyAhxJbnZhbGlkIGd3eCBjb250cmFjdCBhZGRyZXNzARFkYXRhUHV0QWN0aW9uSW5mbwoNaW5BbXRBc3NldEFtdA9pblByaWNlQXNzZXRBbXQIb3V0THBBbXQFcHJpY2UKc2xpcEJ5VXNlcgxzbGlwcGFnZVJlYWwIdHhIZWlnaHQLdHhUaW1lc3RhbXAMc2xpcGFnZUFtQW10DHNsaXBhZ2VQckFtdAkAuQkCCQDMCAICFCVkJWQlZCVkJWQlZCVkJWQlZCVkCQDMCAIJAKQDAQUNaW5BbXRBc3NldEFtdAkAzAgCCQCkAwEFD2luUHJpY2VBc3NldEFtdAkAzAgCCQCkAwEFCG91dExwQW10CQDMCAIJAKQDAQUFcHJpY2UJAMwIAgkApAMBBQpzbGlwQnlVc2VyCQDMCAIJAKQDAQUMc2xpcHBhZ2VSZWFsCQDMCAIJAKQDAQUIdHhIZWlnaHQJAMwIAgkApAMBBQt0eFRpbWVzdGFtcAkAzAgCCQCkAwEFDHNsaXBhZ2VBbUFtdAkAzAgCCQCkAwEFDHNsaXBhZ2VQckFtdAUDbmlsBQNTRVABEWRhdGFHZXRBY3Rpb25JbmZvBg5vdXRBbXRBc3NldEFtdBBvdXRQcmljZUFzc2V0QW10B2luTHBBbXQFcHJpY2UIdHhIZWlnaHQLdHhUaW1lc3RhbXAJALkJAgkAzAgCAgwlZCVkJWQlZCVkJWQJAMwIAgkApAMBBQ5vdXRBbXRBc3NldEFtdAkAzAgCCQCkAwEFEG91dFByaWNlQXNzZXRBbXQJAMwIAgkApAMBBQdpbkxwQW10CQDMCAIJAKQDAQUFcHJpY2UJAMwIAgkApAMBBQh0eEhlaWdodAkAzAgCCQCkAwEFC3R4VGltZXN0YW1wBQNuaWwFA1NFUAENZ2V0QWNjQmFsYW5jZQEHYXNzZXRJZAMJAAACBQdhc3NldElkAgVXQVZFUwgJAO8HAQUEdGhpcwlhdmFpbGFibGUJAPAHAgUEdGhpcwkA2QQBBQdhc3NldElkAQRjcGJpAghwckFtdFgxOAhhbUFtdFgxOAkAvAIDBQhwckFtdFgxOAUHc2NhbGUxOAUIYW1BbXRYMTgBBWNwYmlyAwhwckFtdFgxOAhhbUFtdFgxOAVyb3VuZAkAvQIEBQhwckFtdFgxOAUHc2NhbGUxOAUIYW1BbXRYMTgFBXJvdW5kAQN2YWQDAkExAkEyCHNsaXBwYWdlBARkaWZmCQC8AgMJALgCAgUCQTEFAkEyBQxzY2FsZThCaWdJbnQFAkEyBARwYXNzCQC/AgIJALgCAgUIc2xpcHBhZ2UJAQNhYnMBBQRkaWZmBQp6ZXJvQmlnSW50AwkBASEBBQRwYXNzCQACAQkArAICAgpCaWcgc2xwZzogCQCmAwEFBGRpZmYJAJQKAgUEcGFzcwkAmQMBCQDMCAIFAkExCQDMCAIFAkEyBQNuaWwBAnZkAwJEMQJEMARzbHBnBARkaWZmCQC8AgMFAkQwBQxzY2FsZThCaWdJbnQFAkQxBARmYWlsCQC/AgIFBHNscGcFBGRpZmYDAwUEZmFpbAYJAL8CAgUCRDAFAkQxCQACAQkArAICCQCsAgIJAKwCAgkArAICCQCsAgIJAKwCAgkApgMBBQJEMAIBIAkApgMBBQJEMQIBIAkApgMBBQRkaWZmAgEgCQCmAwEFBHNscGcFBGZhaWwBA3BjcAQKYW1Bc3NldERjbQpwckFzc2V0RGNtBWFtQW10BXByQW10BAthbXRBc0FtdFgxOAkBAnQxAgUFYW1BbXQFCmFtQXNzZXREY20ECnByQXNBbXRYMTgJAQJ0MQIFBXByQW10BQpwckFzc2V0RGNtCQEEY3BiaQIFCnByQXNBbXRYMTgFC2FtdEFzQW10WDE4AQpjYWxjUHJpY2VzAwVhbUFtdAVwckFtdAVscEFtdAQIYW10QXNEY20FFmNmZ0Ftb3VudEFzc2V0RGVjaW1hbHMEB3ByQXNEY20FFWNmZ1ByaWNlQXNzZXREZWNpbWFscwQIcHJpY2VYMTgJAQNwY3AEBQhhbXRBc0RjbQUHcHJBc0RjbQUFYW1BbXQFBXByQW10BAhhbUFtdFgxOAkBAnQxAgUFYW1BbXQFCGFtdEFzRGNtBAhwckFtdFgxOAkBAnQxAgUFcHJBbXQFB3ByQXNEY20ECGxwQW10WDE4CQECdDECBQVscEFtdAUGc2NhbGU4BA1scFBySW5BbUFzWDE4CQEEY3BiaQIFCGFtQW10WDE4BQhscEFtdFgxOAQNbHBQckluUHJBc1gxOAkBBGNwYmkCBQhwckFtdFgxOAUIbHBBbXRYMTgJAMwIAgUIcHJpY2VYMTgJAMwIAgUNbHBQckluQW1Bc1gxOAkAzAgCBQ1scFBySW5QckFzWDE4BQNuaWwBD2NhbGN1bGF0ZVByaWNlcwMFYW1BbXQFcHJBbXQFbHBBbXQEAXAJAQpjYWxjUHJpY2VzAwUFYW1BbXQFBXByQW10BQVscEFtdAkAzAgCCQECZjECCQCRAwIFAXAAAAUGc2NhbGU4CQDMCAIJAQJmMQIJAJEDAgUBcAABBQZzY2FsZTgJAMwIAgkBAmYxAgkAkQMCBQFwAAIFBnNjYWxlOAUDbmlsAQd0YWtlRmVlAgZhbW91bnQDZmVlBAlmZWVBbW91bnQDCQAAAgUDZmVlAAAAAAkAawMFBmFtb3VudAUDZmVlBQZzY2FsZTgJAJQKAgkAZQIFBmFtb3VudAUJZmVlQW1vdW50BQlmZWVBbW91bnQBBGdldEQBAnhwBAN4cDAJAJEDAgUCeHAAAAQDeHAxCQCRAwIFAnhwAAEEAXMJALcCAgUDeHAwBQN4cDEDCQAAAgUBcwUEYmlnMAUEYmlnMAQBYQkBDXBhcnNlSW50VmFsdWUBBQFBBANhbm4JAGgCBQFhAAIEAXAJALwCAwUDeHAwBQN4cDEFBGJpZzEEC3hwMF94cDFfbl9uCQC8AgMFAXAFBGJpZzQFBGJpZzEEBWFubl9zCQC8AgMJALYCAQUDYW5uBQFzBQRiaWcxBAVhbm5fMQkAtgIBCQBlAgUDYW5uAAEKAQljYWxjRE5leHQBAWQEAmRkCQC8AgMFAWQFAWQFBGJpZzEEA2RkZAkAvAIDBQJkZAUBZAUEYmlnMQQCZHAJALwCAwUDZGRkBQRiaWcxBQt4cDBfeHAxX25fbgkAvAIDCQC3AgIFBWFubl9zCQC8AgMFAmRwBQRiaWcyBQRiaWcxBQFkCQC3AgIJALwCAwUFYW5uXzEFAWQFBGJpZzEJALwCAwUEYmlnMwUCZHAFBGJpZzEKAQRjYWxjAgNhY2MBaQMIBQNhY2MCXzIFA2FjYwQBZAgFA2FjYwJfMQQFZE5leHQJAQljYWxjRE5leHQBBQFkBAhkRGlmZlJhdwkAuAICBQVkTmV4dAkBBXZhbHVlAQUBZAQFZERpZmYDCQC/AgIFBGJpZzAFCGREaWZmUmF3CQC+AgEFCGREaWZmUmF3BQhkRGlmZlJhdwMJAMACAgUEYmlnMQUFZERpZmYJAJQKAgUFZE5leHQGCQCUCgIFBWROZXh0BwQDYXJyCQDMCAIAAAkAzAgCAAEJAMwIAgACCQDMCAIAAwkAzAgCAAQJAMwIAgAFCQDMCAIABgkAzAgCAAcJAMwIAgAICQDMCAIACQkAzAgCAAoJAMwIAgALCQDMCAIADAkAzAgCAA0JAMwIAgAOCQDMCAIADwkAzAgCABAJAMwIAgARBQNuaWwEDSR0MDEyNzAzMTI3NTEKAAIkbAUDYXJyCgACJHMJAJADAQUCJGwKAAUkYWNjMAkAlAoCBQFzBwoBBSRmMF8xAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQEEY2FsYwIFAiRhCQCRAwIFAiRsBQIkaQoBBSRmMF8yAgIkYQIkaQMJAGcCBQIkaQUCJHMFAiRhCQACAQIUTGlzdCBzaXplIGV4Y2VlZHMgMTgJAQUkZjBfMgIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIJAQUkZjBfMQIFBSRhY2MwAAAAAQACAAMABAAFAAYABwAIAAkACgALAAwADQAOAA8AEAARABIEAWQIBQ0kdDAxMjcwMzEyNzUxAl8xBAVmb3VuZAgFDSR0MDEyNzAzMTI3NTECXzIDBQVmb3VuZAUBZAkAAgEJAKwCAgIZRCBjYWxjdWxhdGlvbiBlcnJvciwgRCA9IAkApgMBBQFkAQNlZ28EBnR4SWQ1OApwbXRBc3NldElkCHBtdExwQW10C3VzZXJBZGRyZXNzBARscElkBQxjZmdMcEFzc2V0SWQEBGFtSWQJANgEAQkBBXZhbHVlAQUQY2ZnQW1vdW50QXNzZXRJZAQEcHJJZAkA2AQBCQEFdmFsdWUBBQ9jZmdQcmljZUFzc2V0SWQEBWFtRGNtBRZjZmdBbW91bnRBc3NldERlY2ltYWxzBAVwckRjbQUVY2ZnUHJpY2VBc3NldERlY2ltYWxzBANzdHMJAKQDAQUNY2ZnUG9vbFN0YXR1cwQHbHBFbWlzcwgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkA7AcBBQRscElkAgtXcm9uZyBMUCBpZAhxdWFudGl0eQMJAQIhPQIJANgEAQUEbHBJZAUKcG10QXNzZXRJZAkAAgECD1dyb25nIHBtdCBhc3NldAQJYW1CYWxhbmNlCQENZ2V0QWNjQmFsYW5jZQEFBGFtSWQEDGFtQmFsYW5jZVgxOAkBAnQxAgUJYW1CYWxhbmNlBQVhbURjbQQJcHJCYWxhbmNlCQENZ2V0QWNjQmFsYW5jZQEFBHBySWQEDHByQmFsYW5jZVgxOAkBAnQxAgUJcHJCYWxhbmNlBQVwckRjbQQLY3VyUHJpY2VYMTgJAQRjcGJpAgUMcHJCYWxhbmNlWDE4BQxhbUJhbGFuY2VYMTgECGN1clByaWNlCQECZjECBQtjdXJQcmljZVgxOAUGc2NhbGU4BAtwbXRMcEFtdFgxOAkBAnQxAgUIcG10THBBbXQFBnNjYWxlOAQKbHBFbWlzc1gxOAkBAnQxAgUHbHBFbWlzcwUGc2NhbGU4BAtvdXRBbUFtdFgxOAkAvAIDBQxhbUJhbGFuY2VYMTgFC3BtdExwQW10WDE4BQpscEVtaXNzWDE4BAtvdXRQckFtdFgxOAkAvAIDBQxwckJhbGFuY2VYMTgFC3BtdExwQW10WDE4BQpscEVtaXNzWDE4BAhvdXRBbUFtdAkBDGZyb21YMThSb3VuZAMFC291dEFtQW10WDE4BQVhbURjbQUFRkxPT1IECG91dFByQW10CQEMZnJvbVgxOFJvdW5kAwULb3V0UHJBbXRYMTgFBXByRGNtBQVGTE9PUgQFc3RhdGUDCQAAAgUGdHhJZDU4AgAFA25pbAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQt1c2VyQWRkcmVzcwUIb3V0QW1BbXQDCQAAAgUEYW1JZAIFV0FWRVMFBHVuaXQJANkEAQUEYW1JZAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQt1c2VyQWRkcmVzcwUIb3V0UHJBbXQDCQAAAgUEcHJJZAIFV0FWRVMFBHVuaXQJANkEAQUEcHJJZAkAzAgCCQELU3RyaW5nRW50cnkCCQEDZ2F1AgkApQgBBQt1c2VyQWRkcmVzcwUGdHhJZDU4CQERZGF0YUdldEFjdGlvbkluZm8GBQhvdXRBbUFtdAUIb3V0UHJBbXQFCHBtdExwQW10BQhjdXJQcmljZQUGaGVpZ2h0CAUJbGFzdEJsb2NrCXRpbWVzdGFtcAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAnBsAAUIY3VyUHJpY2UJAMwIAgkBDEludGVnZXJFbnRyeQIJAQJwaAIFBmhlaWdodAgFCWxhc3RCbG9jawl0aW1lc3RhbXAFCGN1clByaWNlBQNuaWwJAJwKCgUIb3V0QW1BbXQFCG91dFByQW10BQRhbUlkBQRwcklkBQlhbUJhbGFuY2UFCXByQmFsYW5jZQUHbHBFbWlzcwULY3VyUHJpY2VYMTgFA3N0cwUFc3RhdGUBA2Vwbw0GdHhJZDU4CHNsaXBwYWdlB2luQW1BbXQGaW5BbUlkB2luUHJBbXQGaW5QcklkC3VzZXJBZGRyZXNzBmlzRXZhbAZlbWl0THAKaXNPbmVBc3NldBB2YWxpZGF0ZVNsaXBwYWdlBnBtdEFtdAVwbXRJZAQEbHBJZAUMY2ZnTHBBc3NldElkBAdhbUlkU3RyCQDYBAEJAQV2YWx1ZQEFEGNmZ0Ftb3VudEFzc2V0SWQEB3BySWRTdHIJANgEAQkBBXZhbHVlAQUPY2ZnUHJpY2VBc3NldElkBAlpbkFtSWRTdHIFEmNmZ0luQW1vdW50QXNzZWRJZAQJaW5QcklkU3RyBRFjZmdJblByaWNlQXNzZXRJZAQGYW10RGNtBRZjZmdBbW91bnRBc3NldERlY2ltYWxzBAhwcmljZURjbQUVY2ZnUHJpY2VBc3NldERlY2ltYWxzBANzdHMJAKQDAQUNY2ZnUG9vbFN0YXR1cwQEbHBFbQgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkA7AcBBQRscElkAghXciBscCBhcwhxdWFudGl0eQQJYW1CYWxhbmNlAwUGaXNFdmFsCQENZ2V0QWNjQmFsYW5jZQEFB2FtSWRTdHIDAwUKaXNPbmVBc3NldAkAAAIFBXBtdElkBQdhbUlkU3RyBwkAZQIJAQ1nZXRBY2NCYWxhbmNlAQUHYW1JZFN0cgUGcG10QW10AwUKaXNPbmVBc3NldAkBDWdldEFjY0JhbGFuY2UBBQdhbUlkU3RyCQBlAgkBDWdldEFjY0JhbGFuY2UBBQdhbUlkU3RyBQdpbkFtQW10BAlwckJhbGFuY2UDBQZpc0V2YWwJAQ1nZXRBY2NCYWxhbmNlAQUHcHJJZFN0cgMDBQppc09uZUFzc2V0CQAAAgUFcG10SWQFB3BySWRTdHIHCQBlAgkBDWdldEFjY0JhbGFuY2UBBQdwcklkU3RyBQZwbXRBbXQDBQppc09uZUFzc2V0CQENZ2V0QWNjQmFsYW5jZQEFB3BySWRTdHIJAGUCCQENZ2V0QWNjQmFsYW5jZQEFB3BySWRTdHIFB2luUHJBbXQED2luQW1Bc3NldEFtdFgxOAkBAnQxAgUHaW5BbUFtdAUGYW10RGNtBA9pblByQXNzZXRBbXRYMTgJAQJ0MQIFB2luUHJBbXQFCHByaWNlRGNtBAx1c2VyUHJpY2VYMTgJAQRjcGJpAgUPaW5QckFzc2V0QW10WDE4BQ9pbkFtQXNzZXRBbXRYMTgEDGFtQmFsYW5jZVgxOAkBAnQxAgUJYW1CYWxhbmNlBQZhbXREY20EDHByQmFsYW5jZVgxOAkBAnQxAgUJcHJCYWxhbmNlBQhwcmljZURjbQQCRDAJAQRnZXREAQkAzAgCBQxhbUJhbGFuY2VYMTgJAMwIAgUMcHJCYWxhbmNlWDE4BQNuaWwEAXIDCQAAAgUEbHBFbQAABAJEMQkBBGdldEQBCQDMCAIJALcCAgUMYW1CYWxhbmNlWDE4BQ9pbkFtQXNzZXRBbXRYMTgJAMwIAgkAtwICBQxwckJhbGFuY2VYMTgFD2luUHJBc3NldEFtdFgxOAUDbmlsBAZjaGVja0QDCQC/AgIFAkQxBQJEMAYJAAIBAhxEMSBzaG91bGQgYmUgZ3JlYXRlciB0aGFuIEQwAwkAAAIFBmNoZWNrRAUGY2hlY2tEBAtjdXJQcmljZVgxOAUKemVyb0JpZ0ludAQLc2xpcHBhZ2VYMTgFCnplcm9CaWdJbnQECGxwQW10WDE4BQJEMQkAlwoFCQECZjECBQhscEFtdFgxOAUGc2NhbGU4CQECZjECBQ9pbkFtQXNzZXRBbXRYMTgFBmFtdERjbQkBAmYxAgUPaW5QckFzc2V0QW10WDE4BQhwcmljZURjbQkBBGNwYmkCCQC3AgIFDHByQmFsYW5jZVgxOAUPaW5QckFzc2V0QW10WDE4CQC3AgIFDGFtQmFsYW5jZVgxOAUPaW5BbUFzc2V0QW10WDE4BQtzbGlwcGFnZVgxOAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgQLY3VyUHJpY2VYMTgJAQRjcGJpAgUMcHJCYWxhbmNlWDE4BQxhbUJhbGFuY2VYMTgED3NsaXBwYWdlUmVhbFgxOAkAvAIDCQEDYWJzAQkAuAICBQtjdXJQcmljZVgxOAUMdXNlclByaWNlWDE4BQdzY2FsZTE4BQtjdXJQcmljZVgxOAQLc2xpcHBhZ2VYMTgJAQJ0MQIFCHNsaXBwYWdlBQZzY2FsZTgDAwMFEHZhbGlkYXRlU2xpcHBhZ2UJAQIhPQIFC2N1clByaWNlWDE4BQp6ZXJvQmlnSW50BwkAvwICBQ9zbGlwcGFnZVJlYWxYMTgFC3NsaXBwYWdlWDE4BwkAAgEJAKwCAgkArAICCQCsAgICD1ByaWNlIHNsaXBwYWdlIAkApgMBBQ9zbGlwcGFnZVJlYWxYMTgCAyA+IAkApgMBBQtzbGlwcGFnZVgxOAQNbHBFbWlzc2lvblgxOAkBAnQxAgUEbHBFbQUGc2NhbGU4BApwclZpYUFtWDE4CQC9AgQFD2luQW1Bc3NldEFtdFgxOAkBBWNwYmlyAwUMcHJCYWxhbmNlWDE4BQxhbUJhbGFuY2VYMTgFB0NFSUxJTkcFB3NjYWxlMTgFB0NFSUxJTkcECmFtVmlhUHJYMTgJAL0CBAUPaW5QckFzc2V0QW10WDE4BQdzY2FsZTE4CQEFY3BiaXIDBQxwckJhbGFuY2VYMTgFDGFtQmFsYW5jZVgxOAUFRkxPT1IFB0NFSUxJTkcEDGV4cGVjdGVkQW10cwMJAL8CAgUKcHJWaWFBbVgxOAUPaW5QckFzc2V0QW10WDE4CQCUCgIFCmFtVmlhUHJYMTgFD2luUHJBc3NldEFtdFgxOAkAlAoCBQ9pbkFtQXNzZXRBbXRYMTgFCnByVmlhQW1YMTgEEWV4cEFtdEFzc2V0QW10WDE4CAUMZXhwZWN0ZWRBbXRzAl8xBBNleHBQcmljZUFzc2V0QW10WDE4CAUMZXhwZWN0ZWRBbXRzAl8yBAJEMQkBBGdldEQBCQDMCAIJALcCAgUMYW1CYWxhbmNlWDE4BRFleHBBbXRBc3NldEFtdFgxOAkAzAgCCQC3AgIFDHByQmFsYW5jZVgxOAUTZXhwUHJpY2VBc3NldEFtdFgxOAUDbmlsBAZjaGVja0QDCQC/AgIFAkQxBQJEMAYJAAIBAhxEMSBzaG91bGQgYmUgZ3JlYXRlciB0aGFuIEQwAwkAAAIFBmNoZWNrRAUGY2hlY2tEBAhscEFtdFgxOAkAvAIDBQ1scEVtaXNzaW9uWDE4CQC4AgIFAkQxBQJEMAUCRDAJAJcKBQkBDGZyb21YMThSb3VuZAMFCGxwQW10WDE4BQZzY2FsZTgFBUZMT09SCQEMZnJvbVgxOFJvdW5kAwURZXhwQW10QXNzZXRBbXRYMTgFBmFtdERjbQUHQ0VJTElORwkBDGZyb21YMThSb3VuZAMFE2V4cFByaWNlQXNzZXRBbXRYMTgFCHByaWNlRGNtBQdDRUlMSU5HBQtjdXJQcmljZVgxOAULc2xpcHBhZ2VYMTgJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4ECWNhbGNMcEFtdAgFAXICXzEEDmNhbGNBbUFzc2V0UG10CAUBcgJfMgQOY2FsY1ByQXNzZXRQbXQIBQFyAl8zBAhjdXJQcmljZQkBAmYxAggFAXICXzQFBnNjYWxlOAQMc2xpcHBhZ2VDYWxjCQECZjECCAUBcgJfNQUGc2NhbGU4AwkAZwIAAAUJY2FsY0xwQW10CQACAQIHTFAgPD0gMAQJZW1pdExwQW10AwkBASEBBQZlbWl0THAAAAUJY2FsY0xwQW10BAZhbURpZmYJAGUCBQdpbkFtQW10BQ5jYWxjQW1Bc3NldFBtdAQGcHJEaWZmCQBlAgUHaW5QckFtdAUOY2FsY1ByQXNzZXRQbXQEDSR0MDIwNTkwMjA5MzUDAwUKaXNPbmVBc3NldAkAAAIFBXBtdElkBQdhbUlkU3RyBwkAlAoCBQZwbXRBbXQAAAMDBQppc09uZUFzc2V0CQAAAgUFcG10SWQFB3BySWRTdHIHCQCUCgIAAAUGcG10QW10CQCUCgIFDmNhbGNBbUFzc2V0UG10BQ5jYWxjUHJBc3NldFBtdAQKd3JpdGVBbUFtdAgFDSR0MDIwNTkwMjA5MzUCXzEECndyaXRlUHJBbXQIBQ0kdDAyMDU5MDIwOTM1Al8yBAtjb21tb25TdGF0ZQkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAnBsAAUIY3VyUHJpY2UJAMwIAgkBDEludGVnZXJFbnRyeQIJAQJwaAIFBmhlaWdodAgFCWxhc3RCbG9jawl0aW1lc3RhbXAFCGN1clByaWNlCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQNwYXUCBQt1c2VyQWRkcmVzcwUGdHhJZDU4CQERZGF0YVB1dEFjdGlvbkluZm8KBQp3cml0ZUFtQW10BQp3cml0ZVByQW10BQllbWl0THBBbXQFCGN1clByaWNlBQhzbGlwcGFnZQUMc2xpcHBhZ2VDYWxjBQZoZWlnaHQIBQlsYXN0QmxvY2sJdGltZXN0YW1wBQZhbURpZmYFBnByRGlmZgUDbmlsCQCfCg0FCWNhbGNMcEFtdAUJZW1pdExwQW10BQhjdXJQcmljZQUJYW1CYWxhbmNlBQlwckJhbGFuY2UFBGxwRW0FBGxwSWQFA3N0cwULY29tbW9uU3RhdGUFBmFtRGlmZgUGcHJEaWZmBQZpbkFtSWQFBmluUHJJZAEFZ2V0WUQDAnhwAWkBRAQBbgUEYmlnMgQBeAkAkQMCBQJ4cAMJAAACBQFpAAAAAQAABAphUHJlY2lzaW9uCQCnAwEFBUFtdWx0BAFhCQC5AgIJAKcDAQUBQQUKYVByZWNpc2lvbgQBcwUBeAQDYW5uCQC5AgIFAWEFAW4EAWMJALoCAgkAuQICCQC5AgIJALoCAgkAuQICBQFEBQFECQC5AgIFAXgFAW4FAUQFCmFQcmVjaXNpb24JALkCAgUDYW5uBQFuBAFiCQC4AgIJALcCAgUBcwkAugICCQC5AgIFAUQFCmFQcmVjaXNpb24FA2FubgUBRAoBBGNhbGMCA2FjYwNjdXIEDSR0MDIyMTMwMjIxNTAFA2FjYwQBeQgFDSR0MDIyMTMwMjIxNTACXzEEBWZvdW5kCAUNJHQwMjIxMzAyMjE1MAJfMgMJAQIhPQIFBWZvdW5kBQR1bml0BQNhY2MEBXlOZXh0CQC6AgIJALcCAgkAuQICBQF5BQF5BQFjCQC3AgIJALkCAgUEYmlnMgUBeQUBYgQFeURpZmYJAQlhYnNCaWdJbnQBCQC4AgIFBXlOZXh0CQEFdmFsdWUBBQF5AwkAwAICBQRiaWcxBQV5RGlmZgkAlAoCBQV5TmV4dAUDY3VyCQCUCgIFBXlOZXh0BQR1bml0BANhcnIJAMwIAgAACQDMCAIAAQkAzAgCAAIJAMwIAgADCQDMCAIABAkAzAgCAAUJAMwIAgAGCQDMCAIABwkAzAgCAAgJAMwIAgAJCQDMCAIACgkAzAgCAAsJAMwIAgAMCQDMCAIADQkAzAgCAA4FA25pbAQNJHQwMjI0NTcyMjUwNAoAAiRsBQNhcnIKAAIkcwkAkAMBBQIkbAoABSRhY2MwCQCUCgIFAUQFBHVuaXQKAQUkZjBfMQICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkBBGNhbGMCBQIkYQkAkQMCBQIkbAUCJGkKAQUkZjBfMgICJGECJGkDCQBnAgUCJGkFAiRzBQIkYQkAAgECFExpc3Qgc2l6ZSBleGNlZWRzIDE1CQEFJGYwXzICCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECCQEFJGYwXzECBQUkYWNjMAAAAAEAAgADAAQABQAGAAcACAAJAAoACwAMAA0ADgAPBAF5CAUNJHQwMjI0NTcyMjUwNAJfMQQFZm91bmQIBQ0kdDAyMjQ1NzIyNTA0Al8yAwkBAiE9AgUFZm91bmQFBHVuaXQFAXkJAAIBCQCsAgICGVkgY2FsY3VsYXRpb24gZXJyb3IsIFkgPSAJAKYDAQUBeQEHY2FsY0RMcAMNYW1vdW50QmFsYW5jZQxwcmljZUJhbGFuY2UKbHBFbWlzc2lvbgQKdXBkYXRlZERMcAkAvAIDCQEEZ2V0RAEJAMwIAgkBCHQxQmlnSW50AgUNYW1vdW50QmFsYW5jZQkAtgIBBRZjZmdBbW91bnRBc3NldERlY2ltYWxzCQDMCAIJAQh0MUJpZ0ludAIFDHByaWNlQmFsYW5jZQkAtgIBBRVjZmdQcmljZUFzc2V0RGVjaW1hbHMFA25pbAUHc2NhbGUxOAUKbHBFbWlzc2lvbgMJAAACBQpscEVtaXNzaW9uBQRiaWcwBQRiaWcwBQp1cGRhdGVkRExwAQ5jYWxjQ3VycmVudERMcAMQYW1vdW50QXNzZXREZWx0YQ9wcmljZUFzc2V0RGVsdGEUbHBBc3NldEVtaXNzaW9uRGVsdGEEEmFtb3VudEFzc2V0QmFsYW5jZQkAuAICCQC2AgEJAQ1nZXRBY2NCYWxhbmNlAQkBD2Fzc2V0SWRUb1N0cmluZwEFEGNmZ0Ftb3VudEFzc2V0SWQFEGFtb3VudEFzc2V0RGVsdGEEEXByaWNlQXNzZXRCYWxhbmNlCQC4AgIJALYCAQkBDWdldEFjY0JhbGFuY2UBCQEPYXNzZXRJZFRvU3RyaW5nAQUPY2ZnUHJpY2VBc3NldElkBQ9wcmljZUFzc2V0RGVsdGEED2xwQXNzZXRFbWlzc2lvbgkAuAICCQC2AgEICQEFdmFsdWUBCQDsBwEFDGNmZ0xwQXNzZXRJZAhxdWFudGl0eQUUbHBBc3NldEVtaXNzaW9uRGVsdGEECmN1cnJlbnRETHAJAQdjYWxjRExwAwUSYW1vdW50QXNzZXRCYWxhbmNlBRFwcmljZUFzc2V0QmFsYW5jZQUPbHBBc3NldEVtaXNzaW9uBQpjdXJyZW50RExwARJyZWZyZXNoRExwSW50ZXJuYWwDF2Ftb3VudEFzc2V0QmFsYW5jZURlbHRhFnByaWNlQXNzZXRCYWxhbmNlRGVsdGEUbHBBc3NldEVtaXNzaW9uRGVsdGEEEmFtb3VudEFzc2V0QmFsYW5jZQkAZAIJAQ1nZXRBY2NCYWxhbmNlAQkBD2Fzc2V0SWRUb1N0cmluZwEFEGNmZ0Ftb3VudEFzc2V0SWQFF2Ftb3VudEFzc2V0QmFsYW5jZURlbHRhBBFwcmljZUFzc2V0QmFsYW5jZQkAZAIJAQ1nZXRBY2NCYWxhbmNlAQkBD2Fzc2V0SWRUb1N0cmluZwEFD2NmZ1ByaWNlQXNzZXRJZAUWcHJpY2VBc3NldEJhbGFuY2VEZWx0YQQPbHBBc3NldEVtaXNzaW9uCQBkAggJAQV2YWx1ZQEJAOwHAQUMY2ZnTHBBc3NldElkCHF1YW50aXR5BRRscEFzc2V0RW1pc3Npb25EZWx0YQQKdXBkYXRlZERMcAkBB2NhbGNETHADCQC2AgEFEmFtb3VudEFzc2V0QmFsYW5jZQkAtgIBBRFwcmljZUFzc2V0QmFsYW5jZQkAtgIBBQ9scEFzc2V0RW1pc3Npb24EB2FjdGlvbnMJAMwIAgkBDEludGVnZXJFbnRyeQIFFWtleURMcFJlZnJlc2hlZEhlaWdodAUGaGVpZ2h0CQDMCAIJAQtTdHJpbmdFbnRyeQIFBmtleURMcAkApgMBBQp1cGRhdGVkRExwBQNuaWwJAJQKAgUHYWN0aW9ucwUKdXBkYXRlZERMcAESdmFsaWRhdGVVcGRhdGVkRExwAgZvbGRETHAKdXBkYXRlZERMcAMJAMACAgUKdXBkYXRlZERMcAUGb2xkRExwBgkBCHRocm93RXJyAQIidXBkYXRlZCBETHAgbG93ZXIgdGhhbiBjdXJyZW50IERMcAEbdmFsaWRhdGVNYXRjaGVyT3JkZXJBbGxvd2VkAQVvcmRlcgQSYW1vdW50QXNzZXRCYWxhbmNlCQENZ2V0QWNjQmFsYW5jZQEJAQ9hc3NldElkVG9TdHJpbmcBBRBjZmdBbW91bnRBc3NldElkBBFwcmljZUFzc2V0QmFsYW5jZQkBDWdldEFjY0JhbGFuY2UBCQEPYXNzZXRJZFRvU3RyaW5nAQUPY2ZnUHJpY2VBc3NldElkBBFhbW91bnRBc3NldEFtb3VudAgFBW9yZGVyBmFtb3VudAQQcHJpY2VBc3NldEFtb3VudAkAbgQIBQVvcmRlcgZhbW91bnQIBQVvcmRlcgVwcmljZQUGc2NhbGU4BQVGTE9PUgQNJHQwMjQ3MDIyNDkxNAMJAAACCAUFb3JkZXIJb3JkZXJUeXBlBQNCdXkJAJQKAgURYW1vdW50QXNzZXRBbW91bnQJAQEtAQUQcHJpY2VBc3NldEFtb3VudAkAlAoCCQEBLQEFEWFtb3VudEFzc2V0QW1vdW50BRBwcmljZUFzc2V0QW1vdW50BBdhbW91bnRBc3NldEJhbGFuY2VEZWx0YQgFDSR0MDI0NzAyMjQ5MTQCXzEEFnByaWNlQXNzZXRCYWxhbmNlRGVsdGEIBQ0kdDAyNDcwMjI0OTE0Al8yAwMDCQEDaWdzAAYJAAACBQ1jZmdQb29sU3RhdHVzBQ5Qb29sTWF0Y2hlckRpcwYJAAACBQ1jZmdQb29sU3RhdHVzBQxQb29sU2h1dGRvd24JAAIBAg1BZG1pbiBibG9ja2VkAwMJAQIhPQIICAUFb3JkZXIJYXNzZXRQYWlyC2Ftb3VudEFzc2V0BRBjZmdBbW91bnRBc3NldElkBgkBAiE9AggIBQVvcmRlcglhc3NldFBhaXIKcHJpY2VBc3NldAUPY2ZnUHJpY2VBc3NldElkCQACAQIJV3IgYXNzZXRzBANkTHAJAKcDAQkBC3ZhbHVlT3JFbHNlAgkAnQgCBQR0aGlzBQZrZXlETHACATAEDSR0MDI1MjU2MjUzNTYJARJyZWZyZXNoRExwSW50ZXJuYWwDBRdhbW91bnRBc3NldEJhbGFuY2VEZWx0YQUWcHJpY2VBc3NldEJhbGFuY2VEZWx0YQAABA11bnVzZWRBY3Rpb25zCAUNJHQwMjUyNTYyNTM1NgJfMQQGZExwTmV3CAUNJHQwMjUyNTYyNTM1NgJfMgQMaXNPcmRlclZhbGlkCQDAAgIFBmRMcE5ldwUDZExwBARpbmZvCQC5CQIJAMwIAgIEZExwPQkAzAgCCQCmAwEFA2RMcAkAzAgCAgggZExwTmV3PQkAzAgCCQCmAwEFBmRMcE5ldwkAzAgCAhQgYW1vdW50QXNzZXRCYWxhbmNlPQkAzAgCCQCkAwEFEmFtb3VudEFzc2V0QmFsYW5jZQkAzAgCAhMgcHJpY2VBc3NldEJhbGFuY2U9CQDMCAIJAKQDAQURcHJpY2VBc3NldEJhbGFuY2UJAMwIAgIZIGFtb3VudEFzc2V0QmFsYW5jZURlbHRhPQkAzAgCCQCkAwEFF2Ftb3VudEFzc2V0QmFsYW5jZURlbHRhCQDMCAICGCBwcmljZUFzc2V0QmFsYW5jZURlbHRhPQkAzAgCCQCkAwEFFnByaWNlQXNzZXRCYWxhbmNlRGVsdGEJAMwIAgIIIGhlaWdodD0JAMwIAgkApAMBBQZoZWlnaHQFA25pbAIACQCUCgIFDGlzT3JkZXJWYWxpZAUEaW5mbwECY2cBAWkDCQECIT0CCQCQAwEIBQFpCHBheW1lbnRzAAEJAAIBAgoxIHBtbnQgZXhwBANwbXQJAQV2YWx1ZQEJAJEDAggFAWkIcGF5bWVudHMAAAQKcG10QXNzZXRJZAkBBXZhbHVlAQgFA3BtdAdhc3NldElkBAZwbXRBbXQIBQNwbXQGYW1vdW50BAFyCQEDZWdvBAkA2AQBCAUBaQ10cmFuc2FjdGlvbklkCQDYBAEFCnBtdEFzc2V0SWQFBnBtdEFtdAgFAWkGY2FsbGVyBAhvdXRBbUFtdAgFAXICXzEECG91dFByQW10CAUBcgJfMgQDc3RzCQENcGFyc2VJbnRWYWx1ZQEIBQFyAl85BAVzdGF0ZQgFAXIDXzEwAwMJAQNpZ3MABgkAAAIFA3N0cwUMUG9vbFNodXRkb3duCQACAQkArAICAg9BZG1pbiBibG9ja2VkOiAJAKQDAQUDc3RzCQCXCgUFCG91dEFtQW10BQhvdXRQckFtdAUGcG10QW10BQpwbXRBc3NldElkBQVzdGF0ZQECY3AKBmNhbGxlcgR0eElkB2FtQXNQbXQHcHJBc1BtdAhzbGlwcGFnZQZlbWl0THAKaXNPbmVBc3NldBB2YWxpZGF0ZVNsaXBwYWdlBnBtdEFtdAVwbXRJZAQBcgkBA2Vwbw0FBHR4SWQFCHNsaXBwYWdlCAkBBXZhbHVlAQUHYW1Bc1BtdAZhbW91bnQICQEFdmFsdWUBBQdhbUFzUG10B2Fzc2V0SWQICQEFdmFsdWUBBQdwckFzUG10BmFtb3VudAgJAQV2YWx1ZQEFB3ByQXNQbXQHYXNzZXRJZAUGY2FsbGVyCQAAAgUEdHhJZAIABQZlbWl0THAFCmlzT25lQXNzZXQFEHZhbGlkYXRlU2xpcHBhZ2UFBnBtdEFtdAUFcG10SWQEA3N0cwkBDXBhcnNlSW50VmFsdWUBCAUBcgJfOAMDAwkBA2lncwAGCQAAAgUDc3RzBQpQb29sUHV0RGlzBgkAAAIFA3N0cwUMUG9vbFNodXRkb3duCQACAQkArAICAghCbG9ja2VkOgkApAMBBQNzdHMFAXIBDWNhbGNQdXRPbmVUa24FCXBtdEFtdFJhdwpwbXRBc3NldElkC3VzZXJBZGRyZXNzBHR4SWQLd2l0aFRha2VGZWUEBGFtSWQJANgEAQkBBXZhbHVlAQUQY2ZnQW1vdW50QXNzZXRJZAQEcHJJZAkA2AQBCQEFdmFsdWUBBQ9jZmdQcmljZUFzc2V0SWQEBGxwSWQFDGNmZ0xwQXNzZXRJZAQGYW10RGNtBRZjZmdBbW91bnRBc3NldERlY2ltYWxzBAhwcmljZURjbQUVY2ZnUHJpY2VBc3NldERlY2ltYWxzBA9scEFzc2V0RW1pc3Npb24JALYCAQgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkA7AcBBQRscElkAhBpbnZhbGlkIGxwIGFzc2V0CHF1YW50aXR5BA1jaGVjaEVtaXNzaW9uAwkAvwICBQ9scEFzc2V0RW1pc3Npb24FBGJpZzAGCQACAQIiaW5pdGlhbCBkZXBvc2l0IHJlcXVpcmVzIGFsbCBjb2lucwMJAAACBQ1jaGVjaEVtaXNzaW9uBQ1jaGVjaEVtaXNzaW9uBAlhbUJhbGFuY2UJAQ1nZXRBY2NCYWxhbmNlAQUEYW1JZAQJcHJCYWxhbmNlCQENZ2V0QWNjQmFsYW5jZQEFBHBySWQEDSR0MDI4MDEyMjg0NzQDCQAAAgUEdHhJZAIACQCUCgIFCWFtQmFsYW5jZQUJcHJCYWxhbmNlAwkAAAIFCnBtdEFzc2V0SWQFBGFtSWQDCQBmAgUJcG10QW10UmF3BQlhbUJhbGFuY2UJAAIBAhZpbnZhbGlkIHBheW1lbnQgYW1vdW50CQCUCgIJAGUCBQlhbUJhbGFuY2UFCXBtdEFtdFJhdwUJcHJCYWxhbmNlAwkAAAIFCnBtdEFzc2V0SWQFBHBySWQDCQBmAgUJcG10QW10UmF3BQlwckJhbGFuY2UJAAIBAhZpbnZhbGlkIHBheW1lbnQgYW1vdW50CQCUCgIFCWFtQmFsYW5jZQkAZQIFCXByQmFsYW5jZQUJcG10QW10UmF3CQACAQIQd3JvbmcgcG10QXNzZXRJZAQMYW1CYWxhbmNlT2xkCAUNJHQwMjgwMTIyODQ3NAJfMQQMcHJCYWxhbmNlT2xkCAUNJHQwMjgwMTIyODQ3NAJfMgQNJHQwMjg0ODAyODY1NgMJAAACBQpwbXRBc3NldElkBQRhbUlkCQCUCgIFCXBtdEFtdFJhdwAAAwkAAAIFCnBtdEFzc2V0SWQFBHBySWQJAJQKAgAABQlwbXRBbXRSYXcJAAIBAg9pbnZhbGlkIHBheW1lbnQEC2FtQW1vdW50UmF3CAUNJHQwMjg0ODAyODY1NgJfMQQLcHJBbW91bnRSYXcIBQ0kdDAyODQ4MDI4NjU2Al8yBA0kdDAyODY2MDI4OTE0AwULd2l0aFRha2VGZWUJAJUKAwgJAQd0YWtlRmVlAgULYW1BbW91bnRSYXcFBWluRmVlAl8xCAkBB3Rha2VGZWUCBQtwckFtb3VudFJhdwUFaW5GZWUCXzEICQEHdGFrZUZlZQIFCXBtdEFtdFJhdwUFaW5GZWUCXzIJAJUKAwULYW1BbW91bnRSYXcFC3ByQW1vdW50UmF3AAAECGFtQW1vdW50CAUNJHQwMjg2NjAyODkxNAJfMQQIcHJBbW91bnQIBQ0kdDAyODY2MDI4OTE0Al8yBAlmZWVBbW91bnQIBQ0kdDAyODY2MDI4OTE0Al8zBAxhbUJhbGFuY2VOZXcJAGQCBQxhbUJhbGFuY2VPbGQFCGFtQW1vdW50BAxwckJhbGFuY2VOZXcJAGQCBQxwckJhbGFuY2VPbGQFCHByQW1vdW50BAJEMAkBBGdldEQBCQDMCAIJAQJ0MQIFDGFtQmFsYW5jZU9sZAUWY2ZnQW1vdW50QXNzZXREZWNpbWFscwkAzAgCCQECdDECBQxwckJhbGFuY2VPbGQFFWNmZ1ByaWNlQXNzZXREZWNpbWFscwUDbmlsBAJEMQkBBGdldEQBCQDMCAIJAQJ0MQIFDGFtQmFsYW5jZU5ldwUWY2ZnQW1vdW50QXNzZXREZWNpbWFscwkAzAgCCQECdDECBQxwckJhbGFuY2VOZXcFFWNmZ1ByaWNlQXNzZXREZWNpbWFscwUDbmlsBAZjaGVja0QDCQC/AgIFAkQxBQJEMAYJAQV0aHJvdwADCQAAAgUGY2hlY2tEBQZjaGVja0QECGxwQW1vdW50CQC9AgQFD2xwQXNzZXRFbWlzc2lvbgkAuAICBQJEMQUCRDAFAkQwBQVGTE9PUgQIY3VyUHJpY2UJAQJmMQIJAQRjcGJpAgkBAnQxAgUMcHJCYWxhbmNlTmV3BQhwcmljZURjbQkBAnQxAgUMYW1CYWxhbmNlTmV3BQZhbXREY20FBnNjYWxlOAQLY29tbW9uU3RhdGUJAMwIAgkBDEludGVnZXJFbnRyeQIJAQJwbAAFCGN1clByaWNlCQDMCAIJAQxJbnRlZ2VyRW50cnkCCQECcGgCBQZoZWlnaHQIBQlsYXN0QmxvY2sJdGltZXN0YW1wBQhjdXJQcmljZQkAzAgCCQELU3RyaW5nRW50cnkCCQEDcGF1AgULdXNlckFkZHJlc3MFBHR4SWQJARFkYXRhUHV0QWN0aW9uSW5mbwoFC2FtQW1vdW50UmF3BQtwckFtb3VudFJhdwkAoAMBBQhscEFtb3VudAUIY3VyUHJpY2UAAAAABQZoZWlnaHQIBQlsYXN0QmxvY2sJdGltZXN0YW1wAAAAAAUDbmlsBA5wb29sUHJvcG9ydGlvbgkAawMFDHByQmFsYW5jZU9sZAUGc2NhbGU4BQxhbUJhbGFuY2VPbGQED2Ftb3VudEFzc2V0UGFydAkAawMFCXBtdEFtdFJhdwUGc2NhbGU4CQBkAgUOcG9vbFByb3BvcnRpb24FBnNjYWxlOAQOcHJpY2VBc3NldFBhcnQJAGUCBQlwbXRBbXRSYXcFD2Ftb3VudEFzc2V0UGFydAQJbHBBbXRCb3RoCQC8AgMFD2xwQXNzZXRFbWlzc2lvbgkAtgIBBQ5wcmljZUFzc2V0UGFydAkAtgIBBQxwckJhbGFuY2VPbGQEBWJvbnVzCQCgAwEJALwCAwkAuAICBQhscEFtb3VudAUJbHBBbXRCb3RoBQxzY2FsZThCaWdJbnQFCWxwQW10Qm90aAkAlgoECQCgAwEFCGxwQW1vdW50BQtjb21tb25TdGF0ZQUJZmVlQW1vdW50BQVib251cwkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgETZ2V0T25lVGtuVjJJbnRlcm5hbAYKb3V0QXNzZXRJZAxtaW5PdXRBbW91bnQIcGF5bWVudHMGY2FsbGVyDG9yaWdpbkNhbGxlcg10cmFuc2FjdGlvbklkBARscElkCQDYBAEJAQV2YWx1ZQEFDGNmZ0xwQXNzZXRJZAQEYW1JZAkA2AQBCQEFdmFsdWUBBRBjZmdBbW91bnRBc3NldElkBARwcklkCQDYBAEJAQV2YWx1ZQEFD2NmZ1ByaWNlQXNzZXRJZAQKYW1EZWNpbWFscwUWY2ZnQW1vdW50QXNzZXREZWNpbWFscwQKcHJEZWNpbWFscwUVY2ZnUHJpY2VBc3NldERlY2ltYWxzBApwb29sU3RhdHVzBQ1jZmdQb29sU3RhdHVzBAt1c2VyQWRkcmVzcwMJAAACBQZjYWxsZXIFDHJlc3RDb250cmFjdAUMb3JpZ2luQ2FsbGVyBQZjYWxsZXIEA3BtdAkBBXZhbHVlAQkAkQMCBQhwYXltZW50cwAABApwbXRBc3NldElkCQEFdmFsdWUBCAUDcG10B2Fzc2V0SWQEBnBtdEFtdAgFA3BtdAZhbW91bnQECmN1cnJlbnRETHAJAQ5jYWxjQ3VycmVudERMcAMFBGJpZzAFBGJpZzAFBGJpZzADCQAAAgUKY3VycmVudERMcAUKY3VycmVudERMcAQGdHhJZDU4CQDYBAEFDXRyYW5zYWN0aW9uSWQDCQECIT0CBQRscElkCQDYBAEFCnBtdEFzc2V0SWQJAAIBAghXcm9uZyBMUAQJYW1CYWxhbmNlCQENZ2V0QWNjQmFsYW5jZQEFBGFtSWQECXByQmFsYW5jZQkBDWdldEFjY0JhbGFuY2UBBQRwcklkBA0kdDAzMTAyNjMxMTM3CgABQAkA/AcEBQR0aGlzAhNnZXRPbmVUa25WMlJFQURPTkxZCQDMCAIFCm91dEFzc2V0SWQJAMwIAgUGcG10QW10BQNuaWwFA25pbAMJAAECBQFAAgooSW50LCBJbnQpBQFACQACAQkArAICCQADAQUBQAIfIGNvdWxkbid0IGJlIGNhc3QgdG8gKEludCwgSW50KQMJAAACBQ0kdDAzMTAyNjMxMTM3BQ0kdDAzMTAyNjMxMTM3BAlmZWVBbW91bnQIBQ0kdDAzMTAyNjMxMTM3Al8yBAh0b3RhbEdldAgFDSR0MDMxMDI2MzExMzcCXzEEC3RvdGFsQW1vdW50AwMJAGYCBQxtaW5PdXRBbW91bnQAAAkAZgIFDG1pbk91dEFtb3VudAUIdG90YWxHZXQHCQEIdGhyb3dFcnIBCQC5CQIJAMwIAgIfYW1vdW50IHRvIHJlY2VpdmUgaXMgbGVzcyB0aGFuIAkAzAgCCQCkAwEFDG1pbk91dEFtb3VudAUDbmlsAgAFCHRvdGFsR2V0BA0kdDAzMTMyNzMxNjM0AwkAAAIFCm91dEFzc2V0SWQFBGFtSWQJAJYKBAULdG90YWxBbW91bnQAAAkAZQIJAGUCBQlhbUJhbGFuY2UFC3RvdGFsQW1vdW50BQlmZWVBbW91bnQFCXByQmFsYW5jZQMJAAACBQpvdXRBc3NldElkBQRwcklkCQCWCgQAAAULdG90YWxBbW91bnQFCWFtQmFsYW5jZQkAZQIJAGUCBQlwckJhbGFuY2UFC3RvdGFsQW1vdW50BQlmZWVBbW91bnQJAAIBAhRpbnZhbGlkIG91dCBhc3NldCBpZAQFb3V0QW0IBQ0kdDAzMTMyNzMxNjM0Al8xBAVvdXRQcggFDSR0MDMxMzI3MzE2MzQCXzIEDGFtQmFsYW5jZU5ldwgFDSR0MDMxMzI3MzE2MzQCXzMEDHByQmFsYW5jZU5ldwgFDSR0MDMxMzI3MzE2MzQCXzQECGN1clByWDE4CQEEY3BiaQIJAQJ0MQIFDHByQmFsYW5jZU5ldwUKcHJEZWNpbWFscwkBAnQxAgUMYW1CYWxhbmNlTmV3BQphbURlY2ltYWxzBAVjdXJQcgkBAmYxAgUIY3VyUHJYMTgFBnNjYWxlOAQRb3V0QXNzZXRJZE9yV2F2ZXMDCQAAAgUKb3V0QXNzZXRJZAIFV0FWRVMFBHVuaXQJANkEAQUKb3V0QXNzZXRJZAQQc2VuZEZlZVRvTWF0Y2hlcgMJAGYCBQlmZWVBbW91bnQAAAkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBRNmZWVDb2xsZWN0b3JBZGRyZXNzBQlmZWVBbW91bnQFEW91dEFzc2V0SWRPcldhdmVzBQNuaWwFA25pbAQFc3RhdGUJAM4IAgkAzAgCCQEOU2NyaXB0VHJhbnNmZXIDBQt1c2VyQWRkcmVzcwULdG90YWxBbW91bnQFEW91dEFzc2V0SWRPcldhdmVzCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQNnYXUCCQClCAEFC3VzZXJBZGRyZXNzBQZ0eElkNTgJARFkYXRhR2V0QWN0aW9uSW5mbwYFBW91dEFtBQVvdXRQcgUGcG10QW10BQVjdXJQcgUGaGVpZ2h0CAUJbGFzdEJsb2NrCXRpbWVzdGFtcAkAzAgCCQEMSW50ZWdlckVudHJ5AgkBAnBsAAUFY3VyUHIJAMwIAgkBDEludGVnZXJFbnRyeQIJAQJwaAIFBmhlaWdodAgFCWxhc3RCbG9jawl0aW1lc3RhbXAFBWN1clByBQNuaWwFEHNlbmRGZWVUb01hdGNoZXIDCQAAAgUFc3RhdGUFBXN0YXRlBARidXJuCQD8BwQFA2ZjYQIEYnVybgkAzAgCBQZwbXRBbXQFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUKcG10QXNzZXRJZAUGcG10QW10BQNuaWwDCQAAAgUEYnVybgUEYnVybgQNJHQwMzI0MTkzMjc2OQQQZmVlQW1vdW50Rm9yQ2FsYwMJAAACBQR0aGlzBRNmZWVDb2xsZWN0b3JBZGRyZXNzAAAFCWZlZUFtb3VudAQQb3V0SW5BbW91bnRBc3NldAMJAAACCQEMcGFyc2VBc3NldElkAQUKb3V0QXNzZXRJZAUQY2ZnQW1vdW50QXNzZXRJZAYHAwUQb3V0SW5BbW91bnRBc3NldAkAlAoCCQEBLQEJAGQCBQh0b3RhbEdldAUQZmVlQW1vdW50Rm9yQ2FsYwAACQCUCgIAAAkBAS0BCQBkAgUIdG90YWxHZXQFEGZlZUFtb3VudEZvckNhbGMEF2Ftb3VudEFzc2V0QmFsYW5jZURlbHRhCAUNJHQwMzI0MTkzMjc2OQJfMQQWcHJpY2VBc3NldEJhbGFuY2VEZWx0YQgFDSR0MDMyNDE5MzI3NjkCXzIEDSR0MDMyNzcyMzI4ODAJARJyZWZyZXNoRExwSW50ZXJuYWwDBRdhbW91bnRBc3NldEJhbGFuY2VEZWx0YQUWcHJpY2VBc3NldEJhbGFuY2VEZWx0YQAABBFyZWZyZXNoRExwQWN0aW9ucwgFDSR0MDMyNzcyMzI4ODACXzEECnVwZGF0ZWRETHAIBQ0kdDAzMjc3MjMyODgwAl8yBBFpc1VwZGF0ZWRETHBWYWxpZAkBEnZhbGlkYXRlVXBkYXRlZERMcAIFCmN1cnJlbnRETHAFCnVwZGF0ZWRETHADCQAAAgURaXNVcGRhdGVkRExwVmFsaWQFEWlzVXBkYXRlZERMcFZhbGlkCQCUCgIJAM4IAgUFc3RhdGUFEXJlZnJlc2hETHBBY3Rpb25zBQt0b3RhbEFtb3VudAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgEBbQAEByRtYXRjaDAJAKIIAQkBA21wawADCQABAgUHJG1hdGNoMAIGU3RyaW5nBAFzBQckbWF0Y2gwCQDZBAEFAXMDCQABAgUHJG1hdGNoMAIEVW5pdAUEdW5pdAkAAgECC01hdGNoIGVycm9yAQJwbQAEByRtYXRjaDAJAKIIAQkBBHBtcGsAAwkAAQIFByRtYXRjaDACBlN0cmluZwQBcwUHJG1hdGNoMAkA2QQBBQFzAwkAAQIFByRtYXRjaDACBFVuaXQFBHVuaXQJAAIBAgtNYXRjaCBlcnJvcgACcGQJAAIBAhFQZXJtaXNzaW9uIGRlbmllZAEJaXNNYW5hZ2VyAQFpBAckbWF0Y2gwCQEBbQADCQABAgUHJG1hdGNoMAIKQnl0ZVZlY3RvcgQCcGsFByRtYXRjaDAJAAACCAUBaQ9jYWxsZXJQdWJsaWNLZXkFAnBrAwkAAQIFByRtYXRjaDACBFVuaXQJAAACCAUBaQZjYWxsZXIFBHRoaXMJAAIBAgtNYXRjaCBlcnJvcgECbW0BAWkEByRtYXRjaDAJAQFtAAMJAAECBQckbWF0Y2gwAgpCeXRlVmVjdG9yBAJwawUHJG1hdGNoMAMJAAACCAUBaQ9jYWxsZXJQdWJsaWNLZXkFAnBrBgUCcGQDCQABAgUHJG1hdGNoMAIEVW5pdAMJAAACCAUBaQZjYWxsZXIFBHRoaXMGBQJwZAkAAgECC01hdGNoIGVycm9yAQRnZXRZAwlpc1JldmVyc2UBRBNwb29sQW1vdW50SW5CYWxhbmNlBApwb29sQ29uZmlnCQEDZ3BjAAQEYW1JZAkAkQMCBQpwb29sQ29uZmlnBQlpZHhBbUFzSWQEBHBySWQJAJEDAgUKcG9vbENvbmZpZwUJaWR4UHJBc0lkBAFuBQRiaWcyBAphUHJlY2lzaW9uCQCnAwEFBUFtdWx0BAFhCQC5AgIJAKcDAQUBQQUKYVByZWNpc2lvbgQCeHADCQAAAgUJaXNSZXZlcnNlBwkAzAgCCQC3AgIJALYCAQkBDWdldEFjY0JhbGFuY2UBBQRhbUlkBRNwb29sQW1vdW50SW5CYWxhbmNlCQDMCAIJALYCAQkBDWdldEFjY0JhbGFuY2UBBQRwcklkBQNuaWwJAMwIAgkAtwICCQC2AgEJAQ1nZXRBY2NCYWxhbmNlAQUEcHJJZAUTcG9vbEFtb3VudEluQmFsYW5jZQkAzAgCCQC2AgEJAQ1nZXRBY2NCYWxhbmNlAQUEYW1JZAUDbmlsBAF4CQCRAwIFAnhwAAAEAXMFAXgEA2FubgkAuQICBQFhBQFuBAFjCQC6AgIJALkCAgkAuQICCQC6AgIJALkCAgUBRAUBRAkAuQICBQF4BQFuBQFEBQphUHJlY2lzaW9uCQC5AgIFA2FubgUBbgQBYgkAuAICCQC3AgIFAXMJALoCAgkAuQICBQFEBQphUHJlY2lzaW9uBQNhbm4FAUQKAQRjYWxjAgNhY2MDY3VyBA0kdDAzNDMyNzM0MzQ3BQNhY2MEAXkIBQ0kdDAzNDMyNzM0MzQ3Al8xBAVmb3VuZAgFDSR0MDM0MzI3MzQzNDcCXzIDCQECIT0CBQVmb3VuZAUEdW5pdAUDYWNjBAV5TmV4dAkAugICCQC3AgIJALkCAgUBeQUBeQUBYwkAtwICCQC5AgIFBGJpZzIFAXkFAWIEBXlEaWZmCQEJYWJzQmlnSW50AQkAuAICBQV5TmV4dAkBBXZhbHVlAQUBeQMJAMACAgUEYmlnMQUFeURpZmYJAJQKAgUFeU5leHQFA2N1cgkAlAoCBQV5TmV4dAUEdW5pdAQDYXJyCQDMCAIAAAkAzAgCAAEJAMwIAgACCQDMCAIAAwkAzAgCAAQJAMwIAgAFCQDMCAIABgkAzAgCAAcJAMwIAgAICQDMCAIACQkAzAgCAAoJAMwIAgALCQDMCAIADAkAzAgCAA0JAMwIAgAOBQNuaWwEDSR0MDM0Njc4MzQ3MjUKAAIkbAUDYXJyCgACJHMJAJADAQUCJGwKAAUkYWNjMAkAlAoCBQFEBQR1bml0CgEFJGYwXzECAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAQRjYWxjAgUCJGEJAJEDAgUCJGwFAiRpCgEFJGYwXzICAiRhAiRpAwkAZwIFAiRpBQIkcwUCJGEJAAIBAhRMaXN0IHNpemUgZXhjZWVkcyAxNQkBBSRmMF8yAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgkBBSRmMF8xAgUFJGFjYzAAAAABAAIAAwAEAAUABgAHAAgACQAKAAsADAANAA4ADwQBeQgFDSR0MDM0Njc4MzQ3MjUCXzEEBWZvdW5kCAUNJHQwMzQ2NzgzNDcyNQJfMgMJAQIhPQIFBWZvdW5kBQR1bml0BQF5CQACAQkArAICAhlZIGNhbGN1bGF0aW9uIGVycm9yLCBZID0gCQCmAwEFAXkeAWkBIWNhbGN1bGF0ZUFtb3VudE91dEZvclN3YXBSRUFET05MWQMNY2xlYW5BbW91bnRJbglpc1JldmVyc2UNZmVlUG9vbEFtb3VudAQNJHQwMzQ5NjYzNTM5MAMJAAACBQlpc1JldmVyc2UHBAhhc3NldE91dAkBBHN0cmYCBQR0aGlzCQECcGEABBNwb29sQW1vdW50SW5CYWxhbmNlCQC3AgIJALYCAQkBDWdldEFjY0JhbGFuY2UBCQEEc3RyZgIFBHRoaXMJAQJhYQAJALYCAQUNY2xlYW5BbW91bnRJbgkAlAoCBQhhc3NldE91dAUTcG9vbEFtb3VudEluQmFsYW5jZQQIYXNzZXRPdXQJAQRzdHJmAgUEdGhpcwkBAmFhAAQTcG9vbEFtb3VudEluQmFsYW5jZQkAtwICCQC2AgEJAQ1nZXRBY2NCYWxhbmNlAQkBBHN0cmYCBQR0aGlzCQECcGEACQC2AgEFDWNsZWFuQW1vdW50SW4JAJQKAgUIYXNzZXRPdXQFE3Bvb2xBbW91bnRJbkJhbGFuY2UECGFzc2V0T3V0CAUNJHQwMzQ5NjYzNTM5MAJfMQQTcG9vbEFtb3VudEluQmFsYW5jZQgFDSR0MDM0OTY2MzUzOTACXzIECnBvb2xDb25maWcJAQNncGMABARhbUlkCQCRAwIFCnBvb2xDb25maWcFCWlkeEFtQXNJZAQEcHJJZAkAkQMCBQpwb29sQ29uZmlnBQlpZHhQckFzSWQEAnhwCQDMCAIJALYCAQkBDWdldEFjY0JhbGFuY2UBBQRhbUlkCQDMCAIJALYCAQkBDWdldEFjY0JhbGFuY2UBBQRwcklkBQNuaWwEAUQJAQRnZXREAQUCeHAEAXkJAQRnZXRZAwUJaXNSZXZlcnNlBQFECQC2AgEFDWNsZWFuQW1vdW50SW4EAmR5CQC4AgIJALgCAgkAtgIBCQENZ2V0QWNjQmFsYW5jZQEFCGFzc2V0T3V0BQF5CQC2AgEAAQQLdG90YWxHZXRSYXcJAJYDAQkAzAgCAAAJAMwIAgkAoAMBBQJkeQUDbmlsBAVuZXdYcAMJAAACBQlpc1JldmVyc2UHCQDMCAIJALcCAgkAtwICCQC2AgEJAQ1nZXRBY2NCYWxhbmNlAQUEYW1JZAkAtgIBBQ1jbGVhbkFtb3VudEluCQC2AgEFDWZlZVBvb2xBbW91bnQJAMwIAgkAuAICCQC2AgEJAQ1nZXRBY2NCYWxhbmNlAQUEcHJJZAUCZHkFA25pbAkAzAgCCQC4AgIJALYCAQkBDWdldEFjY0JhbGFuY2UBBQRhbUlkBQJkeQkAzAgCCQC3AgIJALcCAgkAtgIBCQENZ2V0QWNjQmFsYW5jZQEFBHBySWQJALYCAQUNY2xlYW5BbW91bnRJbgkAtgIBBQ1mZWVQb29sQW1vdW50BQNuaWwEBG5ld0QJAQRnZXREAQUFbmV3WHAEBmNoZWNrRAMJAMACAgUEbmV3RAUBRAYJAAIBCQC5CQIJAMwIAgIUbmV3IEQgaXMgZmV3ZXIgZXJyb3IJAMwIAgkApgMBBQFECQDMCAIJAKYDAQUEbmV3RAUDbmlsAgJfXwMJAAACBQZjaGVja0QFBmNoZWNrRAkAlAoCBQNuaWwFC3RvdGFsR2V0UmF3CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBJmNhbGN1bGF0ZUFtb3VudE91dEZvclN3YXBBbmRTZW5kVG9rZW5zBQ1jbGVhbkFtb3VudEluCWlzUmV2ZXJzZQxhbW91bnRPdXRNaW4JYWRkcmVzc1RvDWZlZVBvb2xBbW91bnQEC3N3YXBDb250YWN0CgABQAkA/AcEBQNmY2ECF2dldFN3YXBDb250cmFjdFJFQURPTkxZBQNuaWwFA25pbAMJAAECBQFAAgZTdHJpbmcFAUAJAAIBCQCsAgIJAAMBBQFAAhsgY291bGRuJ3QgYmUgY2FzdCB0byBTdHJpbmcEBmNoZWNrcwkAzAgCAwkAZwIICQEFdmFsdWUBCQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50BQ1jbGVhbkFtb3VudEluBgkBCHRocm93RXJyAQIMV3JvbmcgYW1vdW50CQDMCAIDCQAAAggFAWkGY2FsbGVyCQERQGV4dHJOYXRpdmUoMTA2MikBBQtzd2FwQ29udGFjdAYJAQh0aHJvd0VycgECEVBlcm1pc3Npb24gZGVuaWVkBQNuaWwDCQAAAgUGY2hlY2tzBQZjaGVja3MEA3BtdAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwAABAdhc3NldEluCQEPYXNzZXRJZFRvU3RyaW5nAQgFA3BtdAdhc3NldElkBA0kdDAzNjgyNjM3MjIwAwkAAAIFCWlzUmV2ZXJzZQcECGFzc2V0T3V0CQEEc3RyZgIFBHRoaXMJAQJwYQAEE3Bvb2xBbW91bnRJbkJhbGFuY2UJAGUCCQENZ2V0QWNjQmFsYW5jZQEFB2Fzc2V0SW4ICQEFdmFsdWUBCQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50CQCUCgIFCGFzc2V0T3V0BRNwb29sQW1vdW50SW5CYWxhbmNlBAhhc3NldE91dAkBBHN0cmYCBQR0aGlzCQECYWEABBNwb29sQW1vdW50SW5CYWxhbmNlCQBlAgkBDWdldEFjY0JhbGFuY2UBBQdhc3NldEluCAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAkAlAoCBQhhc3NldE91dAUTcG9vbEFtb3VudEluQmFsYW5jZQQIYXNzZXRPdXQIBQ0kdDAzNjgyNjM3MjIwAl8xBBNwb29sQW1vdW50SW5CYWxhbmNlCAUNJHQwMzY4MjYzNzIyMAJfMgQKcG9vbENvbmZpZwkBA2dwYwAEBGFtSWQJAJEDAgUKcG9vbENvbmZpZwUJaWR4QW1Bc0lkBARwcklkCQCRAwIFCnBvb2xDb25maWcFCWlkeFByQXNJZAQCeHADCQAAAgUJaXNSZXZlcnNlBwkAzAgCCQC4AgIJALYCAQkBDWdldEFjY0JhbGFuY2UBBQRhbUlkCQC2AgEICQEFdmFsdWUBCQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50CQDMCAIJALYCAQkBDWdldEFjY0JhbGFuY2UBBQRwcklkBQNuaWwJAMwIAgkAtgIBCQENZ2V0QWNjQmFsYW5jZQEFBGFtSWQJAMwIAgkAuAICCQC2AgEJAQ1nZXRBY2NCYWxhbmNlAQUEcHJJZAkAtgIBCAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAUDbmlsBAFECQEEZ2V0RAEFAnhwBAF5CQEEZ2V0WQMFCWlzUmV2ZXJzZQUBRAkAtgIBAAAEAmR5CQC4AgIJALgCAgkAtgIBCQENZ2V0QWNjQmFsYW5jZQEFCGFzc2V0T3V0BQF5CQC2AgEAAQQLdG90YWxHZXRSYXcJAJYDAQkAzAgCAAAJAMwIAgkAoAMBBQJkeQUDbmlsBAhjaGVja01pbgMJAGcCBQt0b3RhbEdldFJhdwUMYW1vdW50T3V0TWluBgkAAgECLEV4Y2hhbmdlIHJlc3VsdCBpcyBmZXdlciBjb2lucyB0aGFuIGV4cGVjdGVkAwkAAAIFCGNoZWNrTWluBQhjaGVja01pbgQFbmV3WHADCQAAAgUJaXNSZXZlcnNlBwkAzAgCCQC3AgIJALYCAQkBDWdldEFjY0JhbGFuY2UBBQRhbUlkCQC2AgEFDWZlZVBvb2xBbW91bnQJAMwIAgkAuAICCQC2AgEJAQ1nZXRBY2NCYWxhbmNlAQUEcHJJZAUCZHkFA25pbAkAzAgCCQC4AgIJALYCAQkBDWdldEFjY0JhbGFuY2UBBQRhbUlkBQJkeQkAzAgCCQC3AgIJALYCAQkBDWdldEFjY0JhbGFuY2UBBQRwcklkCQC2AgEFDWZlZVBvb2xBbW91bnQFA25pbAQEbmV3RAkBBGdldEQBBQVuZXdYcAQGY2hlY2tEAwkAwAICBQRuZXdEBQFEBgkAAgECFG5ldyBEIGlzIGZld2VyIGVycm9yAwkAAAIFBmNoZWNrRAUGY2hlY2tECQCUCgIJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwkBEUBleHRyTmF0aXZlKDEwNjIpAQUJYWRkcmVzc1RvBQt0b3RhbEdldFJhdwkBDHBhcnNlQXNzZXRJZAEFCGFzc2V0T3V0BQNuaWwFC3RvdGFsR2V0UmF3CQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBC2NvbnN0cnVjdG9yAQJmYwQBYwkBAm1tAQUBaQMJAAACBQFjBQFjCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJmYwAFAmZjBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEKc2V0TWFuYWdlcgEXcGVuZGluZ01hbmFnZXJQdWJsaWNLZXkEAWMJAQJtbQEFAWkDCQAAAgUBYwUBYwQCY20JANkEAQUXcGVuZGluZ01hbmFnZXJQdWJsaWNLZXkDCQAAAgUCY20FAmNtCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQRwbXBrAAUXcGVuZGluZ01hbmFnZXJQdWJsaWNLZXkFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQ5jb25maXJtTWFuYWdlcgAEAXAJAQJwbQAEA2hwbQMJAQlpc0RlZmluZWQBBQFwBgkAAgECEk5vIHBlbmRpbmcgbWFuYWdlcgMJAAACBQNocG0FA2hwbQQDY3BtAwkAAAIIBQFpD2NhbGxlclB1YmxpY0tleQkBBXZhbHVlAQUBcAYJAAIBAhtZb3UgYXJlIG5vdCBwZW5kaW5nIG1hbmFnZXIDCQAAAgUDY3BtBQNjcG0JAMwIAgkBC1N0cmluZ0VudHJ5AgkBA21wawAJANgEAQkBBXZhbHVlAQUBcAkAzAgCCQELRGVsZXRlRW50cnkBCQEEcG1wawAFA25pbAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQNwdXQCBHNsaXAJYXV0b1N0YWtlBAdmYWN0Q2ZnCQEDZ2ZjAAQLc3Rha2luZ0NudHIJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQCRAwIFB2ZhY3RDZmcFD2lkeEZhY3RTdGFrQ250cgIKV3Igc3QgYWRkcgQIc2xpcENudHIJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQCRAwIFB2ZhY3RDZmcFEGlkeEZhY3RTbGlwcENudHICCldyIHNsIGFkZHIDCQBmAgAABQRzbGlwCQACAQIOV3Jvbmcgc2xpcHBhZ2UDCQECIT0CCQCQAwEIBQFpCHBheW1lbnRzAAIJAAIBAgwyIHBtbnRzIGV4cGQECmFtQXNzZXRQbXQJALYCAQgJAQV2YWx1ZQEJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQECnByQXNzZXRQbXQJALYCAQgJAQV2YWx1ZQEJAJEDAggFAWkIcGF5bWVudHMAAQZhbW91bnQEEmFtb3VudEFzc2V0QmFsYW5jZQkAuAICCQC2AgEJAQ1nZXRBY2NCYWxhbmNlAQkBD2Fzc2V0SWRUb1N0cmluZwEFEGNmZ0Ftb3VudEFzc2V0SWQFCmFtQXNzZXRQbXQDCQAAAgUSYW1vdW50QXNzZXRCYWxhbmNlBRJhbW91bnRBc3NldEJhbGFuY2UEEXByaWNlQXNzZXRCYWxhbmNlCQC4AgIJALYCAQkBDWdldEFjY0JhbGFuY2UBCQEPYXNzZXRJZFRvU3RyaW5nAQUPY2ZnUHJpY2VBc3NldElkBQpwckFzc2V0UG10AwkAAAIFEXByaWNlQXNzZXRCYWxhbmNlBRFwcmljZUFzc2V0QmFsYW5jZQQPbHBBc3NldEVtaXNzaW9uCQC2AgEICQEFdmFsdWUBCQDsBwEFDGNmZ0xwQXNzZXRJZAhxdWFudGl0eQMJAAACBQ9scEFzc2V0RW1pc3Npb24FD2xwQXNzZXRFbWlzc2lvbgQKY3VycmVudERMcAkBDmNhbGNDdXJyZW50RExwAwUKYW1Bc3NldFBtdAUKcHJBc3NldFBtdAkAtgIBAAADCQAAAgUKY3VycmVudERMcAUKY3VycmVudERMcAQBZQkBAmNwCgkApQgBCAUBaQZjYWxsZXIJANgEAQgFAWkNdHJhbnNhY3Rpb25JZAkBD0F0dGFjaGVkUGF5bWVudAIICQEFdmFsdWUBCQCRAwIIBQFpCHBheW1lbnRzAAAHYXNzZXRJZAgJAQV2YWx1ZQEJAJEDAggFAWkIcGF5bWVudHMAAAZhbW91bnQJAJEDAggFAWkIcGF5bWVudHMAAQUEc2xpcAYHBgAAAgAECWVtaXRMcEFtdAgFAWUCXzIECWxwQXNzZXRJZAgFAWUCXzcEBXN0YXRlCAUBZQJfOQQGYW1EaWZmCAUBZQNfMTAEBnByRGlmZggFAWUDXzExBARhbUlkCAUBZQNfMTIEBHBySWQIBQFlA18xMwQBcgkA/AcEBQNmY2ECBGVtaXQJAMwIAgUJZW1pdExwQW10BQNuaWwFA25pbAMJAAACBQFyBQFyBAJlbAQHJG1hdGNoMAUBcgMJAAECBQckbWF0Y2gwAgdBZGRyZXNzBAZsZWdhY3kFByRtYXRjaDAJAPwHBAUGbGVnYWN5AgRlbWl0CQDMCAIFCWVtaXRMcEFtdAUDbmlsBQNuaWwFBHVuaXQDCQAAAgUCZWwFAmVsBAJzYQMJAGYCBQZhbURpZmYAAAkA/AcEBQhzbGlwQ250cgIDcHV0BQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFBGFtSWQFBmFtRGlmZgUDbmlsBQNuaWwDCQAAAgUCc2EFAnNhBAJzcAMJAGYCBQZwckRpZmYAAAkA/AcEBQhzbGlwQ250cgIDcHV0BQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFBHBySWQFBnByRGlmZgUDbmlsBQNuaWwDCQAAAgUCc3AFAnNwBAhscFRybnNmcgMFCWF1dG9TdGFrZQQCc3MJAPwHBAULc3Rha2luZ0NudHICBXN0YWtlBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFCWxwQXNzZXRJZAUJZW1pdExwQW10BQNuaWwDCQAAAgUCc3MFAnNzBQNuaWwJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwgFAWkGY2FsbGVyBQllbWl0THBBbXQFCWxwQXNzZXRJZAUDbmlsBA0kdDA0MTgzOTQxOTgxCQEScmVmcmVzaERMcEludGVybmFsAwAAAAAAAAQRcmVmcmVzaERMcEFjdGlvbnMIBQ0kdDA0MTgzOTQxOTgxAl8xBAp1cGRhdGVkRExwCAUNJHQwNDE4Mzk0MTk4MQJfMgQFY2hlY2sDCQDAAgIFCnVwZGF0ZWRETHAFCmN1cnJlbnRETHAGCQEIdGhyb3dFcnIBCQC5CQIJAMwIAgIidXBkYXRlZCBETHAgbG93ZXIgdGhhbiBjdXJyZW50IERMcAkAzAgCCQCmAwEFEmFtb3VudEFzc2V0QmFsYW5jZQkAzAgCCQCmAwEFEXByaWNlQXNzZXRCYWxhbmNlCQDMCAIJAKYDAQUPbHBBc3NldEVtaXNzaW9uCQDMCAIJAKYDAQUKY3VycmVudERMcAkAzAgCCQCmAwEFCnVwZGF0ZWRETHAJAMwIAgkApAMBBQZhbURpZmYJAMwIAgkApAMBBQZwckRpZmYFA25pbAIBIAMJAAACBQVjaGVjawUFY2hlY2sEFGxwQXNzZXRFbWlzc2lvbkFmdGVyCAkBBXZhbHVlAQkA7AcBBQxjZmdMcEFzc2V0SWQIcXVhbnRpdHkDCQAAAgUUbHBBc3NldEVtaXNzaW9uQWZ0ZXIFFGxwQXNzZXRFbWlzc2lvbkFmdGVyCQDOCAIJAM4IAgUFc3RhdGUFCGxwVHJuc2ZyBRFyZWZyZXNoRExwQWN0aW9ucwkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpAQtwdXRPbmVUa25WMgIMbWluT3V0QW1vdW50CWF1dG9TdGFrZQQgaXNQb29sT25lVG9rZW5PcGVyYXRpb25zRGlzYWJsZWQKAAFACQD8BwQFA2ZjYQIoaXNQb29sT25lVG9rZW5PcGVyYXRpb25zRGlzYWJsZWRSRUFET05MWQkAzAgCCQClCAEFBHRoaXMFA25pbAUDbmlsAwkAAQIFAUACB0Jvb2xlYW4FAUAJAAIBCQCsAgIJAAMBBQFAAhwgY291bGRuJ3QgYmUgY2FzdCB0byBCb29sZWFuBA1pc1B1dERpc2FibGVkAwMDCQEDaWdzAAYJAAACBQ1jZmdQb29sU3RhdHVzBQpQb29sUHV0RGlzBgkAAAIFDWNmZ1Bvb2xTdGF0dXMFDFBvb2xTaHV0ZG93bgYFIGlzUG9vbE9uZVRva2VuT3BlcmF0aW9uc0Rpc2FibGVkBAZjaGVja3MJAMwIAgMDCQEBIQEFDWlzUHV0RGlzYWJsZWQGCQEJaXNNYW5hZ2VyAQUBaQYJAQh0aHJvd0VycgECIXB1dCBvcGVyYXRpb24gaXMgYmxvY2tlZCBieSBhZG1pbgkAzAgCAwkAAAIJAJADAQgFAWkIcGF5bWVudHMAAQYJAQh0aHJvd0VycgECHmV4YWN0bHkgMSBwYXltZW50IGFyZSBleHBlY3RlZAUDbmlsAwkAAAIFBmNoZWNrcwUGY2hlY2tzBARhbUlkCQDYBAEJAQV2YWx1ZQEFEGNmZ0Ftb3VudEFzc2V0SWQEBHBySWQJANgEAQkBBXZhbHVlAQUPY2ZnUHJpY2VBc3NldElkBARscElkBQxjZmdMcEFzc2V0SWQECmFtRGVjaW1hbHMFFmNmZ0Ftb3VudEFzc2V0RGVjaW1hbHMECnByRGVjaW1hbHMFFWNmZ1ByaWNlQXNzZXREZWNpbWFscwQLdXNlckFkZHJlc3MDCQAAAggFAWkGY2FsbGVyBQR0aGlzCAUBaQxvcmlnaW5DYWxsZXIIBQFpBmNhbGxlcgQDcG10CQEFdmFsdWUBCQCRAwIIBQFpCHBheW1lbnRzAAAECnBtdEFzc2V0SWQJANgEAQkBBXZhbHVlAQgFA3BtdAdhc3NldElkBAZwbXRBbXQIBQNwbXQGYW1vdW50BApjdXJyZW50RExwAwkAAAIIBQNwbXQHYXNzZXRJZAUQY2ZnQW1vdW50QXNzZXRJZAkBDmNhbGNDdXJyZW50RExwAwkAtgIBBQZwbXRBbXQJALYCAQAACQC2AgEAAAkBDmNhbGNDdXJyZW50RExwAwkAtgIBAAAJALYCAQUGcG10QW10CQC2AgEAAAMJAAACBQpjdXJyZW50RExwBQpjdXJyZW50RExwBA0kdDA0MzYyMjQzNzgwCQENY2FsY1B1dE9uZVRrbgUFBnBtdEFtdAUKcG10QXNzZXRJZAkApQgBBQt1c2VyQWRkcmVzcwkA2AQBCAUBaQ10cmFuc2FjdGlvbklkBgMJAAACBQ0kdDA0MzYyMjQzNzgwBQ0kdDA0MzYyMjQzNzgwBAlmZWVBbW91bnQIBQ0kdDA0MzYyMjQzNzgwAl8zBAVzdGF0ZQgFDSR0MDQzNjIyNDM3ODACXzIEB2VzdGltTFAIBQ0kdDA0MzYyMjQzNzgwAl8xBAllbWl0THBBbXQDAwkAZgIFDG1pbk91dEFtb3VudAAACQBmAgUMbWluT3V0QW1vdW50BQdlc3RpbUxQBwkBCHRocm93RXJyAQkAuQkCCQDMCAICH2Ftb3VudCB0byByZWNlaXZlIGlzIGxlc3MgdGhhbiAJAMwIAgkApAMBBQxtaW5PdXRBbW91bnQFA25pbAIABQdlc3RpbUxQBAFlCQD8BwQFA2ZjYQIEZW1pdAkAzAgCBQllbWl0THBBbXQFA25pbAUDbmlsAwkAAAIFAWUFAWUEAmVsBAckbWF0Y2gwBQFlAwkAAQIFByRtYXRjaDACB0FkZHJlc3MEBmxlZ2FjeQUHJG1hdGNoMAkA/AcEBQZsZWdhY3kCBGVtaXQJAMwIAgUJZW1pdExwQW10BQNuaWwFA25pbAUEdW5pdAMJAAACBQJlbAUCZWwECGxwVHJuc2ZyAwUJYXV0b1N0YWtlBAJzcwkA/AcEBQ9zdGFraW5nQ29udHJhY3QCBXN0YWtlBQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFBGxwSWQFCWVtaXRMcEFtdAUDbmlsAwkAAAIFAnNzBQJzcwUDbmlsCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQDMCAIJAQ5TY3JpcHRUcmFuc2ZlcgMIBQFpBmNhbGxlcgUJZW1pdExwQW10BQRscElkBQNuaWwEEHNlbmRGZWVUb01hdGNoZXIDCQBmAgUJZmVlQW1vdW50AAAJAMwIAgkBDlNjcmlwdFRyYW5zZmVyAwUTZmVlQ29sbGVjdG9yQWRkcmVzcwUJZmVlQW1vdW50CQDZBAEFCnBtdEFzc2V0SWQFA25pbAUDbmlsBA0kdDA0NDU5NTQ0OTQ0AwkAAAIFBHRoaXMFE2ZlZUNvbGxlY3RvckFkZHJlc3MJAJQKAgAAAAAEFHBheW1lbnRJbkFtb3VudEFzc2V0AwkAAAIIBQNwbXQHYXNzZXRJZAUQY2ZnQW1vdW50QXNzZXRJZAYHAwUUcGF5bWVudEluQW1vdW50QXNzZXQJAJQKAgkBAS0BBQlmZWVBbW91bnQAAAkAlAoCAAAJAQEtAQUJZmVlQW1vdW50BBdhbW91bnRBc3NldEJhbGFuY2VEZWx0YQgFDSR0MDQ0NTk1NDQ5NDQCXzEEFnByaWNlQXNzZXRCYWxhbmNlRGVsdGEIBQ0kdDA0NDU5NTQ0OTQ0Al8yBA0kdDA0NDk0NzQ1MDU1CQEScmVmcmVzaERMcEludGVybmFsAwUXYW1vdW50QXNzZXRCYWxhbmNlRGVsdGEFFnByaWNlQXNzZXRCYWxhbmNlRGVsdGEAAAQRcmVmcmVzaERMcEFjdGlvbnMIBQ0kdDA0NDk0NzQ1MDU1Al8xBAp1cGRhdGVkRExwCAUNJHQwNDQ5NDc0NTA1NQJfMgQRaXNVcGRhdGVkRExwVmFsaWQJARJ2YWxpZGF0ZVVwZGF0ZWRETHACBQpjdXJyZW50RExwBQp1cGRhdGVkRExwAwkAAAIFEWlzVXBkYXRlZERMcFZhbGlkBRFpc1VwZGF0ZWRETHBWYWxpZAkAlAoCCQDOCAIJAM4IAgkAzggCBQVzdGF0ZQUIbHBUcm5zZnIFEHNlbmRGZWVUb01hdGNoZXIFEXJlZnJlc2hETHBBY3Rpb25zBQllbWl0THBBbXQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEKcHV0Rm9yRnJlZQEHbWF4U2xwZwMJAGYCAAAFB21heFNscGcJAAIBAgpXcm9uZyBzbHBnAwkBAiE9AgkAkAMBCAUBaQhwYXltZW50cwACCQACAQIMMiBwbW50cyBleHBkBAZlc3RQdXQJAQJjcAoJAKUIAQgFAWkGY2FsbGVyCQDYBAEIBQFpDXRyYW5zYWN0aW9uSWQJAQ9BdHRhY2hlZFBheW1lbnQCCAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwAAB2Fzc2V0SWQICQEFdmFsdWUBCQCRAwIIBQFpCHBheW1lbnRzAAAGYW1vdW50CQCRAwIIBQFpCHBheW1lbnRzAAEFB21heFNscGcHBwYAAAIABAVzdGF0ZQgFBmVzdFB1dAJfOQQKYW1Bc3NldFBtdAkAtgIBCAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwAABmFtb3VudAQKcHJBc3NldFBtdAkAtgIBCAkBBXZhbHVlAQkAkQMCCAUBaQhwYXltZW50cwABBmFtb3VudAQKY3VycmVudERMcAkBDmNhbGNDdXJyZW50RExwAwUKYW1Bc3NldFBtdAUKcHJBc3NldFBtdAkAtgIBAAADCQAAAgUKY3VycmVudERMcAUKY3VycmVudERMcAQNJHQwNDYwODU0NjE1MAkBEnJlZnJlc2hETHBJbnRlcm5hbAMAAAAAAAAEEXJlZnJlc2hETHBBY3Rpb25zCAUNJHQwNDYwODU0NjE1MAJfMQQKdXBkYXRlZERMcAgFDSR0MDQ2MDg1NDYxNTACXzIEEWlzVXBkYXRlZERMcFZhbGlkCQESdmFsaWRhdGVVcGRhdGVkRExwAgUKY3VycmVudERMcAUKdXBkYXRlZERMcAMJAAACBRFpc1VwZGF0ZWRETHBWYWxpZAURaXNVcGRhdGVkRExwVmFsaWQJAM4IAgUFc3RhdGUFEXJlZnJlc2hETHBBY3Rpb25zCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBA2dldAAECmN1cnJlbnRETHAJAQ5jYWxjQ3VycmVudERMcAMJALYCAQAACQC2AgEAAAkAtgIBAAADCQAAAgUKY3VycmVudERMcAUKY3VycmVudERMcAQBcgkBAmNnAQUBaQQJb3V0QW10QW10CAUBcgJfMQQIb3V0UHJBbXQIBQFyAl8yBAZwbXRBbXQIBQFyAl8zBApwbXRBc3NldElkCAUBcgJfNAQFc3RhdGUIBQFyAl81BAFiCQD8BwQFA2ZjYQIEYnVybgkAzAgCBQZwbXRBbXQFA25pbAkAzAgCCQEPQXR0YWNoZWRQYXltZW50AgUKcG10QXNzZXRJZAUGcG10QW10BQNuaWwDCQAAAgUBYgUBYgQNJHQwNDczMjM0NzQwNQkBEnJlZnJlc2hETHBJbnRlcm5hbAMJAQEtAQUJb3V0QW10QW10CQEBLQEFCG91dFByQW10AAAEEXJlZnJlc2hETHBBY3Rpb25zCAUNJHQwNDczMjM0NzQwNQJfMQQKdXBkYXRlZERMcAgFDSR0MDQ3MzIzNDc0MDUCXzIEEWlzVXBkYXRlZERMcFZhbGlkCQESdmFsaWRhdGVVcGRhdGVkRExwAgUKY3VycmVudERMcAUKdXBkYXRlZERMcAMJAAACBRFpc1VwZGF0ZWRETHBWYWxpZAURaXNVcGRhdGVkRExwVmFsaWQJAM4IAgUFc3RhdGUFEXJlZnJlc2hETHBBY3Rpb25zCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBC2dldE9uZVRrblYyAgpvdXRBc3NldElkDG1pbk91dEFtb3VudAQgaXNQb29sT25lVG9rZW5PcGVyYXRpb25zRGlzYWJsZWQKAAFACQD8BwQFA2ZjYQIoaXNQb29sT25lVG9rZW5PcGVyYXRpb25zRGlzYWJsZWRSRUFET05MWQkAzAgCCQClCAEFBHRoaXMFA25pbAUDbmlsAwkAAQIFAUACB0Jvb2xlYW4FAUAJAAIBCQCsAgIJAAMBBQFAAhwgY291bGRuJ3QgYmUgY2FzdCB0byBCb29sZWFuBA1pc0dldERpc2FibGVkAwMJAQNpZ3MABgkAAAIFDWNmZ1Bvb2xTdGF0dXMFDFBvb2xTaHV0ZG93bgYFIGlzUG9vbE9uZVRva2VuT3BlcmF0aW9uc0Rpc2FibGVkBAZjaGVja3MJAMwIAgMDCQEBIQEFDWlzR2V0RGlzYWJsZWQGCQEJaXNNYW5hZ2VyAQUBaQYJAQh0aHJvd0VycgECIWdldCBvcGVyYXRpb24gaXMgYmxvY2tlZCBieSBhZG1pbgkAzAgCAwkAAAIJAJADAQgFAWkIcGF5bWVudHMAAQYJAQh0aHJvd0VycgECHmV4YWN0bHkgMSBwYXltZW50IGFyZSBleHBlY3RlZAUDbmlsAwkAAAIFBmNoZWNrcwUGY2hlY2tzBA0kdDA0ODAyMzQ4MTc4CQETZ2V0T25lVGtuVjJJbnRlcm5hbAYFCm91dEFzc2V0SWQFDG1pbk91dEFtb3VudAgFAWkIcGF5bWVudHMIBQFpBmNhbGxlcggFAWkMb3JpZ2luQ2FsbGVyCAUBaQ10cmFuc2FjdGlvbklkBAVzdGF0ZQgFDSR0MDQ4MDIzNDgxNzgCXzEEC3RvdGFsQW1vdW50CAUNJHQwNDgwMjM0ODE3OAJfMgkAlAoCBQVzdGF0ZQULdG90YWxBbW91bnQJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQEKcmVmcmVzaERMcAAEGGxhc3RSZWZyZXNoZWRCbG9ja0hlaWdodAkBC3ZhbHVlT3JFbHNlAgkAnwgBBRVrZXlETHBSZWZyZXNoZWRIZWlnaHQAAAQdY2hlY2tMYXN0UmVmcmVzaGVkQmxvY2tIZWlnaHQDCQBnAgkAZQIFBmhlaWdodAUYbGFzdFJlZnJlc2hlZEJsb2NrSGVpZ2h0BQ9kTHBSZWZyZXNoRGVsYXkFBHVuaXQJAQh0aHJvd0VycgEJALkJAgkAzAgCCQCkAwEFD2RMcFJlZnJlc2hEZWxheQkAzAgCAi8gYmxvY2tzIGhhdmUgbm90IHBhc3NlZCBzaW5jZSB0aGUgcHJldmlvdXMgY2FsbAUDbmlsAgADCQAAAgUdY2hlY2tMYXN0UmVmcmVzaGVkQmxvY2tIZWlnaHQFHWNoZWNrTGFzdFJlZnJlc2hlZEJsb2NrSGVpZ2h0BANkTHAJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkAqAMBCQELdmFsdWVPckVsc2UCCQCdCAIFBHRoaXMFBmtleURMcAIBMAkBBmZtdEVycgECC2ludmFsaWQgZExwBA0kdDA0ODcwMjQ4NzY2CQEScmVmcmVzaERMcEludGVybmFsAwAAAAAAAAQQZExwVXBkYXRlQWN0aW9ucwgFDSR0MDQ4NzAyNDg3NjYCXzEECnVwZGF0ZWRETHAIBQ0kdDA0ODcwMjQ4NzY2Al8yBAdhY3Rpb25zAwkBAiE9AgUDZExwBQp1cGRhdGVkRExwBRBkTHBVcGRhdGVBY3Rpb25zCQEIdGhyb3dFcnIBAhJub3RoaW5nIHRvIHJlZnJlc2gJAJQKAgUHYWN0aW9ucwkApgMBBQp1cGRhdGVkRExwCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBE2dldE9uZVRrblYyUkVBRE9OTFkCCm91dEFzc2V0SWQNbHBBc3NldEFtb3VudAQEYW1JZAkA2AQBCQEFdmFsdWUBBRBjZmdBbW91bnRBc3NldElkBARwcklkCQDYBAEJAQV2YWx1ZQEFD2NmZ1ByaWNlQXNzZXRJZAQEbHBJZAkA2AQBCQEFdmFsdWUBBQxjZmdMcEFzc2V0SWQEAnhwCQDMCAIJALYCAQkBDWdldEFjY0JhbGFuY2UBBQRhbUlkCQDMCAIJALYCAQkBDWdldEFjY0JhbGFuY2UBBQRwcklkBQNuaWwECmxwRW1pc3Npb24JALYCAQgJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkA7AcBCQDZBAEFBGxwSWQCEGludmFsaWQgbHAgYXNzZXQIcXVhbnRpdHkEAkQwCQEEZ2V0RAEFAnhwBAJEMQkAuAICBQJEMAkAvAIDCQC2AgEFDWxwQXNzZXRBbW91bnQFAkQwBQpscEVtaXNzaW9uBAVpbmRleAMJAAACBQpvdXRBc3NldElkBQRhbUlkAAADCQAAAgUKb3V0QXNzZXRJZAUEcHJJZAABCQACAQIUaW52YWxpZCBvdXQgYXNzZXQgaWQEBG5ld1kJAQVnZXRZRAMFAnhwBQVpbmRleAUCRDEEAmR5CQC4AgIJAJEDAgUCeHAFBWluZGV4BQRuZXdZBAt0b3RhbEdldFJhdwkAlgMBCQDMCAIAAAkAzAgCCQCgAwEJALgCAgUCZHkFBGJpZzEFA25pbAQNJHQwNDk3NzY0OTgzMQkBB3Rha2VGZWUCBQt0b3RhbEdldFJhdwUGb3V0RmVlBAh0b3RhbEdldAgFDSR0MDQ5Nzc2NDk4MzECXzEECWZlZUFtb3VudAgFDSR0MDQ5Nzc2NDk4MzECXzIJAJQKAgUDbmlsCQCUCgIFCHRvdGFsR2V0BQlmZWVBbW91bnQBaQEcZ2V0T25lVGtuVjJXaXRoQm9udXNSRUFET05MWQIKb3V0QXNzZXRJZA1scEFzc2V0QW1vdW50BARhbUlkCQDYBAEJAQV2YWx1ZQEFEGNmZ0Ftb3VudEFzc2V0SWQEBHBySWQJANgEAQkBBXZhbHVlAQUPY2ZnUHJpY2VBc3NldElkBARscElkCQDYBAEJAQV2YWx1ZQEFDGNmZ0xwQXNzZXRJZAQJYW1CYWxhbmNlCQENZ2V0QWNjQmFsYW5jZQEFBGFtSWQECXByQmFsYW5jZQkBDWdldEFjY0JhbGFuY2UBBQRwcklkBA0kdDA1MDIwNjUwMzIxCgABQAkA/AcEBQR0aGlzAhNnZXRPbmVUa25WMlJFQURPTkxZCQDMCAIFCm91dEFzc2V0SWQJAMwIAgUNbHBBc3NldEFtb3VudAUDbmlsBQNuaWwDCQABAgUBQAIKKEludCwgSW50KQUBQAkAAgEJAKwCAgkAAwEFAUACHyBjb3VsZG4ndCBiZSBjYXN0IHRvIChJbnQsIEludCkECHRvdGFsR2V0CAUNJHQwNTAyMDY1MDMyMQJfMQQJZmVlQW1vdW50CAUNJHQwNTAyMDY1MDMyMQJfMgQBcgkBA2VnbwQCAAUEbHBJZAUNbHBBc3NldEFtb3VudAUEdGhpcwQIb3V0QW1BbXQIBQFyAl8xBAhvdXRQckFtdAgFAXICXzIEDnN1bU9mR2V0QXNzZXRzCQBkAgUIb3V0QW1BbXQFCG91dFByQW10BAVib251cwMJAAACBQ5zdW1PZkdldEFzc2V0cwAAAwkAAAIFCHRvdGFsR2V0AAAAAAkAAgECF2JvbnVzIGNhbGN1bGF0aW9uIGVycm9yCQBrAwkAZQIFCHRvdGFsR2V0BQ5zdW1PZkdldEFzc2V0cwUGc2NhbGU4BQ5zdW1PZkdldEFzc2V0cwkAlAoCBQNuaWwJAJUKAwUIdG90YWxHZXQFCWZlZUFtb3VudAUFYm9udXMBaQEJZ2V0Tm9MZXNzAhJub0xlc3NUaGVuQW10QXNzZXQUbm9MZXNzVGhlblByaWNlQXNzZXQEAXIJAQJjZwEFAWkECG91dEFtQW10CAUBcgJfMQQIb3V0UHJBbXQIBQFyAl8yBAZwbXRBbXQIBQFyAl8zBApwbXRBc3NldElkCAUBcgJfNAQFc3RhdGUIBQFyAl81AwkAZgIFEm5vTGVzc1RoZW5BbXRBc3NldAUIb3V0QW1BbXQJAAIBCQCsAgIJAKwCAgkArAICAglGYWlsZWQ6ICAJAKQDAQUIb3V0QW1BbXQCAyA8IAkApAMBBRJub0xlc3NUaGVuQW10QXNzZXQDCQBmAgUUbm9MZXNzVGhlblByaWNlQXNzZXQFCG91dFByQW10CQACAQkArAICCQCsAgIJAKwCAgIIRmFpbGVkOiAJAKQDAQUIb3V0UHJBbXQCAyA8IAkApAMBBRRub0xlc3NUaGVuUHJpY2VBc3NldAQKY3VycmVudERMcAkBDmNhbGNDdXJyZW50RExwAwkAtgIBAAAJALYCAQAACQC2AgEAAAMJAAACBQpjdXJyZW50RExwBQpjdXJyZW50RExwBBRidXJuTFBBc3NldE9uRmFjdG9yeQkA/AcEBQNmY2ECBGJ1cm4JAMwIAgUGcG10QW10BQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFCnBtdEFzc2V0SWQFBnBtdEFtdAUDbmlsAwkAAAIFFGJ1cm5MUEFzc2V0T25GYWN0b3J5BRRidXJuTFBBc3NldE9uRmFjdG9yeQQNJHQwNTE0ODc1MTU2OAkBEnJlZnJlc2hETHBJbnRlcm5hbAMJAQEtAQUIb3V0QW1BbXQJAQEtAQUIb3V0UHJBbXQAAAQRcmVmcmVzaERMcEFjdGlvbnMIBQ0kdDA1MTQ4NzUxNTY4Al8xBAp1cGRhdGVkRExwCAUNJHQwNTE0ODc1MTU2OAJfMgQRaXNVcGRhdGVkRExwVmFsaWQJARJ2YWxpZGF0ZVVwZGF0ZWRETHACBQpjdXJyZW50RExwBQp1cGRhdGVkRExwAwkAAAIFEWlzVXBkYXRlZERMcFZhbGlkBRFpc1VwZGF0ZWRETHBWYWxpZAkAzggCBQVzdGF0ZQURcmVmcmVzaERMcEFjdGlvbnMJAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4JAAIBAiRTdHJpY3QgdmFsdWUgaXMgbm90IGVxdWFsIHRvIGl0c2VsZi4BaQENdW5zdGFrZUFuZEdldAEGYW1vdW50BA1jaGVja1BheW1lbnRzAwkBAiE9AgkAkAMBCAUBaQhwYXltZW50cwAACQACAQINTm8gcG1udHMgZXhwZAYDCQAAAgUNY2hlY2tQYXltZW50cwUNY2hlY2tQYXltZW50cwQKZmFjdG9yeUNmZwkBA2dmYwAECWxwQXNzZXRJZAUMY2ZnTHBBc3NldElkBAdzdGFraW5nCQETdmFsdWVPckVycm9yTWVzc2FnZQIJAKYIAQkAkQMCBQpmYWN0b3J5Q2ZnBQ9pZHhGYWN0U3Rha0NudHICCldyIHN0IGFkZHIECmN1cnJlbnRETHAJAQ5jYWxjQ3VycmVudERMcAMJALYCAQAACQC2AgEAAAkAtgIBAAADCQAAAgUKY3VycmVudERMcAUKY3VycmVudERMcAQKdW5zdGFrZUludgkA/AcEBQdzdGFraW5nAgd1bnN0YWtlCQDMCAIJANgEAQUJbHBBc3NldElkCQDMCAIFBmFtb3VudAUDbmlsBQNuaWwDCQAAAgUKdW5zdGFrZUludgUKdW5zdGFrZUludgQBcgkBA2VnbwQJANgEAQgFAWkNdHJhbnNhY3Rpb25JZAkA2AQBBQlscEFzc2V0SWQFBmFtb3VudAgFAWkGY2FsbGVyBAhvdXRBbUFtdAgFAXICXzEECG91dFByQW10CAUBcgJfMgQDc3RzCQENcGFyc2VJbnRWYWx1ZQEIBQFyAl85BAVzdGF0ZQgFAXIDXzEwBAF2AwMJAQNpZ3MABgkAAAIFA3N0cwUMUG9vbFNodXRkb3duCQACAQkArAICAglCbG9ja2VkOiAJAKQDAQUDc3RzBgMJAAACBQF2BQF2BAVidXJuQQkA/AcEBQNmY2ECBGJ1cm4JAMwIAgUGYW1vdW50BQNuaWwJAMwIAgkBD0F0dGFjaGVkUGF5bWVudAIFCWxwQXNzZXRJZAUGYW1vdW50BQNuaWwDCQAAAgUFYnVybkEFBWJ1cm5BBA0kdDA1MjU5NTUyNjc2CQEScmVmcmVzaERMcEludGVybmFsAwkBAS0BBQhvdXRBbUFtdAkBAS0BBQhvdXRQckFtdAAABBFyZWZyZXNoRExwQWN0aW9ucwgFDSR0MDUyNTk1NTI2NzYCXzEECnVwZGF0ZWRETHAIBQ0kdDA1MjU5NTUyNjc2Al8yBBFpc1VwZGF0ZWRETHBWYWxpZAkBEnZhbGlkYXRlVXBkYXRlZERMcAIFCmN1cnJlbnRETHAFCnVwZGF0ZWRETHADCQAAAgURaXNVcGRhdGVkRExwVmFsaWQFEWlzVXBkYXRlZERMcFZhbGlkCQDOCAIFBXN0YXRlBRFyZWZyZXNoRExwQWN0aW9ucwkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpARN1bnN0YWtlQW5kR2V0Tm9MZXNzAw11bnN0YWtlQW1vdW50FW5vTGVzc1RoZW5BbW91bnRBc3NldBRub0xlc3NUaGVuUHJpY2VBc3NldAQNaXNHZXREaXNhYmxlZAMJAQNpZ3MABgkAAAIFDWNmZ1Bvb2xTdGF0dXMFDFBvb2xTaHV0ZG93bgQGY2hlY2tzCQDMCAIDCQEBIQEFDWlzR2V0RGlzYWJsZWQGCQACAQIhZ2V0IG9wZXJhdGlvbiBpcyBibG9ja2VkIGJ5IGFkbWluCQDMCAIDCQAAAgkAkAMBCAUBaQhwYXltZW50cwAABgkAAgECGG5vIHBheW1lbnRzIGFyZSBleHBlY3RlZAUDbmlsAwkAAAIFBmNoZWNrcwUGY2hlY2tzBApjdXJyZW50RExwCQEOY2FsY0N1cnJlbnRETHADCQC2AgEAAAkAtgIBAAAJALYCAQAAAwkAAAIFCmN1cnJlbnRETHAFCmN1cnJlbnRETHAECnVuc3Rha2VJbnYJAPwHBAUPc3Rha2luZ0NvbnRyYWN0Agd1bnN0YWtlCQDMCAIJANgEAQUMY2ZnTHBBc3NldElkCQDMCAIFDXVuc3Rha2VBbW91bnQFA25pbAUDbmlsAwkAAAIFCnVuc3Rha2VJbnYFCnVuc3Rha2VJbnYEA3JlcwkBA2VnbwQJANgEAQgFAWkNdHJhbnNhY3Rpb25JZAkA2AQBBQxjZmdMcEFzc2V0SWQFDXVuc3Rha2VBbW91bnQIBQFpBmNhbGxlcgQIb3V0QW1BbXQIBQNyZXMCXzEECG91dFByQW10CAUDcmVzAl8yBAVzdGF0ZQgFA3JlcwNfMTAEDGNoZWNrQW1vdW50cwkAzAgCAwkAZwIFCG91dEFtQW10BRVub0xlc3NUaGVuQW1vdW50QXNzZXQGCQACAQkAuQkCCQDMCAICLGFtb3VudCBhc3NldCBhbW91bnQgdG8gcmVjZWl2ZSBpcyBsZXNzIHRoYW4gCQDMCAIJAKQDAQUVbm9MZXNzVGhlbkFtb3VudEFzc2V0BQNuaWwCAAkAzAgCAwkAZwIFCG91dFByQW10BRRub0xlc3NUaGVuUHJpY2VBc3NldAYJAAIBCQC5CQIJAMwIAgIrcHJpY2UgYXNzZXQgYW1vdW50IHRvIHJlY2VpdmUgaXMgbGVzcyB0aGFuIAkAzAgCCQCkAwEFFG5vTGVzc1RoZW5QcmljZUFzc2V0BQNuaWwCAAUDbmlsAwkAAAIFDGNoZWNrQW1vdW50cwUMY2hlY2tBbW91bnRzBBRidXJuTFBBc3NldE9uRmFjdG9yeQkA/AcEBQNmY2ECBGJ1cm4JAMwIAgUNdW5zdGFrZUFtb3VudAUDbmlsCQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQxjZmdMcEFzc2V0SWQFDXVuc3Rha2VBbW91bnQFA25pbAMJAAACBRRidXJuTFBBc3NldE9uRmFjdG9yeQUUYnVybkxQQXNzZXRPbkZhY3RvcnkEDSR0MDUzOTI3NTQwMDgJARJyZWZyZXNoRExwSW50ZXJuYWwDCQEBLQEFCG91dEFtQW10CQEBLQEFCG91dFByQW10AAAEEXJlZnJlc2hETHBBY3Rpb25zCAUNJHQwNTM5Mjc1NDAwOAJfMQQKdXBkYXRlZERMcAgFDSR0MDUzOTI3NTQwMDgCXzIEEWlzVXBkYXRlZERMcFZhbGlkCQESdmFsaWRhdGVVcGRhdGVkRExwAgUKY3VycmVudERMcAUKdXBkYXRlZERMcAMJAAACBRFpc1VwZGF0ZWRETHBWYWxpZAURaXNVcGRhdGVkRExwVmFsaWQJAM4IAgUFc3RhdGUFEXJlZnJlc2hETHBBY3Rpb25zCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuCQACAQIkU3RyaWN0IHZhbHVlIGlzIG5vdCBlcXVhbCB0byBpdHNlbGYuAWkBFXVuc3Rha2VBbmRHZXRPbmVUa25WMgMNdW5zdGFrZUFtb3VudApvdXRBc3NldElkDG1pbk91dEFtb3VudAQgaXNQb29sT25lVG9rZW5PcGVyYXRpb25zRGlzYWJsZWQKAAFACQD8BwQFA2ZjYQIoaXNQb29sT25lVG9rZW5PcGVyYXRpb25zRGlzYWJsZWRSRUFET05MWQkAzAgCCQClCAEFBHRoaXMFA25pbAUDbmlsAwkAAQIFAUACB0Jvb2xlYW4FAUAJAAIBCQCsAgIJAAMBBQFAAhwgY291bGRuJ3QgYmUgY2FzdCB0byBCb29sZWFuBA1pc0dldERpc2FibGVkAwMJAQNpZ3MABgkAAAIFDWNmZ1Bvb2xTdGF0dXMFDFBvb2xTaHV0ZG93bgYFIGlzUG9vbE9uZVRva2VuT3BlcmF0aW9uc0Rpc2FibGVkBAZjaGVja3MJAMwIAgMDCQEBIQEFDWlzR2V0RGlzYWJsZWQGCQEJaXNNYW5hZ2VyAQUBaQYJAQh0aHJvd0VycgECIWdldCBvcGVyYXRpb24gaXMgYmxvY2tlZCBieSBhZG1pbgkAzAgCAwkAAAIJAJADAQgFAWkIcGF5bWVudHMAAAYJAQh0aHJvd0VycgECGG5vIHBheW1lbnRzIGFyZSBleHBlY3RlZAUDbmlsAwkAAAIFBmNoZWNrcwUGY2hlY2tzBApmYWN0b3J5Q2ZnCQEDZ2ZjAAQJbHBBc3NldElkBQxjZmdMcEFzc2V0SWQEB3N0YWtpbmcJARN2YWx1ZU9yRXJyb3JNZXNzYWdlAgkApggBCQCRAwIFCmZhY3RvcnlDZmcFD2lkeEZhY3RTdGFrQ250cgIKV3Igc3QgYWRkcgQLdXNlckFkZHJlc3MIBQFpBmNhbGxlcgQXbHBBc3NldFJlY2lwaWVudEFkZHJlc3MFBHRoaXMECnVuc3Rha2VJbnYJAPwHBAUHc3Rha2luZwIPdW5zdGFrZUlOVEVSTkFMCQDMCAIFCWxwQXNzZXRJZAkAzAgCBQ11bnN0YWtlQW1vdW50CQDMCAIIBQt1c2VyQWRkcmVzcwVieXRlcwkAzAgCCAUXbHBBc3NldFJlY2lwaWVudEFkZHJlc3MFYnl0ZXMFA25pbAUDbmlsAwkAAAIFCnVuc3Rha2VJbnYFCnVuc3Rha2VJbnYEDSR0MDU1MDMwNTUyMTgJARNnZXRPbmVUa25WMkludGVybmFsBgUKb3V0QXNzZXRJZAUMbWluT3V0QW1vdW50CQDMCAIJAQ9BdHRhY2hlZFBheW1lbnQCBQlscEFzc2V0SWQFDXVuc3Rha2VBbW91bnQFA25pbAgFAWkGY2FsbGVyCAUBaQxvcmlnaW5DYWxsZXIIBQFpDXRyYW5zYWN0aW9uSWQEBXN0YXRlCAUNJHQwNTUwMzA1NTIxOAJfMQQLdG90YWxBbW91bnQIBQ0kdDA1NTAzMDU1MjE4Al8yCQCUCgIFBXN0YXRlBQt0b3RhbEFtb3VudAkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgkAAgECJFN0cmljdCB2YWx1ZSBpcyBub3QgZXF1YWwgdG8gaXRzZWxmLgFpARxwdXRPbmVUa25WMldpdGhCb251c1JFQURPTkxZAhBwYXltZW50QW1vdW50UmF3DnBheW1lbnRBc3NldElkBA0kdDA1NTM0NjU1NDQ5CQENY2FsY1B1dE9uZVRrbgUFEHBheW1lbnRBbW91bnRSYXcFDnBheW1lbnRBc3NldElkAgACAAYECGxwQW1vdW50CAUNJHQwNTUzNDY1NTQ0OQJfMQQFc3RhdGUIBQ0kdDA1NTM0NjU1NDQ5Al8yBAlmZWVBbW91bnQIBQ0kdDA1NTM0NjU1NDQ5Al8zBAVib251cwgFDSR0MDU1MzQ2NTU0NDkCXzQJAJQKAgUDbmlsCQCVCgMFCGxwQW1vdW50BQlmZWVBbW91bnQFBWJvbnVzAWkBIXB1dE9uZVRrblYyV2l0aG91dFRha2VGZWVSRUFET05MWQIQcGF5bWVudEFtb3VudFJhdw5wYXltZW50QXNzZXRJZAQNJHQwNTU1OTc1NTcwMQkBDWNhbGNQdXRPbmVUa24FBRBwYXltZW50QW1vdW50UmF3BQ5wYXltZW50QXNzZXRJZAIAAgAHBAhscEFtb3VudAgFDSR0MDU1NTk3NTU3MDECXzEEBXN0YXRlCAUNJHQwNTU1OTc1NTcwMQJfMgQJZmVlQW1vdW50CAUNJHQwNTU1OTc1NTcwMQJfMwQFYm9udXMIBQ0kdDA1NTU5NzU1NzAxAl80CQCUCgIFA25pbAkAlQoDBQhscEFtb3VudAUJZmVlQW1vdW50BQVib251cwFpAQhhY3RpdmF0ZQIIYW10QXNTdHIHcHJBc1N0cgMJAQIhPQIJAKUIAQgFAWkGY2FsbGVyCQClCAEFA2ZjYQkAAgECBmRlbmllZAkAlAoCCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJhYQAFCGFtdEFzU3RyCQDMCAIJAQtTdHJpbmdFbnRyeQIJAQJwYQAFB3ByQXNTdHIFA25pbAIHc3VjY2VzcwFpAQRzZXRTAgFrAXYDCQECIT0CCQClCAEIBQFpBmNhbGxlcgkBBHN0cmYCBQR0aGlzCQEDYWRhAAUCcGQJAMwIAgkBC1N0cmluZ0VudHJ5AgUBawUBdgUDbmlsAWkBBHNldEkCAWsBdgMJAQIhPQIJAKUIAQgFAWkGY2FsbGVyCQEEc3RyZgIFBHRoaXMJAQNhZGEABQJwZAkAzAgCCQEMSW50ZWdlckVudHJ5AgUBawUBdgUDbmlsAWkBHGdldFBvb2xDb25maWdXcmFwcGVyUkVBRE9OTFkACQCUCgIFA25pbAkBA2dwYwABaQEcZ2V0QWNjQmFsYW5jZVdyYXBwZXJSRUFET05MWQEHYXNzZXRJZAkAlAoCBQNuaWwJAQ1nZXRBY2NCYWxhbmNlAQUHYXNzZXRJZAFpARljYWxjUHJpY2VzV3JhcHBlclJFQURPTkxZAwVhbUFtdAVwckFtdAVscEFtdAQCcHIJAQpjYWxjUHJpY2VzAwUFYW1BbXQFBXByQW10BQVscEFtdAkAlAoCBQNuaWwJAMwIAgkApgMBCQCRAwIFAnByAAAJAMwIAgkApgMBCQCRAwIFAnByAAEJAMwIAgkApgMBCQCRAwIFAnByAAIFA25pbAFpARZmcm9tWDE4V3JhcHBlclJFQURPTkxZAgN2YWwMcmVzU2NhbGVNdWx0CQCUCgIFA25pbAkBAmYxAgkApwMBBQN2YWwFDHJlc1NjYWxlTXVsdAFpARR0b1gxOFdyYXBwZXJSRUFET05MWQIHb3JpZ1ZhbA1vcmlnU2NhbGVNdWx0CQCUCgIFA25pbAkApgMBCQECdDECBQdvcmlnVmFsBQ1vcmlnU2NhbGVNdWx0AWkBHmNhbGNQcmljZUJpZ0ludFdyYXBwZXJSRUFET05MWQIIcHJBbXRYMTgIYW1BbXRYMTgJAJQKAgUDbmlsCQCmAwEJAQRjcGJpAgkApwMBBQhwckFtdFgxOAkApwMBBQhhbUFtdFgxOAFpASNlc3RpbWF0ZVB1dE9wZXJhdGlvbldyYXBwZXJSRUFET05MWQkGdHhJZDU4CHNsaXBwYWdlB2luQW1BbXQGaW5BbUlkB2luUHJBbXQGaW5QcklkB3VzckFkZHIGaXNFdmFsBmVtaXRMcAkAlAoCBQNuaWwJAQNlcG8NBQZ0eElkNTgFCHNsaXBwYWdlBQdpbkFtQW10BQZpbkFtSWQFB2luUHJBbXQFBmluUHJJZAUHdXNyQWRkcgUGaXNFdmFsBQZlbWl0THAGBwAAAgABaQEjZXN0aW1hdGVHZXRPcGVyYXRpb25XcmFwcGVyUkVBRE9OTFkEBnR4SWQ1OAdwbXRBc0lkCHBtdExwQW10B3VzckFkZHIEAXIJAQNlZ28EBQZ0eElkNTgFB3BtdEFzSWQFCHBtdExwQW10CQERQGV4dHJOYXRpdmUoMTA2MikBBQd1c3JBZGRyCQCUCgIFA25pbAkAnAoKCAUBcgJfMQgFAXICXzIIBQFyAl8zCAUBcgJfNAgFAXICXzUIBQFyAl82CAUBcgJfNwkApgMBCAUBcgJfOAgFAXICXzkIBQFyA18xMAECdHgBBnZlcmlmeQAED3RhcmdldFB1YmxpY0tleQQHJG1hdGNoMAkBAW0AAwkAAQIFByRtYXRjaDACCkJ5dGVWZWN0b3IEAnBrBQckbWF0Y2gwBQJwawMJAAECBQckbWF0Y2gwAgRVbml0CAUCdHgPc2VuZGVyUHVibGljS2V5CQACAQILTWF0Y2ggZXJyb3IEByRtYXRjaDAFAnR4AwkAAQIFByRtYXRjaDACBU9yZGVyBAVvcmRlcgUHJG1hdGNoMAQKbWF0Y2hlclB1YgkBAm1wAAQNJHQwNTg0OTM1ODU2MgkBG3ZhbGlkYXRlTWF0Y2hlck9yZGVyQWxsb3dlZAEFBW9yZGVyBApvcmRlclZhbGlkCAUNJHQwNTg0OTM1ODU2MgJfMQQOb3JkZXJWYWxpZEluZm8IBQ0kdDA1ODQ5MzU4NTYyAl8yBAtzZW5kZXJWYWxpZAkA9AMDCAUFb3JkZXIJYm9keUJ5dGVzCQCRAwIIBQVvcmRlcgZwcm9vZnMAAAgFBW9yZGVyD3NlbmRlclB1YmxpY0tleQQMbWF0Y2hlclZhbGlkCQD0AwMIBQVvcmRlcglib2R5Qnl0ZXMJAJEDAggFBW9yZGVyBnByb29mcwABBQptYXRjaGVyUHViAwMDBQpvcmRlclZhbGlkBQtzZW5kZXJWYWxpZAcFDG1hdGNoZXJWYWxpZAcGCQEPdGhyb3dPcmRlckVycm9yBAUKb3JkZXJWYWxpZAUOb3JkZXJWYWxpZEluZm8FC3NlbmRlclZhbGlkBQxtYXRjaGVyVmFsaWQDCQABAgUHJG1hdGNoMAIUU2V0U2NyaXB0VHJhbnNhY3Rpb24EAXMFByRtYXRjaDADCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAABQ90YXJnZXRQdWJsaWNLZXkGBAduZXdIYXNoCQD2AwEJAQV2YWx1ZQEIBQFzBnNjcmlwdAQLYWxsb3dlZEhhc2gJANsEAQkBBXZhbHVlAQkAnQgCBQNmY2EJARxrZXlBbGxvd2VkTHBTdGFibGVTY3JpcHRIYXNoAAQLY3VycmVudEhhc2gJAPEHAQUEdGhpcwMJAAACBQthbGxvd2VkSGFzaAUHbmV3SGFzaAkBAiE9AgULY3VycmVudEhhc2gFB25ld0hhc2gHCQD0AwMIBQJ0eAlib2R5Qnl0ZXMJAJEDAggFAnR4BnByb29mcwAABQ90YXJnZXRQdWJsaWNLZXlMzmd0", "height": 2470738, "applicationStatus": "succeeded", "spentComplexity": 0 } View: original | compacted Prev: none Next: none Full:
OldNewDifferences
1-# no script
1+{-# STDLIB_VERSION 6 #-}
2+{-# SCRIPT_TYPE ACCOUNT #-}
3+{-# CONTENT_TYPE DAPP #-}
4+let scale8 = 100000000
5+
6+let scale8BigInt = toBigInt(100000000)
7+
8+let scale18 = toBigInt(1000000000000000000)
9+
10+let zeroBigInt = toBigInt(0)
11+
12+let big0 = toBigInt(0)
13+
14+let big1 = toBigInt(1)
15+
16+let big2 = toBigInt(2)
17+
18+let big3 = toBigInt(3)
19+
20+let big4 = toBigInt(4)
21+
22+let slippage4D = toBigInt((scale8 - ((scale8 * 1) / scale8)))
23+
24+let wavesString = "WAVES"
25+
26+let Amult = "100"
27+
28+let Dconv = "1"
29+
30+let SEP = "__"
31+
32+let EMPTY = ""
33+
34+let PoolActive = 1
35+
36+let PoolPutDis = 2
37+
38+let PoolMatcherDis = 3
39+
40+let PoolShutdown = 4
41+
42+let idxPoolAddress = 1
43+
44+let idxPoolSt = 2
45+
46+let idxLPAsId = 3
47+
48+let idxAmAsId = 4
49+
50+let idxPrAsId = 5
51+
52+let idxAmtAsDcm = 6
53+
54+let idxPriceAsDcm = 7
55+
56+let idxIAmtAsId = 8
57+
58+let idxIPriceAsId = 9
59+
60+let idxFactStakCntr = 1
61+
62+let idxFactoryRestCntr = 6
63+
64+let idxFactSlippCntr = 7
65+
66+let idxFactGwxRewCntr = 10
67+
68+let feeDefault = fraction(10, scale8, 10000)
69+
70+func t1 (origVal,origScaleMult) = fraction(toBigInt(origVal), scale18, toBigInt(origScaleMult))
71+
72+
73+func t1BigInt (origVal,origScaleMult) = fraction(origVal, scale18, origScaleMult)
74+
75+
76+func f1 (val,resultScaleMult) = toInt(fraction(val, toBigInt(resultScaleMult), scale18))
77+
78+
79+func fromX18Round (val,resultScaleMult,round) = toInt(fraction(val, toBigInt(resultScaleMult), scale18, round))
80+
81+
82+func t2 (origVal,origScaleMult) = fraction(origVal, scale18, toBigInt(origScaleMult))
83+
84+
85+func f2 (val,resultScaleMult) = fraction(val, toBigInt(resultScaleMult), scale18)
86+
87+
88+func ts (amt,resScale,curScale) = fraction(amt, resScale, curScale)
89+
90+
91+func abs (val) = if ((zeroBigInt > val))
92+ then -(val)
93+ else val
94+
95+
96+func absBigInt (val) = if ((zeroBigInt > val))
97+ then -(val)
98+ else val
99+
100+
101+func fc () = "%s__factoryContract"
102+
103+
104+func mpk () = "%s__managerPublicKey"
105+
106+
107+func pmpk () = "%s__pendingManagerPublicKey"
108+
109+
110+func pl () = "%s%s__price__last"
111+
112+
113+func ph (h,t) = makeString(["%s%s%d%d__price__history", toString(h), toString(t)], SEP)
114+
115+
116+func pau (ua,txId) = ((("%s%s%s__P__" + ua) + "__") + txId)
117+
118+
119+func gau (ua,txId) = ((("%s%s%s__G__" + ua) + "__") + txId)
120+
121+
122+func aa () = "%s__amountAsset"
123+
124+
125+func pa () = "%s__priceAsset"
126+
127+
128+func amp () = "%s__amp"
129+
130+
131+func ada () = "%s__addonAddr"
132+
133+
134+let keyFee = "%s__fee"
135+
136+let fee = valueOrElse(getInteger(this, keyFee), feeDefault)
137+
138+let keyDLp = makeString(["%s", "dLp"], SEP)
139+
140+let keyDLpRefreshedHeight = makeString(["%s", "dLpRefreshedHeight"], SEP)
141+
142+let keyDLpRefreshDelay = makeString(["%s", "refreshDLpDelay"], SEP)
143+
144+let dLpRefreshDelayDefault = 30
145+
146+let dLpRefreshDelay = valueOrElse(getInteger(this, keyDLpRefreshDelay), dLpRefreshDelayDefault)
147+
148+func fcfg () = "%s__factoryConfig"
149+
150+
151+func mtpk () = "%s%s__matcher__publicKey"
152+
153+
154+func pc (iAmtAs,iPrAs) = (((("%d%d%s__" + iAmtAs) + "__") + iPrAs) + "__config")
155+
156+
157+func mba (bAStr) = ("%s%s%s__mappings__baseAsset2internalId__" + bAStr)
158+
159+
160+func aps () = "%s__shutdown"
161+
162+
163+func keyAllowedLpStableScriptHash () = "%s__allowedLpStableScriptHash"
164+
165+
166+func keyFeeCollectorAddress () = "%s__feeCollectorAddress"
167+
168+
169+func throwOrderError (orderValid,orderValidInfo,senderValid,matcherValid) = throw((((((((("order validation failed: orderValid=" + toString(orderValid)) + " (") + orderValidInfo) + ")") + " senderValid=") + toString(senderValid)) + " matcherValid=") + toString(matcherValid)))
170+
171+
172+func strf (addr,key) = valueOrErrorMessage(getString(addr, key), makeString(["mandatory ", toString(addr), ".", key, " not defined"], ""))
173+
174+
175+func intf (addr,key) = valueOrErrorMessage(getInteger(addr, key), makeString(["mandatory ", toString(addr), ".", key, " not defined"], ""))
176+
177+
178+func throwErr (msg) = throw(makeString(["lp_stable.ride:", msg], " "))
179+
180+
181+func fmtErr (msg) = makeString(["lp_stable.ride:", msg], " ")
182+
183+
184+let fca = addressFromStringValue(strf(this, fc()))
185+
186+let inFee = {
187+ let @ = invoke(fca, "getInFeeREADONLY", [toString(this)], nil)
188+ if ($isInstanceOf(@, "Int"))
189+ then @
190+ else throw(($getType(@) + " couldn't be cast to Int"))
191+ }
192+
193+let outFee = {
194+ let @ = invoke(fca, "getOutFeeREADONLY", [toString(this)], nil)
195+ if ($isInstanceOf(@, "Int"))
196+ then @
197+ else throw(($getType(@) + " couldn't be cast to Int"))
198+ }
199+
200+let A = strf(this, amp())
201+
202+func igs () = valueOrElse(getBoolean(fca, aps()), false)
203+
204+
205+func mp () = fromBase58String(strf(fca, mtpk()))
206+
207+
208+let feeCollectorAddress = addressFromStringValue(strf(fca, keyFeeCollectorAddress()))
209+
210+func gpc () = {
211+ let amtAs = strf(this, aa())
212+ let priceAs = strf(this, pa())
213+ let iPriceAs = intf(fca, mba(priceAs))
214+ let iAmtAs = intf(fca, mba(amtAs))
215+ split(strf(fca, pc(toString(iAmtAs), toString(iPriceAs))), SEP)
216+ }
217+
218+
219+func parseAssetId (input) = if ((input == wavesString))
220+ then unit
221+ else fromBase58String(input)
222+
223+
224+func assetIdToString (input) = if ((input == unit))
225+ then wavesString
226+ else toBase58String(value(input))
227+
228+
229+func parsePoolConfig (poolConfig) = $Tuple9(addressFromStringValue(poolConfig[idxPoolAddress]), parseIntValue(poolConfig[idxPoolSt]), fromBase58String(poolConfig[idxLPAsId]), parseAssetId(poolConfig[idxAmAsId]), parseAssetId(poolConfig[idxPrAsId]), parseIntValue(poolConfig[idxAmtAsDcm]), parseIntValue(poolConfig[idxPriceAsDcm]), fromBase58String(poolConfig[idxIAmtAsId]), fromBase58String(poolConfig[idxIPriceAsId]))
230+
231+
232+let poolConfigParsed = parsePoolConfig(gpc())
233+
234+let $t079658194 = poolConfigParsed
235+
236+let cfgPoolAddress = $t079658194._1
237+
238+let cfgPoolStatus = $t079658194._2
239+
240+let cfgLpAssetId = $t079658194._3
241+
242+let cfgAmountAssetId = $t079658194._4
243+
244+let cfgPriceAssetId = $t079658194._5
245+
246+let cfgAmountAssetDecimals = $t079658194._6
247+
248+let cfgPriceAssetDecimals = $t079658194._7
249+
250+let cfgInAmountAssedId = $t079658194._8
251+
252+let cfgInPriceAssetId = $t079658194._9
253+
254+func gfc () = split(strf(fca, fcfg()), SEP)
255+
256+
257+let factoryConfig = gfc()
258+
259+let stakingContract = valueOrErrorMessage(addressFromString(factoryConfig[idxFactStakCntr]), "Invalid staking contract address")
260+
261+let slipageContract = valueOrErrorMessage(addressFromString(factoryConfig[idxFactSlippCntr]), "Invalid slipage contract address")
262+
263+let gwxContract = valueOrErrorMessage(addressFromString(factoryConfig[idxFactGwxRewCntr]), "Invalid gwx contract address")
264+
265+let restContract = valueOrErrorMessage(addressFromString(factoryConfig[idxFactoryRestCntr]), "Invalid gwx contract address")
266+
267+func dataPutActionInfo (inAmtAssetAmt,inPriceAssetAmt,outLpAmt,price,slipByUser,slippageReal,txHeight,txTimestamp,slipageAmAmt,slipagePrAmt) = makeString(["%d%d%d%d%d%d%d%d%d%d", toString(inAmtAssetAmt), toString(inPriceAssetAmt), toString(outLpAmt), toString(price), toString(slipByUser), toString(slippageReal), toString(txHeight), toString(txTimestamp), toString(slipageAmAmt), toString(slipagePrAmt)], SEP)
268+
269+
270+func dataGetActionInfo (outAmtAssetAmt,outPriceAssetAmt,inLpAmt,price,txHeight,txTimestamp) = makeString(["%d%d%d%d%d%d", toString(outAmtAssetAmt), toString(outPriceAssetAmt), toString(inLpAmt), toString(price), toString(txHeight), toString(txTimestamp)], SEP)
271+
272+
273+func getAccBalance (assetId) = if ((assetId == "WAVES"))
274+ then wavesBalance(this).available
275+ else assetBalance(this, fromBase58String(assetId))
276+
277+
278+func cpbi (prAmtX18,amAmtX18) = fraction(prAmtX18, scale18, amAmtX18)
279+
280+
281+func cpbir (prAmtX18,amAmtX18,round) = fraction(prAmtX18, scale18, amAmtX18, round)
282+
283+
284+func vad (A1,A2,slippage) = {
285+ let diff = fraction((A1 - A2), scale8BigInt, A2)
286+ let pass = ((slippage - abs(diff)) > zeroBigInt)
287+ if (!(pass))
288+ then throw(("Big slpg: " + toString(diff)))
289+ else $Tuple2(pass, min([A1, A2]))
290+ }
291+
292+
293+func vd (D1,D0,slpg) = {
294+ let diff = fraction(D0, scale8BigInt, D1)
295+ let fail = (slpg > diff)
296+ if (if (fail)
297+ then true
298+ else (D0 > D1))
299+ then throw(((((((toString(D0) + " ") + toString(D1)) + " ") + toString(diff)) + " ") + toString(slpg)))
300+ else fail
301+ }
302+
303+
304+func pcp (amAssetDcm,prAssetDcm,amAmt,prAmt) = {
305+ let amtAsAmtX18 = t1(amAmt, amAssetDcm)
306+ let prAsAmtX18 = t1(prAmt, prAssetDcm)
307+ cpbi(prAsAmtX18, amtAsAmtX18)
308+ }
309+
310+
311+func calcPrices (amAmt,prAmt,lpAmt) = {
312+ let amtAsDcm = cfgAmountAssetDecimals
313+ let prAsDcm = cfgPriceAssetDecimals
314+ let priceX18 = pcp(amtAsDcm, prAsDcm, amAmt, prAmt)
315+ let amAmtX18 = t1(amAmt, amtAsDcm)
316+ let prAmtX18 = t1(prAmt, prAsDcm)
317+ let lpAmtX18 = t1(lpAmt, scale8)
318+ let lpPrInAmAsX18 = cpbi(amAmtX18, lpAmtX18)
319+ let lpPrInPrAsX18 = cpbi(prAmtX18, lpAmtX18)
320+[priceX18, lpPrInAmAsX18, lpPrInPrAsX18]
321+ }
322+
323+
324+func calculatePrices (amAmt,prAmt,lpAmt) = {
325+ let p = calcPrices(amAmt, prAmt, lpAmt)
326+[f1(p[0], scale8), f1(p[1], scale8), f1(p[2], scale8)]
327+ }
328+
329+
330+func takeFee (amount,fee) = {
331+ let feeAmount = if ((fee == 0))
332+ then 0
333+ else fraction(amount, fee, scale8)
334+ $Tuple2((amount - feeAmount), feeAmount)
335+ }
336+
337+
338+func getD (xp) = {
339+ let xp0 = xp[0]
340+ let xp1 = xp[1]
341+ let s = (xp0 + xp1)
342+ if ((s == big0))
343+ then big0
344+ else {
345+ let a = parseIntValue(A)
346+ let ann = (a * 2)
347+ let p = fraction(xp0, xp1, big1)
348+ let xp0_xp1_n_n = fraction(p, big4, big1)
349+ let ann_s = fraction(toBigInt(ann), s, big1)
350+ let ann_1 = toBigInt((ann - 1))
351+ func calcDNext (d) = {
352+ let dd = fraction(d, d, big1)
353+ let ddd = fraction(dd, d, big1)
354+ let dp = fraction(ddd, big1, xp0_xp1_n_n)
355+ fraction((ann_s + fraction(dp, big2, big1)), d, (fraction(ann_1, d, big1) + fraction(big3, dp, big1)))
356+ }
357+
358+ func calc (acc,i) = if (acc._2)
359+ then acc
360+ else {
361+ let d = acc._1
362+ let dNext = calcDNext(d)
363+ let dDiffRaw = (dNext - value(d))
364+ let dDiff = if ((big0 > dDiffRaw))
365+ then -(dDiffRaw)
366+ else dDiffRaw
367+ if ((big1 >= dDiff))
368+ then $Tuple2(dNext, true)
369+ else $Tuple2(dNext, false)
370+ }
371+
372+ let arr = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17]
373+ let $t01270312751 = {
374+ let $l = arr
375+ let $s = size($l)
376+ let $acc0 = $Tuple2(s, false)
377+ func $f0_1 ($a,$i) = if (($i >= $s))
378+ then $a
379+ else calc($a, $l[$i])
380+
381+ func $f0_2 ($a,$i) = if (($i >= $s))
382+ then $a
383+ else throw("List size exceeds 18")
384+
385+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15), 16), 17), 18)
386+ }
387+ let d = $t01270312751._1
388+ let found = $t01270312751._2
389+ if (found)
390+ then d
391+ else throw(("D calculation error, D = " + toString(d)))
392+ }
393+ }
394+
395+
396+func ego (txId58,pmtAssetId,pmtLpAmt,userAddress) = {
397+ let lpId = cfgLpAssetId
398+ let amId = toBase58String(value(cfgAmountAssetId))
399+ let prId = toBase58String(value(cfgPriceAssetId))
400+ let amDcm = cfgAmountAssetDecimals
401+ let prDcm = cfgPriceAssetDecimals
402+ let sts = toString(cfgPoolStatus)
403+ let lpEmiss = valueOrErrorMessage(assetInfo(lpId), "Wrong LP id").quantity
404+ if ((toBase58String(lpId) != pmtAssetId))
405+ then throw("Wrong pmt asset")
406+ else {
407+ let amBalance = getAccBalance(amId)
408+ let amBalanceX18 = t1(amBalance, amDcm)
409+ let prBalance = getAccBalance(prId)
410+ let prBalanceX18 = t1(prBalance, prDcm)
411+ let curPriceX18 = cpbi(prBalanceX18, amBalanceX18)
412+ let curPrice = f1(curPriceX18, scale8)
413+ let pmtLpAmtX18 = t1(pmtLpAmt, scale8)
414+ let lpEmissX18 = t1(lpEmiss, scale8)
415+ let outAmAmtX18 = fraction(amBalanceX18, pmtLpAmtX18, lpEmissX18)
416+ let outPrAmtX18 = fraction(prBalanceX18, pmtLpAmtX18, lpEmissX18)
417+ let outAmAmt = fromX18Round(outAmAmtX18, amDcm, FLOOR)
418+ let outPrAmt = fromX18Round(outPrAmtX18, prDcm, FLOOR)
419+ let state = if ((txId58 == ""))
420+ then nil
421+ else [ScriptTransfer(userAddress, outAmAmt, if ((amId == "WAVES"))
422+ then unit
423+ else fromBase58String(amId)), ScriptTransfer(userAddress, outPrAmt, if ((prId == "WAVES"))
424+ then unit
425+ else fromBase58String(prId)), StringEntry(gau(toString(userAddress), txId58), dataGetActionInfo(outAmAmt, outPrAmt, pmtLpAmt, curPrice, height, lastBlock.timestamp)), IntegerEntry(pl(), curPrice), IntegerEntry(ph(height, lastBlock.timestamp), curPrice)]
426+ $Tuple10(outAmAmt, outPrAmt, amId, prId, amBalance, prBalance, lpEmiss, curPriceX18, sts, state)
427+ }
428+ }
429+
430+
431+func epo (txId58,slippage,inAmAmt,inAmId,inPrAmt,inPrId,userAddress,isEval,emitLp,isOneAsset,validateSlippage,pmtAmt,pmtId) = {
432+ let lpId = cfgLpAssetId
433+ let amIdStr = toBase58String(value(cfgAmountAssetId))
434+ let prIdStr = toBase58String(value(cfgPriceAssetId))
435+ let inAmIdStr = cfgInAmountAssedId
436+ let inPrIdStr = cfgInPriceAssetId
437+ let amtDcm = cfgAmountAssetDecimals
438+ let priceDcm = cfgPriceAssetDecimals
439+ let sts = toString(cfgPoolStatus)
440+ let lpEm = valueOrErrorMessage(assetInfo(lpId), "Wr lp as").quantity
441+ let amBalance = if (isEval)
442+ then getAccBalance(amIdStr)
443+ else if (if (isOneAsset)
444+ then (pmtId == amIdStr)
445+ else false)
446+ then (getAccBalance(amIdStr) - pmtAmt)
447+ else if (isOneAsset)
448+ then getAccBalance(amIdStr)
449+ else (getAccBalance(amIdStr) - inAmAmt)
450+ let prBalance = if (isEval)
451+ then getAccBalance(prIdStr)
452+ else if (if (isOneAsset)
453+ then (pmtId == prIdStr)
454+ else false)
455+ then (getAccBalance(prIdStr) - pmtAmt)
456+ else if (isOneAsset)
457+ then getAccBalance(prIdStr)
458+ else (getAccBalance(prIdStr) - inPrAmt)
459+ let inAmAssetAmtX18 = t1(inAmAmt, amtDcm)
460+ let inPrAssetAmtX18 = t1(inPrAmt, priceDcm)
461+ let userPriceX18 = cpbi(inPrAssetAmtX18, inAmAssetAmtX18)
462+ let amBalanceX18 = t1(amBalance, amtDcm)
463+ let prBalanceX18 = t1(prBalance, priceDcm)
464+ let D0 = getD([amBalanceX18, prBalanceX18])
465+ let r = if ((lpEm == 0))
466+ then {
467+ let D1 = getD([(amBalanceX18 + inAmAssetAmtX18), (prBalanceX18 + inPrAssetAmtX18)])
468+ let checkD = if ((D1 > D0))
469+ then true
470+ else throw("D1 should be greater than D0")
471+ if ((checkD == checkD))
472+ then {
473+ let curPriceX18 = zeroBigInt
474+ let slippageX18 = zeroBigInt
475+ let lpAmtX18 = D1
476+ $Tuple5(f1(lpAmtX18, scale8), f1(inAmAssetAmtX18, amtDcm), f1(inPrAssetAmtX18, priceDcm), cpbi((prBalanceX18 + inPrAssetAmtX18), (amBalanceX18 + inAmAssetAmtX18)), slippageX18)
477+ }
478+ else throw("Strict value is not equal to itself.")
479+ }
480+ else {
481+ let curPriceX18 = cpbi(prBalanceX18, amBalanceX18)
482+ let slippageRealX18 = fraction(abs((curPriceX18 - userPriceX18)), scale18, curPriceX18)
483+ let slippageX18 = t1(slippage, scale8)
484+ if (if (if (validateSlippage)
485+ then (curPriceX18 != zeroBigInt)
486+ else false)
487+ then (slippageRealX18 > slippageX18)
488+ else false)
489+ then throw(((("Price slippage " + toString(slippageRealX18)) + " > ") + toString(slippageX18)))
490+ else {
491+ let lpEmissionX18 = t1(lpEm, scale8)
492+ let prViaAmX18 = fraction(inAmAssetAmtX18, cpbir(prBalanceX18, amBalanceX18, CEILING), scale18, CEILING)
493+ let amViaPrX18 = fraction(inPrAssetAmtX18, scale18, cpbir(prBalanceX18, amBalanceX18, FLOOR), CEILING)
494+ let expectedAmts = if ((prViaAmX18 > inPrAssetAmtX18))
495+ then $Tuple2(amViaPrX18, inPrAssetAmtX18)
496+ else $Tuple2(inAmAssetAmtX18, prViaAmX18)
497+ let expAmtAssetAmtX18 = expectedAmts._1
498+ let expPriceAssetAmtX18 = expectedAmts._2
499+ let D1 = getD([(amBalanceX18 + expAmtAssetAmtX18), (prBalanceX18 + expPriceAssetAmtX18)])
500+ let checkD = if ((D1 > D0))
501+ then true
502+ else throw("D1 should be greater than D0")
503+ if ((checkD == checkD))
504+ then {
505+ let lpAmtX18 = fraction(lpEmissionX18, (D1 - D0), D0)
506+ $Tuple5(fromX18Round(lpAmtX18, scale8, FLOOR), fromX18Round(expAmtAssetAmtX18, amtDcm, CEILING), fromX18Round(expPriceAssetAmtX18, priceDcm, CEILING), curPriceX18, slippageX18)
507+ }
508+ else throw("Strict value is not equal to itself.")
509+ }
510+ }
511+ let calcLpAmt = r._1
512+ let calcAmAssetPmt = r._2
513+ let calcPrAssetPmt = r._3
514+ let curPrice = f1(r._4, scale8)
515+ let slippageCalc = f1(r._5, scale8)
516+ if ((0 >= calcLpAmt))
517+ then throw("LP <= 0")
518+ else {
519+ let emitLpAmt = if (!(emitLp))
520+ then 0
521+ else calcLpAmt
522+ let amDiff = (inAmAmt - calcAmAssetPmt)
523+ let prDiff = (inPrAmt - calcPrAssetPmt)
524+ let $t02059020935 = if (if (isOneAsset)
525+ then (pmtId == amIdStr)
526+ else false)
527+ then $Tuple2(pmtAmt, 0)
528+ else if (if (isOneAsset)
529+ then (pmtId == prIdStr)
530+ else false)
531+ then $Tuple2(0, pmtAmt)
532+ else $Tuple2(calcAmAssetPmt, calcPrAssetPmt)
533+ let writeAmAmt = $t02059020935._1
534+ let writePrAmt = $t02059020935._2
535+ let commonState = [IntegerEntry(pl(), curPrice), IntegerEntry(ph(height, lastBlock.timestamp), curPrice), StringEntry(pau(userAddress, txId58), dataPutActionInfo(writeAmAmt, writePrAmt, emitLpAmt, curPrice, slippage, slippageCalc, height, lastBlock.timestamp, amDiff, prDiff))]
536+ $Tuple13(calcLpAmt, emitLpAmt, curPrice, amBalance, prBalance, lpEm, lpId, sts, commonState, amDiff, prDiff, inAmId, inPrId)
537+ }
538+ }
539+
540+
541+func getYD (xp,i,D) = {
542+ let n = big2
543+ let x = xp[if ((i == 0))
544+ then 1
545+ else 0]
546+ let aPrecision = parseBigIntValue(Amult)
547+ let a = (parseBigIntValue(A) * aPrecision)
548+ let s = x
549+ let ann = (a * n)
550+ let c = (((((D * D) / (x * n)) * D) * aPrecision) / (ann * n))
551+ let b = ((s + ((D * aPrecision) / ann)) - D)
552+ func calc (acc,cur) = {
553+ let $t02213022150 = acc
554+ let y = $t02213022150._1
555+ let found = $t02213022150._2
556+ if ((found != unit))
557+ then acc
558+ else {
559+ let yNext = (((y * y) + c) / ((big2 * y) + b))
560+ let yDiff = absBigInt((yNext - value(y)))
561+ if ((big1 >= yDiff))
562+ then $Tuple2(yNext, cur)
563+ else $Tuple2(yNext, unit)
564+ }
565+ }
566+
567+ let arr = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14]
568+ let $t02245722504 = {
569+ let $l = arr
570+ let $s = size($l)
571+ let $acc0 = $Tuple2(D, unit)
572+ func $f0_1 ($a,$i) = if (($i >= $s))
573+ then $a
574+ else calc($a, $l[$i])
575+
576+ func $f0_2 ($a,$i) = if (($i >= $s))
577+ then $a
578+ else throw("List size exceeds 15")
579+
580+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
581+ }
582+ let y = $t02245722504._1
583+ let found = $t02245722504._2
584+ if ((found != unit))
585+ then y
586+ else throw(("Y calculation error, Y = " + toString(y)))
587+ }
588+
589+
590+func calcDLp (amountBalance,priceBalance,lpEmission) = {
591+ let updatedDLp = fraction(getD([t1BigInt(amountBalance, toBigInt(cfgAmountAssetDecimals)), t1BigInt(priceBalance, toBigInt(cfgPriceAssetDecimals))]), scale18, lpEmission)
592+ if ((lpEmission == big0))
593+ then big0
594+ else updatedDLp
595+ }
596+
597+
598+func calcCurrentDLp (amountAssetDelta,priceAssetDelta,lpAssetEmissionDelta) = {
599+ let amountAssetBalance = (toBigInt(getAccBalance(assetIdToString(cfgAmountAssetId))) - amountAssetDelta)
600+ let priceAssetBalance = (toBigInt(getAccBalance(assetIdToString(cfgPriceAssetId))) - priceAssetDelta)
601+ let lpAssetEmission = (toBigInt(value(assetInfo(cfgLpAssetId)).quantity) - lpAssetEmissionDelta)
602+ let currentDLp = calcDLp(amountAssetBalance, priceAssetBalance, lpAssetEmission)
603+ currentDLp
604+ }
605+
606+
607+func refreshDLpInternal (amountAssetBalanceDelta,priceAssetBalanceDelta,lpAssetEmissionDelta) = {
608+ let amountAssetBalance = (getAccBalance(assetIdToString(cfgAmountAssetId)) + amountAssetBalanceDelta)
609+ let priceAssetBalance = (getAccBalance(assetIdToString(cfgPriceAssetId)) + priceAssetBalanceDelta)
610+ let lpAssetEmission = (value(assetInfo(cfgLpAssetId)).quantity + lpAssetEmissionDelta)
611+ let updatedDLp = calcDLp(toBigInt(amountAssetBalance), toBigInt(priceAssetBalance), toBigInt(lpAssetEmission))
612+ let actions = [IntegerEntry(keyDLpRefreshedHeight, height), StringEntry(keyDLp, toString(updatedDLp))]
613+ $Tuple2(actions, updatedDLp)
614+ }
615+
616+
617+func validateUpdatedDLp (oldDLp,updatedDLp) = if ((updatedDLp >= oldDLp))
618+ then true
619+ else throwErr("updated DLp lower than current DLp")
620+
621+
622+func validateMatcherOrderAllowed (order) = {
623+ let amountAssetBalance = getAccBalance(assetIdToString(cfgAmountAssetId))
624+ let priceAssetBalance = getAccBalance(assetIdToString(cfgPriceAssetId))
625+ let amountAssetAmount = order.amount
626+ let priceAssetAmount = fraction(order.amount, order.price, scale8, FLOOR)
627+ let $t02470224914 = if ((order.orderType == Buy))
628+ then $Tuple2(amountAssetAmount, -(priceAssetAmount))
629+ else $Tuple2(-(amountAssetAmount), priceAssetAmount)
630+ let amountAssetBalanceDelta = $t02470224914._1
631+ let priceAssetBalanceDelta = $t02470224914._2
632+ if (if (if (igs())
633+ then true
634+ else (cfgPoolStatus == PoolMatcherDis))
635+ then true
636+ else (cfgPoolStatus == PoolShutdown))
637+ then throw("Admin blocked")
638+ else if (if ((order.assetPair.amountAsset != cfgAmountAssetId))
639+ then true
640+ else (order.assetPair.priceAsset != cfgPriceAssetId))
641+ then throw("Wr assets")
642+ else {
643+ let dLp = parseBigIntValue(valueOrElse(getString(this, keyDLp), "0"))
644+ let $t02525625356 = refreshDLpInternal(amountAssetBalanceDelta, priceAssetBalanceDelta, 0)
645+ let unusedActions = $t02525625356._1
646+ let dLpNew = $t02525625356._2
647+ let isOrderValid = (dLpNew >= dLp)
648+ let info = makeString(["dLp=", toString(dLp), " dLpNew=", toString(dLpNew), " amountAssetBalance=", toString(amountAssetBalance), " priceAssetBalance=", toString(priceAssetBalance), " amountAssetBalanceDelta=", toString(amountAssetBalanceDelta), " priceAssetBalanceDelta=", toString(priceAssetBalanceDelta), " height=", toString(height)], "")
649+ $Tuple2(isOrderValid, info)
650+ }
651+ }
652+
653+
654+func cg (i) = if ((size(i.payments) != 1))
655+ then throw("1 pmnt exp")
656+ else {
657+ let pmt = value(i.payments[0])
658+ let pmtAssetId = value(pmt.assetId)
659+ let pmtAmt = pmt.amount
660+ let r = ego(toBase58String(i.transactionId), toBase58String(pmtAssetId), pmtAmt, i.caller)
661+ let outAmAmt = r._1
662+ let outPrAmt = r._2
663+ let sts = parseIntValue(r._9)
664+ let state = r._10
665+ if (if (igs())
666+ then true
667+ else (sts == PoolShutdown))
668+ then throw(("Admin blocked: " + toString(sts)))
669+ else $Tuple5(outAmAmt, outPrAmt, pmtAmt, pmtAssetId, state)
670+ }
671+
672+
673+func cp (caller,txId,amAsPmt,prAsPmt,slippage,emitLp,isOneAsset,validateSlippage,pmtAmt,pmtId) = {
674+ let r = epo(txId, slippage, value(amAsPmt).amount, value(amAsPmt).assetId, value(prAsPmt).amount, value(prAsPmt).assetId, caller, (txId == ""), emitLp, isOneAsset, validateSlippage, pmtAmt, pmtId)
675+ let sts = parseIntValue(r._8)
676+ if (if (if (igs())
677+ then true
678+ else (sts == PoolPutDis))
679+ then true
680+ else (sts == PoolShutdown))
681+ then throw(("Blocked:" + toString(sts)))
682+ else r
683+ }
684+
685+
686+func calcPutOneTkn (pmtAmtRaw,pmtAssetId,userAddress,txId,withTakeFee) = {
687+ let amId = toBase58String(value(cfgAmountAssetId))
688+ let prId = toBase58String(value(cfgPriceAssetId))
689+ let lpId = cfgLpAssetId
690+ let amtDcm = cfgAmountAssetDecimals
691+ let priceDcm = cfgPriceAssetDecimals
692+ let lpAssetEmission = toBigInt(valueOrErrorMessage(assetInfo(lpId), "invalid lp asset").quantity)
693+ let chechEmission = if ((lpAssetEmission > big0))
694+ then true
695+ else throw("initial deposit requires all coins")
696+ if ((chechEmission == chechEmission))
697+ then {
698+ let amBalance = getAccBalance(amId)
699+ let prBalance = getAccBalance(prId)
700+ let $t02801228474 = if ((txId == ""))
701+ then $Tuple2(amBalance, prBalance)
702+ else if ((pmtAssetId == amId))
703+ then if ((pmtAmtRaw > amBalance))
704+ then throw("invalid payment amount")
705+ else $Tuple2((amBalance - pmtAmtRaw), prBalance)
706+ else if ((pmtAssetId == prId))
707+ then if ((pmtAmtRaw > prBalance))
708+ then throw("invalid payment amount")
709+ else $Tuple2(amBalance, (prBalance - pmtAmtRaw))
710+ else throw("wrong pmtAssetId")
711+ let amBalanceOld = $t02801228474._1
712+ let prBalanceOld = $t02801228474._2
713+ let $t02848028656 = if ((pmtAssetId == amId))
714+ then $Tuple2(pmtAmtRaw, 0)
715+ else if ((pmtAssetId == prId))
716+ then $Tuple2(0, pmtAmtRaw)
717+ else throw("invalid payment")
718+ let amAmountRaw = $t02848028656._1
719+ let prAmountRaw = $t02848028656._2
720+ let $t02866028914 = if (withTakeFee)
721+ then $Tuple3(takeFee(amAmountRaw, inFee)._1, takeFee(prAmountRaw, inFee)._1, takeFee(pmtAmtRaw, inFee)._2)
722+ else $Tuple3(amAmountRaw, prAmountRaw, 0)
723+ let amAmount = $t02866028914._1
724+ let prAmount = $t02866028914._2
725+ let feeAmount = $t02866028914._3
726+ let amBalanceNew = (amBalanceOld + amAmount)
727+ let prBalanceNew = (prBalanceOld + prAmount)
728+ let D0 = getD([t1(amBalanceOld, cfgAmountAssetDecimals), t1(prBalanceOld, cfgPriceAssetDecimals)])
729+ let D1 = getD([t1(amBalanceNew, cfgAmountAssetDecimals), t1(prBalanceNew, cfgPriceAssetDecimals)])
730+ let checkD = if ((D1 > D0))
731+ then true
732+ else throw()
733+ if ((checkD == checkD))
734+ then {
735+ let lpAmount = fraction(lpAssetEmission, (D1 - D0), D0, FLOOR)
736+ let curPrice = f1(cpbi(t1(prBalanceNew, priceDcm), t1(amBalanceNew, amtDcm)), scale8)
737+ let commonState = [IntegerEntry(pl(), curPrice), IntegerEntry(ph(height, lastBlock.timestamp), curPrice), StringEntry(pau(userAddress, txId), dataPutActionInfo(amAmountRaw, prAmountRaw, toInt(lpAmount), curPrice, 0, 0, height, lastBlock.timestamp, 0, 0))]
738+ let poolProportion = fraction(prBalanceOld, scale8, amBalanceOld)
739+ let amountAssetPart = fraction(pmtAmtRaw, scale8, (poolProportion + scale8))
740+ let priceAssetPart = (pmtAmtRaw - amountAssetPart)
741+ let lpAmtBoth = fraction(lpAssetEmission, toBigInt(priceAssetPart), toBigInt(prBalanceOld))
742+ let bonus = toInt(fraction((lpAmount - lpAmtBoth), scale8BigInt, lpAmtBoth))
743+ $Tuple4(toInt(lpAmount), commonState, feeAmount, bonus)
744+ }
745+ else throw("Strict value is not equal to itself.")
746+ }
747+ else throw("Strict value is not equal to itself.")
748+ }
749+
750+
751+func getOneTknV2Internal (outAssetId,minOutAmount,payments,caller,originCaller,transactionId) = {
752+ let lpId = toBase58String(value(cfgLpAssetId))
753+ let amId = toBase58String(value(cfgAmountAssetId))
754+ let prId = toBase58String(value(cfgPriceAssetId))
755+ let amDecimals = cfgAmountAssetDecimals
756+ let prDecimals = cfgPriceAssetDecimals
757+ let poolStatus = cfgPoolStatus
758+ let userAddress = if ((caller == restContract))
759+ then originCaller
760+ else caller
761+ let pmt = value(payments[0])
762+ let pmtAssetId = value(pmt.assetId)
763+ let pmtAmt = pmt.amount
764+ let currentDLp = calcCurrentDLp(big0, big0, big0)
765+ if ((currentDLp == currentDLp))
766+ then {
767+ let txId58 = toBase58String(transactionId)
768+ if ((lpId != toBase58String(pmtAssetId)))
769+ then throw("Wrong LP")
770+ else {
771+ let amBalance = getAccBalance(amId)
772+ let prBalance = getAccBalance(prId)
773+ let $t03102631137 = {
774+ let @ = invoke(this, "getOneTknV2READONLY", [outAssetId, pmtAmt], nil)
775+ if ($isInstanceOf(@, "(Int, Int)"))
776+ then @
777+ else throw(($getType(@) + " couldn't be cast to (Int, Int)"))
778+ }
779+ if (($t03102631137 == $t03102631137))
780+ then {
781+ let feeAmount = $t03102631137._2
782+ let totalGet = $t03102631137._1
783+ let totalAmount = if (if ((minOutAmount > 0))
784+ then (minOutAmount > totalGet)
785+ else false)
786+ then throwErr(makeString(["amount to receive is less than ", toString(minOutAmount)], ""))
787+ else totalGet
788+ let $t03132731634 = if ((outAssetId == amId))
789+ then $Tuple4(totalAmount, 0, ((amBalance - totalAmount) - feeAmount), prBalance)
790+ else if ((outAssetId == prId))
791+ then $Tuple4(0, totalAmount, amBalance, ((prBalance - totalAmount) - feeAmount))
792+ else throw("invalid out asset id")
793+ let outAm = $t03132731634._1
794+ let outPr = $t03132731634._2
795+ let amBalanceNew = $t03132731634._3
796+ let prBalanceNew = $t03132731634._4
797+ let curPrX18 = cpbi(t1(prBalanceNew, prDecimals), t1(amBalanceNew, amDecimals))
798+ let curPr = f1(curPrX18, scale8)
799+ let outAssetIdOrWaves = if ((outAssetId == "WAVES"))
800+ then unit
801+ else fromBase58String(outAssetId)
802+ let sendFeeToMatcher = if ((feeAmount > 0))
803+ then [ScriptTransfer(feeCollectorAddress, feeAmount, outAssetIdOrWaves)]
804+ else nil
805+ let state = ([ScriptTransfer(userAddress, totalAmount, outAssetIdOrWaves), StringEntry(gau(toString(userAddress), txId58), dataGetActionInfo(outAm, outPr, pmtAmt, curPr, height, lastBlock.timestamp)), IntegerEntry(pl(), curPr), IntegerEntry(ph(height, lastBlock.timestamp), curPr)] ++ sendFeeToMatcher)
806+ if ((state == state))
807+ then {
808+ let burn = invoke(fca, "burn", [pmtAmt], [AttachedPayment(pmtAssetId, pmtAmt)])
809+ if ((burn == burn))
810+ then {
811+ let $t03241932769 = {
812+ let feeAmountForCalc = if ((this == feeCollectorAddress))
813+ then 0
814+ else feeAmount
815+ let outInAmountAsset = if ((parseAssetId(outAssetId) == cfgAmountAssetId))
816+ then true
817+ else false
818+ if (outInAmountAsset)
819+ then $Tuple2(-((totalGet + feeAmountForCalc)), 0)
820+ else $Tuple2(0, -((totalGet + feeAmountForCalc)))
821+ }
822+ let amountAssetBalanceDelta = $t03241932769._1
823+ let priceAssetBalanceDelta = $t03241932769._2
824+ let $t03277232880 = refreshDLpInternal(amountAssetBalanceDelta, priceAssetBalanceDelta, 0)
825+ let refreshDLpActions = $t03277232880._1
826+ let updatedDLp = $t03277232880._2
827+ let isUpdatedDLpValid = validateUpdatedDLp(currentDLp, updatedDLp)
828+ if ((isUpdatedDLpValid == isUpdatedDLpValid))
829+ then $Tuple2((state ++ refreshDLpActions), totalAmount)
830+ else throw("Strict value is not equal to itself.")
831+ }
832+ else throw("Strict value is not equal to itself.")
833+ }
834+ else throw("Strict value is not equal to itself.")
835+ }
836+ else throw("Strict value is not equal to itself.")
837+ }
838+ }
839+ else throw("Strict value is not equal to itself.")
840+ }
841+
842+
843+func m () = match getString(mpk()) {
844+ case s: String =>
845+ fromBase58String(s)
846+ case _: Unit =>
847+ unit
848+ case _ =>
849+ throw("Match error")
850+}
851+
852+
853+func pm () = match getString(pmpk()) {
854+ case s: String =>
855+ fromBase58String(s)
856+ case _: Unit =>
857+ unit
858+ case _ =>
859+ throw("Match error")
860+}
861+
862+
863+let pd = throw("Permission denied")
864+
865+func isManager (i) = match m() {
866+ case pk: ByteVector =>
867+ (i.callerPublicKey == pk)
868+ case _: Unit =>
869+ (i.caller == this)
870+ case _ =>
871+ throw("Match error")
872+}
873+
874+
875+func mm (i) = match m() {
876+ case pk: ByteVector =>
877+ if ((i.callerPublicKey == pk))
878+ then true
879+ else pd
880+ case _: Unit =>
881+ if ((i.caller == this))
882+ then true
883+ else pd
884+ case _ =>
885+ throw("Match error")
886+}
887+
888+
889+func getY (isReverse,D,poolAmountInBalance) = {
890+ let poolConfig = gpc()
891+ let amId = poolConfig[idxAmAsId]
892+ let prId = poolConfig[idxPrAsId]
893+ let n = big2
894+ let aPrecision = parseBigIntValue(Amult)
895+ let a = (parseBigIntValue(A) * aPrecision)
896+ let xp = if ((isReverse == false))
897+ then [(toBigInt(getAccBalance(amId)) + poolAmountInBalance), toBigInt(getAccBalance(prId))]
898+ else [(toBigInt(getAccBalance(prId)) + poolAmountInBalance), toBigInt(getAccBalance(amId))]
899+ let x = xp[0]
900+ let s = x
901+ let ann = (a * n)
902+ let c = (((((D * D) / (x * n)) * D) * aPrecision) / (ann * n))
903+ let b = ((s + ((D * aPrecision) / ann)) - D)
904+ func calc (acc,cur) = {
905+ let $t03432734347 = acc
906+ let y = $t03432734347._1
907+ let found = $t03432734347._2
908+ if ((found != unit))
909+ then acc
910+ else {
911+ let yNext = (((y * y) + c) / ((big2 * y) + b))
912+ let yDiff = absBigInt((yNext - value(y)))
913+ if ((big1 >= yDiff))
914+ then $Tuple2(yNext, cur)
915+ else $Tuple2(yNext, unit)
916+ }
917+ }
918+
919+ let arr = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14]
920+ let $t03467834725 = {
921+ let $l = arr
922+ let $s = size($l)
923+ let $acc0 = $Tuple2(D, unit)
924+ func $f0_1 ($a,$i) = if (($i >= $s))
925+ then $a
926+ else calc($a, $l[$i])
927+
928+ func $f0_2 ($a,$i) = if (($i >= $s))
929+ then $a
930+ else throw("List size exceeds 15")
931+
932+ $f0_2($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($f0_1($acc0, 0), 1), 2), 3), 4), 5), 6), 7), 8), 9), 10), 11), 12), 13), 14), 15)
933+ }
934+ let y = $t03467834725._1
935+ let found = $t03467834725._2
936+ if ((found != unit))
937+ then y
938+ else throw(("Y calculation error, Y = " + toString(y)))
939+ }
940+
941+
942+@Callable(i)
943+func calculateAmountOutForSwapREADONLY (cleanAmountIn,isReverse,feePoolAmount) = {
944+ let $t03496635390 = if ((isReverse == false))
945+ then {
946+ let assetOut = strf(this, pa())
947+ let poolAmountInBalance = (toBigInt(getAccBalance(strf(this, aa()))) + toBigInt(cleanAmountIn))
948+ $Tuple2(assetOut, poolAmountInBalance)
949+ }
950+ else {
951+ let assetOut = strf(this, aa())
952+ let poolAmountInBalance = (toBigInt(getAccBalance(strf(this, pa()))) + toBigInt(cleanAmountIn))
953+ $Tuple2(assetOut, poolAmountInBalance)
954+ }
955+ let assetOut = $t03496635390._1
956+ let poolAmountInBalance = $t03496635390._2
957+ let poolConfig = gpc()
958+ let amId = poolConfig[idxAmAsId]
959+ let prId = poolConfig[idxPrAsId]
960+ let xp = [toBigInt(getAccBalance(amId)), toBigInt(getAccBalance(prId))]
961+ let D = getD(xp)
962+ let y = getY(isReverse, D, toBigInt(cleanAmountIn))
963+ let dy = ((toBigInt(getAccBalance(assetOut)) - y) - toBigInt(1))
964+ let totalGetRaw = max([0, toInt(dy)])
965+ let newXp = if ((isReverse == false))
966+ then [((toBigInt(getAccBalance(amId)) + toBigInt(cleanAmountIn)) + toBigInt(feePoolAmount)), (toBigInt(getAccBalance(prId)) - dy)]
967+ else [(toBigInt(getAccBalance(amId)) - dy), ((toBigInt(getAccBalance(prId)) + toBigInt(cleanAmountIn)) + toBigInt(feePoolAmount))]
968+ let newD = getD(newXp)
969+ let checkD = if ((newD >= D))
970+ then true
971+ else throw(makeString(["new D is fewer error", toString(D), toString(newD)], "__"))
972+ if ((checkD == checkD))
973+ then $Tuple2(nil, totalGetRaw)
974+ else throw("Strict value is not equal to itself.")
975+ }
976+
977+
978+
979+@Callable(i)
980+func calculateAmountOutForSwapAndSendTokens (cleanAmountIn,isReverse,amountOutMin,addressTo,feePoolAmount) = {
981+ let swapContact = {
982+ let @ = invoke(fca, "getSwapContractREADONLY", nil, nil)
983+ if ($isInstanceOf(@, "String"))
984+ then @
985+ else throw(($getType(@) + " couldn't be cast to String"))
986+ }
987+ let checks = [if ((value(i.payments[0]).amount >= cleanAmountIn))
988+ then true
989+ else throwErr("Wrong amount"), if ((i.caller == addressFromStringValue(swapContact)))
990+ then true
991+ else throwErr("Permission denied")]
992+ if ((checks == checks))
993+ then {
994+ let pmt = value(i.payments[0])
995+ let assetIn = assetIdToString(pmt.assetId)
996+ let $t03682637220 = if ((isReverse == false))
997+ then {
998+ let assetOut = strf(this, pa())
999+ let poolAmountInBalance = (getAccBalance(assetIn) - value(i.payments[0]).amount)
1000+ $Tuple2(assetOut, poolAmountInBalance)
1001+ }
1002+ else {
1003+ let assetOut = strf(this, aa())
1004+ let poolAmountInBalance = (getAccBalance(assetIn) - value(i.payments[0]).amount)
1005+ $Tuple2(assetOut, poolAmountInBalance)
1006+ }
1007+ let assetOut = $t03682637220._1
1008+ let poolAmountInBalance = $t03682637220._2
1009+ let poolConfig = gpc()
1010+ let amId = poolConfig[idxAmAsId]
1011+ let prId = poolConfig[idxPrAsId]
1012+ let xp = if ((isReverse == false))
1013+ then [(toBigInt(getAccBalance(amId)) - toBigInt(value(i.payments[0]).amount)), toBigInt(getAccBalance(prId))]
1014+ else [toBigInt(getAccBalance(amId)), (toBigInt(getAccBalance(prId)) - toBigInt(value(i.payments[0]).amount))]
1015+ let D = getD(xp)
1016+ let y = getY(isReverse, D, toBigInt(0))
1017+ let dy = ((toBigInt(getAccBalance(assetOut)) - y) - toBigInt(1))
1018+ let totalGetRaw = max([0, toInt(dy)])
1019+ let checkMin = if ((totalGetRaw >= amountOutMin))
1020+ then true
1021+ else throw("Exchange result is fewer coins than expected")
1022+ if ((checkMin == checkMin))
1023+ then {
1024+ let newXp = if ((isReverse == false))
1025+ then [(toBigInt(getAccBalance(amId)) + toBigInt(feePoolAmount)), (toBigInt(getAccBalance(prId)) - dy)]
1026+ else [(toBigInt(getAccBalance(amId)) - dy), (toBigInt(getAccBalance(prId)) + toBigInt(feePoolAmount))]
1027+ let newD = getD(newXp)
1028+ let checkD = if ((newD >= D))
1029+ then true
1030+ else throw("new D is fewer error")
1031+ if ((checkD == checkD))
1032+ then $Tuple2([ScriptTransfer(addressFromStringValue(addressTo), totalGetRaw, parseAssetId(assetOut))], totalGetRaw)
1033+ else throw("Strict value is not equal to itself.")
1034+ }
1035+ else throw("Strict value is not equal to itself.")
1036+ }
1037+ else throw("Strict value is not equal to itself.")
1038+ }
1039+
1040+
1041+
1042+@Callable(i)
1043+func constructor (fc) = {
1044+ let c = mm(i)
1045+ if ((c == c))
1046+ then [StringEntry(fc(), fc)]
1047+ else throw("Strict value is not equal to itself.")
1048+ }
1049+
1050+
1051+
1052+@Callable(i)
1053+func setManager (pendingManagerPublicKey) = {
1054+ let c = mm(i)
1055+ if ((c == c))
1056+ then {
1057+ let cm = fromBase58String(pendingManagerPublicKey)
1058+ if ((cm == cm))
1059+ then [StringEntry(pmpk(), pendingManagerPublicKey)]
1060+ else throw("Strict value is not equal to itself.")
1061+ }
1062+ else throw("Strict value is not equal to itself.")
1063+ }
1064+
1065+
1066+
1067+@Callable(i)
1068+func confirmManager () = {
1069+ let p = pm()
1070+ let hpm = if (isDefined(p))
1071+ then true
1072+ else throw("No pending manager")
1073+ if ((hpm == hpm))
1074+ then {
1075+ let cpm = if ((i.callerPublicKey == value(p)))
1076+ then true
1077+ else throw("You are not pending manager")
1078+ if ((cpm == cpm))
1079+ then [StringEntry(mpk(), toBase58String(value(p))), DeleteEntry(pmpk())]
1080+ else throw("Strict value is not equal to itself.")
1081+ }
1082+ else throw("Strict value is not equal to itself.")
1083+ }
1084+
1085+
1086+
1087+@Callable(i)
1088+func put (slip,autoStake) = {
1089+ let factCfg = gfc()
1090+ let stakingCntr = valueOrErrorMessage(addressFromString(factCfg[idxFactStakCntr]), "Wr st addr")
1091+ let slipCntr = valueOrErrorMessage(addressFromString(factCfg[idxFactSlippCntr]), "Wr sl addr")
1092+ if ((0 > slip))
1093+ then throw("Wrong slippage")
1094+ else if ((size(i.payments) != 2))
1095+ then throw("2 pmnts expd")
1096+ else {
1097+ let amAssetPmt = toBigInt(value(i.payments[0]).amount)
1098+ let prAssetPmt = toBigInt(value(i.payments[1]).amount)
1099+ let amountAssetBalance = (toBigInt(getAccBalance(assetIdToString(cfgAmountAssetId))) - amAssetPmt)
1100+ if ((amountAssetBalance == amountAssetBalance))
1101+ then {
1102+ let priceAssetBalance = (toBigInt(getAccBalance(assetIdToString(cfgPriceAssetId))) - prAssetPmt)
1103+ if ((priceAssetBalance == priceAssetBalance))
1104+ then {
1105+ let lpAssetEmission = toBigInt(value(assetInfo(cfgLpAssetId)).quantity)
1106+ if ((lpAssetEmission == lpAssetEmission))
1107+ then {
1108+ let currentDLp = calcCurrentDLp(amAssetPmt, prAssetPmt, toBigInt(0))
1109+ if ((currentDLp == currentDLp))
1110+ then {
1111+ let e = cp(toString(i.caller), toBase58String(i.transactionId), AttachedPayment(value(i.payments[0]).assetId, value(i.payments[0]).amount), i.payments[1], slip, true, false, true, 0, "")
1112+ let emitLpAmt = e._2
1113+ let lpAssetId = e._7
1114+ let state = e._9
1115+ let amDiff = e._10
1116+ let prDiff = e._11
1117+ let amId = e._12
1118+ let prId = e._13
1119+ let r = invoke(fca, "emit", [emitLpAmt], nil)
1120+ if ((r == r))
1121+ then {
1122+ let el = match r {
1123+ case legacy: Address =>
1124+ invoke(legacy, "emit", [emitLpAmt], nil)
1125+ case _ =>
1126+ unit
1127+ }
1128+ if ((el == el))
1129+ then {
1130+ let sa = if ((amDiff > 0))
1131+ then invoke(slipCntr, "put", nil, [AttachedPayment(amId, amDiff)])
1132+ else nil
1133+ if ((sa == sa))
1134+ then {
1135+ let sp = if ((prDiff > 0))
1136+ then invoke(slipCntr, "put", nil, [AttachedPayment(prId, prDiff)])
1137+ else nil
1138+ if ((sp == sp))
1139+ then {
1140+ let lpTrnsfr = if (autoStake)
1141+ then {
1142+ let ss = invoke(stakingCntr, "stake", nil, [AttachedPayment(lpAssetId, emitLpAmt)])
1143+ if ((ss == ss))
1144+ then nil
1145+ else throw("Strict value is not equal to itself.")
1146+ }
1147+ else [ScriptTransfer(i.caller, emitLpAmt, lpAssetId)]
1148+ let $t04183941981 = refreshDLpInternal(0, 0, 0)
1149+ let refreshDLpActions = $t04183941981._1
1150+ let updatedDLp = $t04183941981._2
1151+ let check = if ((updatedDLp >= currentDLp))
1152+ then true
1153+ else throwErr(makeString(["updated DLp lower than current DLp", toString(amountAssetBalance), toString(priceAssetBalance), toString(lpAssetEmission), toString(currentDLp), toString(updatedDLp), toString(amDiff), toString(prDiff)], " "))
1154+ if ((check == check))
1155+ then {
1156+ let lpAssetEmissionAfter = value(assetInfo(cfgLpAssetId)).quantity
1157+ if ((lpAssetEmissionAfter == lpAssetEmissionAfter))
1158+ then ((state ++ lpTrnsfr) ++ refreshDLpActions)
1159+ else throw("Strict value is not equal to itself.")
1160+ }
1161+ else throw("Strict value is not equal to itself.")
1162+ }
1163+ else throw("Strict value is not equal to itself.")
1164+ }
1165+ else throw("Strict value is not equal to itself.")
1166+ }
1167+ else throw("Strict value is not equal to itself.")
1168+ }
1169+ else throw("Strict value is not equal to itself.")
1170+ }
1171+ else throw("Strict value is not equal to itself.")
1172+ }
1173+ else throw("Strict value is not equal to itself.")
1174+ }
1175+ else throw("Strict value is not equal to itself.")
1176+ }
1177+ else throw("Strict value is not equal to itself.")
1178+ }
1179+ }
1180+
1181+
1182+
1183+@Callable(i)
1184+func putOneTknV2 (minOutAmount,autoStake) = {
1185+ let isPoolOneTokenOperationsDisabled = {
1186+ let @ = invoke(fca, "isPoolOneTokenOperationsDisabledREADONLY", [toString(this)], nil)
1187+ if ($isInstanceOf(@, "Boolean"))
1188+ then @
1189+ else throw(($getType(@) + " couldn't be cast to Boolean"))
1190+ }
1191+ let isPutDisabled = if (if (if (igs())
1192+ then true
1193+ else (cfgPoolStatus == PoolPutDis))
1194+ then true
1195+ else (cfgPoolStatus == PoolShutdown))
1196+ then true
1197+ else isPoolOneTokenOperationsDisabled
1198+ let checks = [if (if (!(isPutDisabled))
1199+ then true
1200+ else isManager(i))
1201+ then true
1202+ else throwErr("put operation is blocked by admin"), if ((size(i.payments) == 1))
1203+ then true
1204+ else throwErr("exactly 1 payment are expected")]
1205+ if ((checks == checks))
1206+ then {
1207+ let amId = toBase58String(value(cfgAmountAssetId))
1208+ let prId = toBase58String(value(cfgPriceAssetId))
1209+ let lpId = cfgLpAssetId
1210+ let amDecimals = cfgAmountAssetDecimals
1211+ let prDecimals = cfgPriceAssetDecimals
1212+ let userAddress = if ((i.caller == this))
1213+ then i.originCaller
1214+ else i.caller
1215+ let pmt = value(i.payments[0])
1216+ let pmtAssetId = toBase58String(value(pmt.assetId))
1217+ let pmtAmt = pmt.amount
1218+ let currentDLp = if ((pmt.assetId == cfgAmountAssetId))
1219+ then calcCurrentDLp(toBigInt(pmtAmt), toBigInt(0), toBigInt(0))
1220+ else calcCurrentDLp(toBigInt(0), toBigInt(pmtAmt), toBigInt(0))
1221+ if ((currentDLp == currentDLp))
1222+ then {
1223+ let $t04362243780 = calcPutOneTkn(pmtAmt, pmtAssetId, toString(userAddress), toBase58String(i.transactionId), true)
1224+ if (($t04362243780 == $t04362243780))
1225+ then {
1226+ let feeAmount = $t04362243780._3
1227+ let state = $t04362243780._2
1228+ let estimLP = $t04362243780._1
1229+ let emitLpAmt = if (if ((minOutAmount > 0))
1230+ then (minOutAmount > estimLP)
1231+ else false)
1232+ then throwErr(makeString(["amount to receive is less than ", toString(minOutAmount)], ""))
1233+ else estimLP
1234+ let e = invoke(fca, "emit", [emitLpAmt], nil)
1235+ if ((e == e))
1236+ then {
1237+ let el = match e {
1238+ case legacy: Address =>
1239+ invoke(legacy, "emit", [emitLpAmt], nil)
1240+ case _ =>
1241+ unit
1242+ }
1243+ if ((el == el))
1244+ then {
1245+ let lpTrnsfr = if (autoStake)
1246+ then {
1247+ let ss = invoke(stakingContract, "stake", nil, [AttachedPayment(lpId, emitLpAmt)])
1248+ if ((ss == ss))
1249+ then nil
1250+ else throw("Strict value is not equal to itself.")
1251+ }
1252+ else [ScriptTransfer(i.caller, emitLpAmt, lpId)]
1253+ let sendFeeToMatcher = if ((feeAmount > 0))
1254+ then [ScriptTransfer(feeCollectorAddress, feeAmount, fromBase58String(pmtAssetId))]
1255+ else nil
1256+ let $t04459544944 = if ((this == feeCollectorAddress))
1257+ then $Tuple2(0, 0)
1258+ else {
1259+ let paymentInAmountAsset = if ((pmt.assetId == cfgAmountAssetId))
1260+ then true
1261+ else false
1262+ if (paymentInAmountAsset)
1263+ then $Tuple2(-(feeAmount), 0)
1264+ else $Tuple2(0, -(feeAmount))
1265+ }
1266+ let amountAssetBalanceDelta = $t04459544944._1
1267+ let priceAssetBalanceDelta = $t04459544944._2
1268+ let $t04494745055 = refreshDLpInternal(amountAssetBalanceDelta, priceAssetBalanceDelta, 0)
1269+ let refreshDLpActions = $t04494745055._1
1270+ let updatedDLp = $t04494745055._2
1271+ let isUpdatedDLpValid = validateUpdatedDLp(currentDLp, updatedDLp)
1272+ if ((isUpdatedDLpValid == isUpdatedDLpValid))
1273+ then $Tuple2((((state ++ lpTrnsfr) ++ sendFeeToMatcher) ++ refreshDLpActions), emitLpAmt)
1274+ else throw("Strict value is not equal to itself.")
1275+ }
1276+ else throw("Strict value is not equal to itself.")
1277+ }
1278+ else throw("Strict value is not equal to itself.")
1279+ }
1280+ else throw("Strict value is not equal to itself.")
1281+ }
1282+ else throw("Strict value is not equal to itself.")
1283+ }
1284+ else throw("Strict value is not equal to itself.")
1285+ }
1286+
1287+
1288+
1289+@Callable(i)
1290+func putForFree (maxSlpg) = if ((0 > maxSlpg))
1291+ then throw("Wrong slpg")
1292+ else if ((size(i.payments) != 2))
1293+ then throw("2 pmnts expd")
1294+ else {
1295+ let estPut = cp(toString(i.caller), toBase58String(i.transactionId), AttachedPayment(value(i.payments[0]).assetId, value(i.payments[0]).amount), i.payments[1], maxSlpg, false, false, true, 0, "")
1296+ let state = estPut._9
1297+ let amAssetPmt = toBigInt(value(i.payments[0]).amount)
1298+ let prAssetPmt = toBigInt(value(i.payments[1]).amount)
1299+ let currentDLp = calcCurrentDLp(amAssetPmt, prAssetPmt, toBigInt(0))
1300+ if ((currentDLp == currentDLp))
1301+ then {
1302+ let $t04608546150 = refreshDLpInternal(0, 0, 0)
1303+ let refreshDLpActions = $t04608546150._1
1304+ let updatedDLp = $t04608546150._2
1305+ let isUpdatedDLpValid = validateUpdatedDLp(currentDLp, updatedDLp)
1306+ if ((isUpdatedDLpValid == isUpdatedDLpValid))
1307+ then (state ++ refreshDLpActions)
1308+ else throw("Strict value is not equal to itself.")
1309+ }
1310+ else throw("Strict value is not equal to itself.")
1311+ }
1312+
1313+
1314+
1315+@Callable(i)
1316+func get () = {
1317+ let currentDLp = calcCurrentDLp(toBigInt(0), toBigInt(0), toBigInt(0))
1318+ if ((currentDLp == currentDLp))
1319+ then {
1320+ let r = cg(i)
1321+ let outAmtAmt = r._1
1322+ let outPrAmt = r._2
1323+ let pmtAmt = r._3
1324+ let pmtAssetId = r._4
1325+ let state = r._5
1326+ let b = invoke(fca, "burn", [pmtAmt], [AttachedPayment(pmtAssetId, pmtAmt)])
1327+ if ((b == b))
1328+ then {
1329+ let $t04732347405 = refreshDLpInternal(-(outAmtAmt), -(outPrAmt), 0)
1330+ let refreshDLpActions = $t04732347405._1
1331+ let updatedDLp = $t04732347405._2
1332+ let isUpdatedDLpValid = validateUpdatedDLp(currentDLp, updatedDLp)
1333+ if ((isUpdatedDLpValid == isUpdatedDLpValid))
1334+ then (state ++ refreshDLpActions)
1335+ else throw("Strict value is not equal to itself.")
1336+ }
1337+ else throw("Strict value is not equal to itself.")
1338+ }
1339+ else throw("Strict value is not equal to itself.")
1340+ }
1341+
1342+
1343+
1344+@Callable(i)
1345+func getOneTknV2 (outAssetId,minOutAmount) = {
1346+ let isPoolOneTokenOperationsDisabled = {
1347+ let @ = invoke(fca, "isPoolOneTokenOperationsDisabledREADONLY", [toString(this)], nil)
1348+ if ($isInstanceOf(@, "Boolean"))
1349+ then @
1350+ else throw(($getType(@) + " couldn't be cast to Boolean"))
1351+ }
1352+ let isGetDisabled = if (if (igs())
1353+ then true
1354+ else (cfgPoolStatus == PoolShutdown))
1355+ then true
1356+ else isPoolOneTokenOperationsDisabled
1357+ let checks = [if (if (!(isGetDisabled))
1358+ then true
1359+ else isManager(i))
1360+ then true
1361+ else throwErr("get operation is blocked by admin"), if ((size(i.payments) == 1))
1362+ then true
1363+ else throwErr("exactly 1 payment are expected")]
1364+ if ((checks == checks))
1365+ then {
1366+ let $t04802348178 = getOneTknV2Internal(outAssetId, minOutAmount, i.payments, i.caller, i.originCaller, i.transactionId)
1367+ let state = $t04802348178._1
1368+ let totalAmount = $t04802348178._2
1369+ $Tuple2(state, totalAmount)
1370+ }
1371+ else throw("Strict value is not equal to itself.")
1372+ }
1373+
1374+
1375+
1376+@Callable(i)
1377+func refreshDLp () = {
1378+ let lastRefreshedBlockHeight = valueOrElse(getInteger(keyDLpRefreshedHeight), 0)
1379+ let checkLastRefreshedBlockHeight = if (((height - lastRefreshedBlockHeight) >= dLpRefreshDelay))
1380+ then unit
1381+ else throwErr(makeString([toString(dLpRefreshDelay), " blocks have not passed since the previous call"], ""))
1382+ if ((checkLastRefreshedBlockHeight == checkLastRefreshedBlockHeight))
1383+ then {
1384+ let dLp = valueOrErrorMessage(parseBigInt(valueOrElse(getString(this, keyDLp), "0")), fmtErr("invalid dLp"))
1385+ let $t04870248766 = refreshDLpInternal(0, 0, 0)
1386+ let dLpUpdateActions = $t04870248766._1
1387+ let updatedDLp = $t04870248766._2
1388+ let actions = if ((dLp != updatedDLp))
1389+ then dLpUpdateActions
1390+ else throwErr("nothing to refresh")
1391+ $Tuple2(actions, toString(updatedDLp))
1392+ }
1393+ else throw("Strict value is not equal to itself.")
1394+ }
1395+
1396+
1397+
1398+@Callable(i)
1399+func getOneTknV2READONLY (outAssetId,lpAssetAmount) = {
1400+ let amId = toBase58String(value(cfgAmountAssetId))
1401+ let prId = toBase58String(value(cfgPriceAssetId))
1402+ let lpId = toBase58String(value(cfgLpAssetId))
1403+ let xp = [toBigInt(getAccBalance(amId)), toBigInt(getAccBalance(prId))]
1404+ let lpEmission = toBigInt(valueOrErrorMessage(assetInfo(fromBase58String(lpId)), "invalid lp asset").quantity)
1405+ let D0 = getD(xp)
1406+ let D1 = (D0 - fraction(toBigInt(lpAssetAmount), D0, lpEmission))
1407+ let index = if ((outAssetId == amId))
1408+ then 0
1409+ else if ((outAssetId == prId))
1410+ then 1
1411+ else throw("invalid out asset id")
1412+ let newY = getYD(xp, index, D1)
1413+ let dy = (xp[index] - newY)
1414+ let totalGetRaw = max([0, toInt((dy - big1))])
1415+ let $t04977649831 = takeFee(totalGetRaw, outFee)
1416+ let totalGet = $t04977649831._1
1417+ let feeAmount = $t04977649831._2
1418+ $Tuple2(nil, $Tuple2(totalGet, feeAmount))
1419+ }
1420+
1421+
1422+
1423+@Callable(i)
1424+func getOneTknV2WithBonusREADONLY (outAssetId,lpAssetAmount) = {
1425+ let amId = toBase58String(value(cfgAmountAssetId))
1426+ let prId = toBase58String(value(cfgPriceAssetId))
1427+ let lpId = toBase58String(value(cfgLpAssetId))
1428+ let amBalance = getAccBalance(amId)
1429+ let prBalance = getAccBalance(prId)
1430+ let $t05020650321 = {
1431+ let @ = invoke(this, "getOneTknV2READONLY", [outAssetId, lpAssetAmount], nil)
1432+ if ($isInstanceOf(@, "(Int, Int)"))
1433+ then @
1434+ else throw(($getType(@) + " couldn't be cast to (Int, Int)"))
1435+ }
1436+ let totalGet = $t05020650321._1
1437+ let feeAmount = $t05020650321._2
1438+ let r = ego("", lpId, lpAssetAmount, this)
1439+ let outAmAmt = r._1
1440+ let outPrAmt = r._2
1441+ let sumOfGetAssets = (outAmAmt + outPrAmt)
1442+ let bonus = if ((sumOfGetAssets == 0))
1443+ then if ((totalGet == 0))
1444+ then 0
1445+ else throw("bonus calculation error")
1446+ else fraction((totalGet - sumOfGetAssets), scale8, sumOfGetAssets)
1447+ $Tuple2(nil, $Tuple3(totalGet, feeAmount, bonus))
1448+ }
1449+
1450+
1451+
1452+@Callable(i)
1453+func getNoLess (noLessThenAmtAsset,noLessThenPriceAsset) = {
1454+ let r = cg(i)
1455+ let outAmAmt = r._1
1456+ let outPrAmt = r._2
1457+ let pmtAmt = r._3
1458+ let pmtAssetId = r._4
1459+ let state = r._5
1460+ if ((noLessThenAmtAsset > outAmAmt))
1461+ then throw(((("Failed: " + toString(outAmAmt)) + " < ") + toString(noLessThenAmtAsset)))
1462+ else if ((noLessThenPriceAsset > outPrAmt))
1463+ then throw(((("Failed: " + toString(outPrAmt)) + " < ") + toString(noLessThenPriceAsset)))
1464+ else {
1465+ let currentDLp = calcCurrentDLp(toBigInt(0), toBigInt(0), toBigInt(0))
1466+ if ((currentDLp == currentDLp))
1467+ then {
1468+ let burnLPAssetOnFactory = invoke(fca, "burn", [pmtAmt], [AttachedPayment(pmtAssetId, pmtAmt)])
1469+ if ((burnLPAssetOnFactory == burnLPAssetOnFactory))
1470+ then {
1471+ let $t05148751568 = refreshDLpInternal(-(outAmAmt), -(outPrAmt), 0)
1472+ let refreshDLpActions = $t05148751568._1
1473+ let updatedDLp = $t05148751568._2
1474+ let isUpdatedDLpValid = validateUpdatedDLp(currentDLp, updatedDLp)
1475+ if ((isUpdatedDLpValid == isUpdatedDLpValid))
1476+ then (state ++ refreshDLpActions)
1477+ else throw("Strict value is not equal to itself.")
1478+ }
1479+ else throw("Strict value is not equal to itself.")
1480+ }
1481+ else throw("Strict value is not equal to itself.")
1482+ }
1483+ }
1484+
1485+
1486+
1487+@Callable(i)
1488+func unstakeAndGet (amount) = {
1489+ let checkPayments = if ((size(i.payments) != 0))
1490+ then throw("No pmnts expd")
1491+ else true
1492+ if ((checkPayments == checkPayments))
1493+ then {
1494+ let factoryCfg = gfc()
1495+ let lpAssetId = cfgLpAssetId
1496+ let staking = valueOrErrorMessage(addressFromString(factoryCfg[idxFactStakCntr]), "Wr st addr")
1497+ let currentDLp = calcCurrentDLp(toBigInt(0), toBigInt(0), toBigInt(0))
1498+ if ((currentDLp == currentDLp))
1499+ then {
1500+ let unstakeInv = invoke(staking, "unstake", [toBase58String(lpAssetId), amount], nil)
1501+ if ((unstakeInv == unstakeInv))
1502+ then {
1503+ let r = ego(toBase58String(i.transactionId), toBase58String(lpAssetId), amount, i.caller)
1504+ let outAmAmt = r._1
1505+ let outPrAmt = r._2
1506+ let sts = parseIntValue(r._9)
1507+ let state = r._10
1508+ let v = if (if (igs())
1509+ then true
1510+ else (sts == PoolShutdown))
1511+ then throw(("Blocked: " + toString(sts)))
1512+ else true
1513+ if ((v == v))
1514+ then {
1515+ let burnA = invoke(fca, "burn", [amount], [AttachedPayment(lpAssetId, amount)])
1516+ if ((burnA == burnA))
1517+ then {
1518+ let $t05259552676 = refreshDLpInternal(-(outAmAmt), -(outPrAmt), 0)
1519+ let refreshDLpActions = $t05259552676._1
1520+ let updatedDLp = $t05259552676._2
1521+ let isUpdatedDLpValid = validateUpdatedDLp(currentDLp, updatedDLp)
1522+ if ((isUpdatedDLpValid == isUpdatedDLpValid))
1523+ then (state ++ refreshDLpActions)
1524+ else throw("Strict value is not equal to itself.")
1525+ }
1526+ else throw("Strict value is not equal to itself.")
1527+ }
1528+ else throw("Strict value is not equal to itself.")
1529+ }
1530+ else throw("Strict value is not equal to itself.")
1531+ }
1532+ else throw("Strict value is not equal to itself.")
1533+ }
1534+ else throw("Strict value is not equal to itself.")
1535+ }
1536+
1537+
1538+
1539+@Callable(i)
1540+func unstakeAndGetNoLess (unstakeAmount,noLessThenAmountAsset,noLessThenPriceAsset) = {
1541+ let isGetDisabled = if (igs())
1542+ then true
1543+ else (cfgPoolStatus == PoolShutdown)
1544+ let checks = [if (!(isGetDisabled))
1545+ then true
1546+ else throw("get operation is blocked by admin"), if ((size(i.payments) == 0))
1547+ then true
1548+ else throw("no payments are expected")]
1549+ if ((checks == checks))
1550+ then {
1551+ let currentDLp = calcCurrentDLp(toBigInt(0), toBigInt(0), toBigInt(0))
1552+ if ((currentDLp == currentDLp))
1553+ then {
1554+ let unstakeInv = invoke(stakingContract, "unstake", [toBase58String(cfgLpAssetId), unstakeAmount], nil)
1555+ if ((unstakeInv == unstakeInv))
1556+ then {
1557+ let res = ego(toBase58String(i.transactionId), toBase58String(cfgLpAssetId), unstakeAmount, i.caller)
1558+ let outAmAmt = res._1
1559+ let outPrAmt = res._2
1560+ let state = res._10
1561+ let checkAmounts = [if ((outAmAmt >= noLessThenAmountAsset))
1562+ then true
1563+ else throw(makeString(["amount asset amount to receive is less than ", toString(noLessThenAmountAsset)], "")), if ((outPrAmt >= noLessThenPriceAsset))
1564+ then true
1565+ else throw(makeString(["price asset amount to receive is less than ", toString(noLessThenPriceAsset)], ""))]
1566+ if ((checkAmounts == checkAmounts))
1567+ then {
1568+ let burnLPAssetOnFactory = invoke(fca, "burn", [unstakeAmount], [AttachedPayment(cfgLpAssetId, unstakeAmount)])
1569+ if ((burnLPAssetOnFactory == burnLPAssetOnFactory))
1570+ then {
1571+ let $t05392754008 = refreshDLpInternal(-(outAmAmt), -(outPrAmt), 0)
1572+ let refreshDLpActions = $t05392754008._1
1573+ let updatedDLp = $t05392754008._2
1574+ let isUpdatedDLpValid = validateUpdatedDLp(currentDLp, updatedDLp)
1575+ if ((isUpdatedDLpValid == isUpdatedDLpValid))
1576+ then (state ++ refreshDLpActions)
1577+ else throw("Strict value is not equal to itself.")
1578+ }
1579+ else throw("Strict value is not equal to itself.")
1580+ }
1581+ else throw("Strict value is not equal to itself.")
1582+ }
1583+ else throw("Strict value is not equal to itself.")
1584+ }
1585+ else throw("Strict value is not equal to itself.")
1586+ }
1587+ else throw("Strict value is not equal to itself.")
1588+ }
1589+
1590+
1591+
1592+@Callable(i)
1593+func unstakeAndGetOneTknV2 (unstakeAmount,outAssetId,minOutAmount) = {
1594+ let isPoolOneTokenOperationsDisabled = {
1595+ let @ = invoke(fca, "isPoolOneTokenOperationsDisabledREADONLY", [toString(this)], nil)
1596+ if ($isInstanceOf(@, "Boolean"))
1597+ then @
1598+ else throw(($getType(@) + " couldn't be cast to Boolean"))
1599+ }
1600+ let isGetDisabled = if (if (igs())
1601+ then true
1602+ else (cfgPoolStatus == PoolShutdown))
1603+ then true
1604+ else isPoolOneTokenOperationsDisabled
1605+ let checks = [if (if (!(isGetDisabled))
1606+ then true
1607+ else isManager(i))
1608+ then true
1609+ else throwErr("get operation is blocked by admin"), if ((size(i.payments) == 0))
1610+ then true
1611+ else throwErr("no payments are expected")]
1612+ if ((checks == checks))
1613+ then {
1614+ let factoryCfg = gfc()
1615+ let lpAssetId = cfgLpAssetId
1616+ let staking = valueOrErrorMessage(addressFromString(factoryCfg[idxFactStakCntr]), "Wr st addr")
1617+ let userAddress = i.caller
1618+ let lpAssetRecipientAddress = this
1619+ let unstakeInv = invoke(staking, "unstakeINTERNAL", [lpAssetId, unstakeAmount, userAddress.bytes, lpAssetRecipientAddress.bytes], nil)
1620+ if ((unstakeInv == unstakeInv))
1621+ then {
1622+ let $t05503055218 = getOneTknV2Internal(outAssetId, minOutAmount, [AttachedPayment(lpAssetId, unstakeAmount)], i.caller, i.originCaller, i.transactionId)
1623+ let state = $t05503055218._1
1624+ let totalAmount = $t05503055218._2
1625+ $Tuple2(state, totalAmount)
1626+ }
1627+ else throw("Strict value is not equal to itself.")
1628+ }
1629+ else throw("Strict value is not equal to itself.")
1630+ }
1631+
1632+
1633+
1634+@Callable(i)
1635+func putOneTknV2WithBonusREADONLY (paymentAmountRaw,paymentAssetId) = {
1636+ let $t05534655449 = calcPutOneTkn(paymentAmountRaw, paymentAssetId, "", "", true)
1637+ let lpAmount = $t05534655449._1
1638+ let state = $t05534655449._2
1639+ let feeAmount = $t05534655449._3
1640+ let bonus = $t05534655449._4
1641+ $Tuple2(nil, $Tuple3(lpAmount, feeAmount, bonus))
1642+ }
1643+
1644+
1645+
1646+@Callable(i)
1647+func putOneTknV2WithoutTakeFeeREADONLY (paymentAmountRaw,paymentAssetId) = {
1648+ let $t05559755701 = calcPutOneTkn(paymentAmountRaw, paymentAssetId, "", "", false)
1649+ let lpAmount = $t05559755701._1
1650+ let state = $t05559755701._2
1651+ let feeAmount = $t05559755701._3
1652+ let bonus = $t05559755701._4
1653+ $Tuple2(nil, $Tuple3(lpAmount, feeAmount, bonus))
1654+ }
1655+
1656+
1657+
1658+@Callable(i)
1659+func activate (amtAsStr,prAsStr) = if ((toString(i.caller) != toString(fca)))
1660+ then throw("denied")
1661+ else $Tuple2([StringEntry(aa(), amtAsStr), StringEntry(pa(), prAsStr)], "success")
1662+
1663+
1664+
1665+@Callable(i)
1666+func setS (k,v) = if ((toString(i.caller) != strf(this, ada())))
1667+ then pd
1668+ else [StringEntry(k, v)]
1669+
1670+
1671+
1672+@Callable(i)
1673+func setI (k,v) = if ((toString(i.caller) != strf(this, ada())))
1674+ then pd
1675+ else [IntegerEntry(k, v)]
1676+
1677+
1678+
1679+@Callable(i)
1680+func getPoolConfigWrapperREADONLY () = $Tuple2(nil, gpc())
1681+
1682+
1683+
1684+@Callable(i)
1685+func getAccBalanceWrapperREADONLY (assetId) = $Tuple2(nil, getAccBalance(assetId))
1686+
1687+
1688+
1689+@Callable(i)
1690+func calcPricesWrapperREADONLY (amAmt,prAmt,lpAmt) = {
1691+ let pr = calcPrices(amAmt, prAmt, lpAmt)
1692+ $Tuple2(nil, [toString(pr[0]), toString(pr[1]), toString(pr[2])])
1693+ }
1694+
1695+
1696+
1697+@Callable(i)
1698+func fromX18WrapperREADONLY (val,resScaleMult) = $Tuple2(nil, f1(parseBigIntValue(val), resScaleMult))
1699+
1700+
1701+
1702+@Callable(i)
1703+func toX18WrapperREADONLY (origVal,origScaleMult) = $Tuple2(nil, toString(t1(origVal, origScaleMult)))
1704+
1705+
1706+
1707+@Callable(i)
1708+func calcPriceBigIntWrapperREADONLY (prAmtX18,amAmtX18) = $Tuple2(nil, toString(cpbi(parseBigIntValue(prAmtX18), parseBigIntValue(amAmtX18))))
1709+
1710+
1711+
1712+@Callable(i)
1713+func estimatePutOperationWrapperREADONLY (txId58,slippage,inAmAmt,inAmId,inPrAmt,inPrId,usrAddr,isEval,emitLp) = $Tuple2(nil, epo(txId58, slippage, inAmAmt, inAmId, inPrAmt, inPrId, usrAddr, isEval, emitLp, true, false, 0, ""))
1714+
1715+
1716+
1717+@Callable(i)
1718+func estimateGetOperationWrapperREADONLY (txId58,pmtAsId,pmtLpAmt,usrAddr) = {
1719+ let r = ego(txId58, pmtAsId, pmtLpAmt, addressFromStringValue(usrAddr))
1720+ $Tuple2(nil, $Tuple10(r._1, r._2, r._3, r._4, r._5, r._6, r._7, toString(r._8), r._9, r._10))
1721+ }
1722+
1723+
1724+@Verifier(tx)
1725+func verify () = {
1726+ let targetPublicKey = match m() {
1727+ case pk: ByteVector =>
1728+ pk
1729+ case _: Unit =>
1730+ tx.senderPublicKey
1731+ case _ =>
1732+ throw("Match error")
1733+ }
1734+ match tx {
1735+ case order: Order =>
1736+ let matcherPub = mp()
1737+ let $t05849358562 = validateMatcherOrderAllowed(order)
1738+ let orderValid = $t05849358562._1
1739+ let orderValidInfo = $t05849358562._2
1740+ let senderValid = sigVerify(order.bodyBytes, order.proofs[0], order.senderPublicKey)
1741+ let matcherValid = sigVerify(order.bodyBytes, order.proofs[1], matcherPub)
1742+ if (if (if (orderValid)
1743+ then senderValid
1744+ else false)
1745+ then matcherValid
1746+ else false)
1747+ then true
1748+ else throwOrderError(orderValid, orderValidInfo, senderValid, matcherValid)
1749+ case s: SetScriptTransaction =>
1750+ if (sigVerify(tx.bodyBytes, tx.proofs[0], targetPublicKey))
1751+ then true
1752+ else {
1753+ let newHash = blake2b256(value(s.script))
1754+ let allowedHash = fromBase64String(value(getString(fca, keyAllowedLpStableScriptHash())))
1755+ let currentHash = scriptHash(this)
1756+ if ((allowedHash == newHash))
1757+ then (currentHash != newHash)
1758+ else false
1759+ }
1760+ case _ =>
1761+ sigVerify(tx.bodyBytes, tx.proofs[0], targetPublicKey)
1762+ }
1763+ }
1764+

github/deemru/w8io/3ef1775 
108.91 ms